app.dialog - 对话框 API

对话框和表单 API。

消息对话框

app.dialog.alert(config)

显示消息对话框。

参数:

  • config (table):
    • title (string) - 标题
    • message (string) - 消息内容
    • detail (string, 可选) - 详情长文本,显示在可滚动的等宽字体文本框中(适合展示脚本输出、错误日志等)
    • buttons (array, 可选) - 按钮数组(默认 [“确定”])
    • style (string, 可选) - 样式:”info”(默认)、”warning”、”critical”

返回值: number - 点击的按钮索引(从 1 开始)

-- 简单提示
app.dialog.alert({title = "提示", message = "操作完成"})

-- 带多个按钮
local result = app.dialog.alert({
    title = "确认",
    message = "确定要继续吗?",
    buttons = {"继续", "取消"},
    style = "warning"
})

if result == 1 then
    -- 点击了"继续"
end

-- 展示长文本详情(detail 在可滚动文本框中显示)
local result = app.shell.execute("git log --oneline -20")
app.dialog.alert({
    title = "Git 日志",
    message = "最近 20 条提交记录:",
    detail = result
})

表单对话框

app.dialog.form(config)

显示表单对话框,收集用户输入。

参数:

  • config (table):
    • title (string) - 表单标题
    • fields (array) - 字段配置数组
    • width (number, 可选) - 宽度(默认 500)
    • maxHeight (number, 可选) - 最大高度(默认 500)
    • onLoad (function, 可选) - 表单加载后回调(非阻塞模式)
    • onSubmit (function, 可选) - 提交回调(非阻塞模式)
    • onCancel (function, 可选) - 取消回调(非阻塞模式)

返回值:

  • 阻塞模式:table|nil - 字段值或 nil(取消)
  • 非阻塞模式:formHandle - 表单句柄

阻塞模式(无回调时):

local result = app.dialog.form({
    title = "设置",
    width = 400,
    fields = {
        {type = "text", id = "name", label = "名称", default = ""},
        {type = "number", id = "count", label = "数量", default = 10},
        {type = "select", id = "format", label = "格式",
         options = {"PNG", "JPEG", "WebP"}, default = "PNG"},
        {type = "checkbox", id = "optimize", label = "优化", default = true}
    }
})

if result then
    print(result.name)      -- string
    print(result.count)     -- number
    print(result.format)    -- string
    print(result.optimize)  -- boolean
end

非阻塞模式(带回调时):

app.dialog.form({
    title = "选择证书",
    fields = {
        {type = "select", id = "cert", label = "证书",
         options = {}, loading = true}
    },
    onLoad = function(form)
        -- 异步加载数据
        app.thread.create(function()
            local certs = loadCertificates()
            form:setFieldOptions("cert", certs, certs[1])
            form:setFieldLoading("cert", false)
        end)
    end,
    onSubmit = function(values)
        print("选择: " .. values.cert)
    end,
    onCancel = function()
        print("已取消")
    end
})

表单句柄方法(非阻塞模式):

方法 说明
form:updateField(id, props) 更新字段属性(通用方法,见下方说明)
form:setFieldValue(id, value) 设置字段值
form:setFieldOptions(id, options, default?) 设置下拉选项
form:setFieldLoading(id, bool) 显示/隐藏加载动画
form:setFieldEnabled(id, bool) 启用/禁用字段
form:setFieldPlaceholder(id, text) 设置占位符文本
form:close() 关闭表单

form:updateField(id, props) — 通用字段更新方法,可一次更新多个属性:

-- 一次更新多个属性
form:updateField("cert", {
    options = {"Cert A", "Cert B"},
    default = "Cert A",
    loading = false,
    enabled = true
})

-- 等价于分别调用:
-- form:setFieldOptions("cert", {"Cert A", "Cert B"}, "Cert A")
-- form:setFieldLoading("cert", false)
-- form:setFieldEnabled("cert", true)

支持的属性:value, options, default, loading, enabled, placeholder

文件选择对话框

app.dialog.openFile(config?)

显示打开文件对话框。

参数:

  • config (table, 可选):
    • title (string, 可选) - 对话框标题
    • message (string, 可选) - 提示信息
    • directory (string, 可选) - 初始目录
    • allowedTypes (array, 可选) - 允许的文件扩展名
    • allowsMultiple (boolean, 可选) - 允许多选(默认 false)

返回值: string|array|nil - 路径或 nil(取消)

local path = app.dialog.openFile({
    title = "选择图片",
    directory = "~/Pictures",
    allowedTypes = {"png", "jpg", "gif"},
    allowsMultiple = false
})

-- 多选
local paths = app.dialog.openFile({
    allowsMultiple = true
})

app.dialog.saveFile(config?)

显示保存文件对话框。

参数:

  • config (table, 可选):
    • title (string, 可选) - 对话框标题
    • message (string, 可选) - 提示信息
    • directory (string, 可选) - 初始目录
    • nameFieldLabel (string, 可选) - 文件名标签
    • nameFieldValue (string, 可选) - 默认文件名
    • allowedTypes (array, 可选) - 允许的文件扩展名

返回值: string|nil - 路径或 nil(取消)

local path = app.dialog.saveFile({
    title = "另存为",
    nameFieldValue = "output.png"
})

app.dialog.chooseFolder(config?)

显示文件夹选择对话框。

参数:

  • config (table, 可选):
    • title (string, 可选) - 对话框标题
    • message (string, 可选) - 提示信息
    • directory (string, 可选) - 初始目录
    • allowsMultiple (boolean, 可选) - 允许多选(默认 false)

返回值: string|array|nil - 路径或 nil(取消)

local folder = app.dialog.chooseFolder({
    title = "选择输出目录"
})

列表选择

app.dialog.choose(items, opts?)

显示列表选择对话框。

参数:

  • items (array) - 选项列表(两种格式):
    • 字符串数组:{"选项A", "选项B", "选项C"}
    • 对象数组:{{id = "a", text = "选项A", icon = "sf:star"}, ...}
  • opts (table, 可选):
    • title (string, 可选) - 对话框标题
    • message (string, 可选) - 提示信息
    • multiSelect (boolean, 可选) - 是否多选(默认 false)
    • defaultIndex (number, 可选) - 默认选中索引(从 0 开始,默认 0)

返回值:

  • 单选:选中的项(string 或 table)或 nil(取消)
  • 多选:选中的项数组或 nil(取消)
-- 字符串列表(单选)
local selected = app.dialog.choose(
    {"PNG", "JPEG", "WebP", "TIFF"},
    {title = "选择格式", message = "请选择导出格式"}
)
if selected then
    app.log.info("选择了: " .. selected)
end

-- 对象列表
local selected = app.dialog.choose({
    {id = "resize", text = "调整大小", icon = "sf:arrow.up.left.and.arrow.down.right"},
    {id = "crop",   text = "裁剪",     icon = "sf:crop"},
    {id = "rotate", text = "旋转",     icon = "sf:rotate.right"},
}, {title = "选择操作"})

if selected then
    app.log.info("选择了: " .. selected.id)
end

-- 多选
local selected = app.dialog.choose(
    {"标签A", "标签B", "标签C", "标签D"},
    {title = "选择标签", multiSelect = true}
)
if selected then
    app.log.info("选择了 " .. #selected .. " 个标签")
end

示例

批量重命名

function MyPlugin:handleRename(context)
    local result = app.dialog.form({
        title = "批量重命名",
        fields = {
            {type = "text", id = "prefix", label = "前缀", default = ""},
            {type = "text", id = "suffix", label = "后缀", default = ""},
            {type = "number", id = "start", label = "起始编号", default = 1}
        }
    })

    if not result then return end

    local num = result.start
    for _, file in ipairs(context.selectedFiles) do
        local dir = app.path.dirname(file)
        local ext = app.path.extension(file)
        local newName = string.format("%s%03d%s.%s",
            result.prefix, num, result.suffix, ext)
        local newPath = app.path.join(dir, newName)

        app.file.move(file, newPath)
        num = num + 1
    end

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