Skip to content
This repository has been archived by the owner on Jan 8, 2023. It is now read-only.

💎 Sketch Plugin Template with skpm umi typescript

Notifications You must be signed in to change notification settings

arvinxx/sketch-plugin-template

Repository files navigation

Sketch Plugin Template

Template Version Build With skpm Build With umi semantic-release

david deps david devDeps


Sketch 插件开发 模板

CLI Commands

安装

npm i

yarn

开发

npm run dev

打包构建

npm run build

项目架构

├── README.md                   # 说明
├── package.json                # package.json
├── src                         # 源代码
  ├── resources                 # 视图端 webview (UI窗口)
  └── sketch                    # sketch 端定义的功能
  ├── bridge                    # 视图层和 sketch 端的通信层
  ├── common                    # resources 和 sketch 共用的模块文件
├── static                      # 静态图片等资源
├── tsconfig.json               # ts 配置文件
├── tslint.json                 # lint 配置文件
├── typings                     # ts 类型定义文件
└── webpack.skpm.config.js      # skpm 配置文件

Resources

Resources 采用 umi 的架构,不再赘述

启动方式

npm run dev:resources

目录结构

resources
├── assets
├─ components
├── config
├── hooks
├── locales
├── models
├── pages
├── services
├── theme
├── tsconfig.json
└── utils

开发注意事项

  1. 建议在浏览器端进行开发,需要用到和 sketch 的交互时再进入 sketch 测试。 预览URL为 http://url/#/{page}.html
  2. 代码模块引用不允许引入 sketch 层的模块 ,所有通信建议封装到 service

Sketch

sketch 文件夹包含 Sketch 端的代码

开发方式

通过 npm run dev:sketch 进行 sketch 端开发 (需要启动 resources 端进行配合)

如果只需要跑 sketch 端代码,不涉及 webview 层,可以使用 npm run dev:sketch-only 只启动 sketch 端进行开发

目录结构

sketch
├── manifest.json             # sketch 插件入口文件
├── commands                  # 在插件栏可直接执行的脚本指令  
└── windows                   # Webview 窗口 每个文件代表一个窗口  
├── modules                   # 自行封装模块
├── utils                     # 工具函数

windows

实现的窗口分成两种,BrowserWindows 悬浮类窗口 和 WKWebView Toolbar 窗口

BrowserWindows: 承载主要的交互能力

WKWebView: 右侧的 Toolbar 面板

配置项

sketch 端使用 skpm 进行构建打包,配置文件在 ./webpack.skpm.config.js,如有需要可以自定义

Debug

应该都会了 就不写了...

To view the output of your console.log, you have a few different options:

  • Open Console.app and look for the sketch logs
  • Use Safari's web inspector to debug your plugin's javascript context
  • Look at the ~/Library/Logs/com.bohemiancoding.sketch3/Plugin Output.log file

Skpm provides a convenient way to do the latter:

自动重载脚本

使用 skpm 将会自动重载 sketch 插件 因此不用进行任何配置

Sketch 端自动刷新

如果定义了一些持久性的变量,需要重启 sketch 才能看到插件更新时,可以使用 entr 进行自动重启

brew install entr

然后执行 npm run refresh 即可

Ref: Sketch Debug

skpm log

The -f option causes skpm log to not stop when the end of logs is reached, but rather to wait for additional data to be appended to the input

Bridge

bridge 是 webview 和端层的通信接口,通过 channel 进行数据交换 (类似前后端分离)

本层定义了通信字段和webview和端层的互相通信方法

bridge
├── channel.ts           # 通信信道字段
├── sendMsgToEnd.ts      # webview 向端层发信方法
├── sendMsgToWebView.ts  # 端层向 webview 发信方法
├── index.ts             # 对外统一暴露接口

webview 向端层发信

唯一方法 sendMsgToEnd,目前只包含了与 sketch 层的通信方式,未来若需扩展到 figma 等平台, 则可以根据平台判断,加入对应的通信方式,抹平端的差异

端层向 webview 发信

底层原理: 在 webview 层定义一个全局函数,然后 sketch 层 通过executeJavaScript方法去调用该全局函数

browserWindow.webContents
  .executeJavaScript('someFuncInWebview("hello")')
  .then(res => {
    // do something with the result
  })

实现上存在两个方法

  1. sendMsgToWebView
  2. sendMsgToThirdWebView (暂时用不到 所以注释了)

sendMsgToWebView

此方法用于端层向插件自有的 webview 发信

在 layouts 层插入了一个全局函数 onReceiveEndMsg 分发从端层获取的信息(利用 dva 的 dispatch)

sendMsgToThirdWebview

此方法用于端层与其他插件的 webview 层通信 原因:三方 webview 无法拿到实例,因此需要利用 identifier 进行识别和发送信息