集成 picgo 到思源

本贴最后更新于 816 天前,其中的信息可能已经时移世改

主要是上传部分,菜单之类的可以自己实现一下

export class picGo extends naive.plugin {
  constructor() {
    super({name:picGo});
    this.初始化();
    let 导出按钮设置 = {
      按钮提示: "上传到picgo",
      按钮图标: "#iconUpload",
      按钮文字: "上传到picgo",
      回调函数: (event) => {
        this.点击上传文档图片(event);
      },
    };
    let 文档按钮设置 = {
      块类型: "NodeDocument",
      菜单图标: "#iconUpload",
      菜单文字: "上传到picgo",
      回调函数: () => {
        this.id上传文档图片(this.当前文档id);
      },
    };
    let 图片菜单设置 = {
        块类型: "image",
        菜单图标: "#iconUpload",
        菜单文字: "上传到picgo",
        回调函数: () => {
          this.上传单张图片();
        },
      };
      let 图片菜单设置1 = {
        块类型: "image",
        菜单图标: "#iconUpload",
        菜单文字: "上传到picgo并改变地址",
        回调函数: () => {
          this.上传单张图片(true);
        },
      };
    this.注册预览按钮(导出按钮设置);
    this.注册文档右上角菜单(文档按钮设置);
    this.注册图片菜单(图片菜单设置);
    this.注册图片菜单(图片菜单设置1);
    this.注册文档树菜单(文档按钮设置)
  }
  async 初始化() {
    let {
      PicGo,
    } = require(`${naive.pathConstructor.pluginsPath()}/picGo/node_modules/picgo`);
    this.picGoPath = this.initFolder();
    this.picgo = new PicGo(this.picGoPath + "/picgoConfig.json");
    let that = this;
    this.picgo.on("afterUpload", function (ctx) {
      console.log(ctx.output);
      ctx.output.forEach((image) => {
        console.log(image);
        console.log(that);
        if (that.previewer) {
          that.添加图片(that.previewer, image);
        }
      });
      alert("上传完成"); // [{fileName, width, height, extname, imgUrl}] <- 注意有imgUrl了。
    });
  }
  上传完成回调() {}
  添加图片(previewer, image) {
    let url = image.imgUrl;
    let name = image.fileName;
    let imageEls = previewer.querySelectorAll(`img[src='assets/${name}']`);
    console.log(imageEls);
    if (imageEls[0]) {
      imageEls.forEach((el) => {
        el.src = url;
      });
    }
  }

  async 点击上传文档图片(event) {
    event.stopPropagation();
    console.log(event.currentTarget.parentElement.parentElement.parentElement);
    let id =
      event.currentTarget.parentElement.parentElement.previousElementSibling
        .firstElementChild.dataset.nodeId;
    console.log(id);
    this.previewer = event.currentTarget.parentElement.nextElementSibling;
    console.log(this.previewer);
    let images = await this.kernelApi.获取文档图片附件({ id: id });
    console.log(images);
    if (images) {
      images.forEach((image) => {
        if (image.startsWith("assets")) {
          let realimage = this.app.workspaceDir + "/data/" + image;
          this.picgo.upload([realimage]);
        }
      });
    }
  }
  async id上传文档图片(id) {
    console.log(id);
    let images = await this.kernelApi.获取文档图片附件({ id: id });
    console.log(images);
    if (images) {
      images.forEach((image) => {
        if (image.startsWith("assets")) {
          let realimage = this.app.workspaceDir + "/data/" + image;
          this.picgo.upload([realimage]);
        }
      });
    }
  }
  async 上传单张图片(flag){
    let imagePath = (window.siyuan.menus.menu.element.querySelector('[placeholder="图片地址"]')).value+''
    if (imagePath.startsWith("assets")) {
        let realimage = this.app.workspaceDir + "/data/" + imagePath;
        this.picgo.upload([realimage]);
      }
    if(flag){
        this.picgo.on("afterUpload", (ctx)=> {
            ctx.output.forEach((image) => {
              console.log(image);
              (window.siyuan.menus.menu.element.querySelector('[placeholder="图片地址"]')).value=image.imgUrl
              let imageEls = document.querySelectorAll(`img[src='${imagePath}']`);
              console.log(imageEls)
              imageEls.forEach(
                el=>el.setAttribute('src',image.imgUrl)
              )
            });
            alert("上传完成"); // [{fileName, width, height, extname, imgUrl}] <- 注意有imgUrl了。
          });
  
    }
  }
}
export const environments =['APP']

设置界面自己实现一下吧就行了,反正就是改 json

  • 思源笔记

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

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

    22351 引用 • 89426 回帖 • 1 关注

相关帖子

欢迎来到这里!

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

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

    哇哦,中文编程哎

  • 其他回帖
  • caogle

    想用自定义的图床,把 picgo 集成到思源内,请问上面的代码如何运行?

推荐标签 标签

  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    125 引用 • 169 回帖 • 1 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 72 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 210 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 94 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1327 回帖
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖
  • BAE

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

    19 引用 • 75 回帖 • 641 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • 钉钉

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

    15 引用 • 67 回帖 • 340 关注
  • 安全

    安全永远都不是一个小问题。

    199 引用 • 816 回帖 • 1 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 62 关注
  • Dubbo

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

    60 引用 • 82 回帖 • 595 关注
  • uTools

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

    6 引用 • 14 回帖 • 2 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 660 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 48 关注
  • ZooKeeper

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

    59 引用 • 29 回帖 • 4 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 411 关注
  • Netty

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

    49 引用 • 33 回帖 • 21 关注
  • 宕机

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

    13 引用 • 82 回帖 • 52 关注
  • Windows

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

    222 引用 • 473 回帖
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 177 关注
  • 数据库

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

    342 引用 • 708 回帖
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 26 关注