Skip to main content

扩展

info

如何在桌面中开发扩展

配置

package.json
{
// 官方 @alemonjs/XXX
// 三方 alemonjs-XXX
"name": "@alemonjs/test",
"version": "0.0.1",
"type": "module",
"main": "lib/index.js",
"scripts": {
"build": "npx lvy build"
},
"export": {
".": "./lib/index.js",
"./package": "./package.json", // 必须的
"./desktop": "./desktop.js" // 可选(桌面扩展入口脚本)
},
"alemonjs": {
"desktop": {
// 指令输入框
"commond": [
{
"name": "test",
"commond": "open.test" // 发送指令
}
],
// 侧边栏
"sidebars": [
{
"name": "test",
"commond": "open.test" // 发送指令
}
],
// 平台(拥有此配置将无法被添加至config.value.apps)
"platform": [
{
"name": "test" // --login test
}
]
}
},
// author
"author": {
"name": "ningmengchongshui",
"email": "ningmengchongshui@gmail.com",
"url": "https://github.com/ningmengchongshui"
}
}

周期

package.js
// 被激活的时候。
export const activate = context => {}

webview

渲染

desktop.js
import { readFileSync } from 'fs'
import { dirname, join } from 'path'
import { fileURLToPath } from 'url'
// 当前目录
const __dirname = dirname(fileURLToPath(import.meta.url))
export const activate = context => {
// 创建一个 webview。
const sidebarWebView = context.createSidebarWebView(context)
// 当命令被触发的时候。
context.onCommand('open.test', () => {
const dir = join(__dirname, 'assets', 'index.html')
// 确保路径存在
const html = readFileSync(dir, 'utf-8')
// 立即渲染 webview
sidebarWebView.loadWebView(html)
})
}
  • 接收消息
desktop.js
export const activate = context => {
// 创建一个 webview。
const sidebarWebView = context.createSidebarWebView(context)
// 监听 webview 的消息。
sidebarWebView.onMessage(data => {
// { type: 'pong',data: ''}
})
}
  • 发送消息
desktop.js
export const activate = context => {
// 创建一个 webview。
const sidebarWebView = context.createSidebarWebView(context)
// 监听 webview 的消息。
sidebarWebView.postMessage({
type: 'ping',
data: ''
})
}

脚本

  • 发送消息
index.js
const API = createDesktopAPI()

API.postMessage({
type: 'pong',
data: ''
})
  • 接收消息
index.js
const API = createDesktopAPI()

API.onMessage(data => {
// { type: 'ping', data: '' }
})

资源路径

desktop.js
import { dirname, join } from 'path'
import { fileURLToPath } from 'url'
// 当前目录
const __dirname = dirname(fileURLToPath(import.meta.url))
export const activate = context => {
// 创建 webview 路径
const styleUri = context.createExtensionDir(join(__dirname, 'assets', 'index.css'))
const scriptUri = context.createExtensionDir(join(__dirname, 'assets', 'index.js'))
// 可替换 html 内部资源,确保正确加载
}

通知推送

desktop.js
export const activate = context => {
context.notification('扩展加载')
}