Logseq Plugins 开发实战
  • Logseq Plugins 开发实战
  • 第一章
    • 搭建开发环境
    • 一个随机句子插件
    • 为logseq添加内容组件
    • 制作一个toolbar仪表盘
    • 制作一个表格生成器
    • 为logseq插件制作设置项
    • 注册Block选项菜单
  • 第二章
    • 适配logseq主题
    • Datascript入门
    • 懒加载与异常处理
  • 第三章
    • 别人的设计:logseq-plugin-tabs为例
    • 发布你的logseq插件到markplace
    • 后记
由 GitBook 提供支持
在本页
  • 引言
  • 起步
  • 从json读取设置项
  • 图形化的设置面板
在GitHub上编辑
  1. 第一章

为logseq插件制作设置项

上一页制作一个表格生成器下一页注册Block选项菜单

最后更新于3年前

引言

在之前的内容中,我们所制做的logseq 插件都是固定的写死的。随着功能被合并。现在logseq有了插件设置的UI界面,在这之前只能通过json去修改设置项。可以为插件提供灵活的设置。接下来我们将做制作一个提供设置功能的插件。

起步

在logseq中,logseq.settingsapi为我们提供了从插件所属的json文件中读取内容的功能。而logseq.updateSettings则为我们提供了创建或修改插件json的功能。

我们通过这两个api就可以完成大部分的功能。

这次我们来创建一个插件。这个插件从用户设置中读取出特定的内容。我们通过命令往logseq中插入我们的特定的内容内容。

从json读取设置项

往json设置默认的值。

我们用之前随机句子的插件加一点修改

main.ts

  if(logseq.settings.template === undefined){ // 如果插件设置项里没有template。既可以认为第一次打开插件。这里往里面写配置项
    logseq.updateSettings({
      template:"hello",
    });
  }
	

注意:我在0.6.1使用时,logseq.updateSettings有时重载插件是没有生效的。如果出现这种情况,请重启logseq。重启第一次加载插件会为logseq.updateSettings生效。

从json读取值

main.ts

  // cosnt { template }= logseq.settings;
  // 这里不能用解构语句。因为没有babel转义js的新语法
  const template = logseq.settings.template; // 从配置项中读取
  console.log(logseq.settings);
  console.log(logseq.settings.template);

图形化的设置面板

在logseq/lib有useSettingsSchemaapi为我们通过SettingSchemaDesc类型的数组向logseq注册我们插件所需要的设置项的信息。然后logseq就可以自动的生成图形化的设置面板。

export type SettingSchemaDesc = {
  key: string
  type: 'string' | 'number' | 'boolean' | 'enum' | 'object'
  default: string | number | boolean | Array<any> | object | null
  title: string
  description: string // 支持md语法
  inputAs?: 'color' | 'date' | 'datetime-local' | 'range'
  enumChoices?: Array<string>
  enumPicker?: 'select' | 'radio' | 'checkbox' // 默认是 select
}

我们建立一个Arrary:

  const schema:Array<SettingSchemaDesc> = [
    {
      key:"template",
      type:"string",
      default:"hello",
      title:"模板",
      description:"插入模板",
    },
    {
      key:"isShow",
      type:"boolean",
      default:true,
      title:"欢迎提示",
      description:"是否显示欢迎提示",
    } 
  ];
  logseq.useSettingsSchema(schema)

效果如下

完整代码如下:

index.ts

import '@logseq/libs'

async function main () {

  console.log(logseq.settings);
  if(logseq.settings.template === undefined){
    logseq.updateSettings({
      template:"hello",
      isShow:true // 这里加了一个设置项
    });
  }

  //cosnt { template }= logseq.settings;
  // 这里不能用解构语句。因为没有babel转义js新语法
  const template = logseq.settings.template;

  if(logseq.settings.isShow){
    logseq.App.showMsg('hello, Logseqer! :)')
  }

  const schema:Array<SettingSchemaDesc> = [
    {
      key:"template",
      type:"string",
      default:"hello",
      title:"模板",
      description:"插入模板",
    },
    {
      key:"isShow",
      type:"boolean",
      default:true,
      title:"欢迎提示",
      description:"是否显示欢迎提示",
    } 
  ];
  logseq.useSettingsSchema(schema)

  logseq.Editor.registerSlashCommand('statement', async () => {
    await logseq.Editor.insertAtEditingCursor(
      `#+BEGIN_QUOTE
      ${template}
      #+END_QUOTE`,
    );
    getStatement();
  })

}
logseq.ready(main).catch(console.error)

SettingSchemaDesc类型有哪些属性可以在看到。它的源码如下

Enhance/Settings UI of plugins
这里