app.dock - Dock 角标/弹跳 API

控制应用 Dock 图标的角标和弹跳提醒。

权限: L1(standard)— 需要在插件 manifest 中声明 app.dock 权限。

方法

app.dock.setBadge(text)

设置 Dock 角标文字。

参数:

  • text (string|number) - 角标文字(数字或文字,空字符串清除角标)

返回值: boolean, error

app.dock.setBadge("5")       -- 显示数字角标
app.dock.setBadge("新")      -- 显示文字角标
app.dock.setBadge("")         -- 清除角标
app.dock.setBadge(42)         -- 数字自动转为字符串

app.dock.getBadge()

获取当前 Dock 角标文字。

返回值: string - 当前角标文字,无角标时返回空字符串

local badge = app.dock.getBadge()
app.log.info("当前角标: " .. badge)

app.dock.removeBadge()

清除 Dock 角标。等价于 setBadge("")

返回值: boolean, error

app.dock.removeBadge()

app.dock.bounce(type?)

弹跳 Dock 图标以引起用户注意。

参数:

  • type (string, 可选) - 弹跳类型:
    • "informational" (默认) - 弹跳一次
    • "critical" - 持续弹跳直到用户切换到应用

返回值: number, error - 请求 ID(用于 cancelBounce()

-- 温和弹跳(一次)
local id = app.dock.bounce()

-- 持续弹跳
local id = app.dock.bounce("critical")

-- 稍后停止弹跳
app.dock.cancelBounce(id)

app.dock.cancelBounce(id)

停止 Dock 弹跳。

参数:

  • id (number) - bounce() 返回的请求 ID

返回值: boolean, error

local id = app.dock.bounce("critical")
-- ... 某些操作后 ...
app.dock.cancelBounce(id)

说明

  • 无需清理,不占用持久资源
  • "critical" 弹跳会持续到用户激活应用或调用 cancelBounce()

示例

文件处理完成后通知

function MyPlugin:handleProcess(context)
    local files = context.selectedFiles
    app.dock.setBadge(tostring(#files))

    for i, file in ipairs(files) do
        -- 处理文件...
        app.dock.setBadge(tostring(#files - i))
    end

    app.dock.removeBadge()
    app.dock.bounce()
    app.notification.show("完成", "已处理 " .. #files .. " 个文件")
end
开发者文档
使用帮助
使用说明 脚本菜单 常见问题
脚本开发
开发指南
插件开发
快速开始 开发指南 示例插件
API 参考
概览 API 查询 插件信息 日志 Finder 上下文 插件设置 国际化
UI 与交互
对话框 进度条 系统通知 选择器 WebView 状态栏 Dock
文件与路径
文件操作 路径工具 Finder 操作 废纸篓 扩展属性 元数据 文件监听
数据格式
JSON Plist CSV XML PDF 图片
文本与编码
字符串 正则表达式 日期时间 颜色 加密编码
系统
Shell 命令 进程管理 应用管理 系统信息 AppleScript 快捷指令
系统信息
网络信息 电源/电池 屏幕/外观 音频控制 蓝牙设备 位置服务
网络
HTTP 请求 WebSocket URL 工具
输入与剪贴板
键盘模拟 鼠标模拟 全局热键 剪贴板 窗口管理
存储
SQLite Keychain UserDefaults
媒体
文字识别 二维码
工具
归档 类型标识 分享 定时器 防休眠 并发/协程