Просмотр файлов
CLI позволяет исследовать дизайн-документы без открытия редактора. Каждая команда также работает с запущенным приложением — просто опустите аргумент файла.
Установка
npm install -g @open-pencil/cli
# или
brew install open-pencil/tap/open-pencilИнформация о документе
Краткий обзор — количество страниц, общее число узлов, используемые шрифты, размер файла:
openpencil info design.figДерево узлов
Вывод полной иерархии узлов:
openpencil tree design.fig[0] [page] "Getting started" (0:46566)
[0] [section] "" (0:46567)
[0] [frame] "Body" (0:46568)
[0] [frame] "Introduction" (0:46569)
[0] [frame] "Introduction Card" (0:46570)
[0] [frame] "Guidance" (0:46571)Поиск узлов
Поиск по типу:
openpencil find design.fig --type TEXTПоиск по имени:
openpencil find design.fig --name "Button"Оба флага можно комбинировать для более точных результатов.
Запросы с XPath
Используйте XPath-селекторы для поиска узлов по типу, атрибутам и структуре дерева:
openpencil query design.fig "//FRAME"Полезные шаблоны
По типу:
openpencil query design.fig "//TEXT" # Все текстовые узлы
openpencil query design.fig "//COMPONENT" # Все компоненты
openpencil query design.fig "//INSTANCE" # Все экземплярыПо атрибутам:
openpencil query design.fig "//FRAME[@width < 300]" # Фреймы шириной менее 300px
openpencil query design.fig "//*[@cornerRadius > 0]" # Скруглённые углы
openpencil query design.fig "//*[@visible = false]" # Скрытые узлы
openpencil query design.fig "//TEXT[@fontSize >= 24]" # Крупный текст
openpencil query design.fig "//*[@opacity < 1]" # Полупрозрачные узлыПо имени и текстовому содержимому:
openpencil query design.fig "//TEXT[contains(@name, 'Button')]" # Имя содержит 'Button'
openpencil query design.fig "//TEXT[contains(@text, 'Hello')]" # Текст содержит 'Hello'По иерархии:
openpencil query design.fig "//SECTION//TEXT" # Текст внутри секций
openpencil query design.fig "//FRAME/TEXT" # Прямые дочерние тексты фреймов
openpencil query design.fig "//COMPONENT_SET//INSTANCE" # Экземпляры внутри наборов компонентовДоступные атрибуты
name, width, height, x, y, visible, opacity, cornerRadius, fontSize, fontFamily, fontWeight, layoutMode, itemSpacing, paddingTop, paddingRight, paddingBottom, paddingLeft, strokeWeight, rotation, locked, blendMode, text, lineHeight, letterSpacing
Пример вывода
Found 5 nodes
[0] [frame] "Logo 92×32" (0:9)
[1] [frame] "logo-short-6 31×32" (0:10)
[2] [frame] "wrapper 128×73" (0:20)
[3] [frame] "pen-drawing 148×52" (0:21)
[4] [frame] "surprised-emoji 32×32" (0:26)Свойства узла
Просмотр всех свойств конкретного узла по его ID:
openpencil node design.fig --id 1:23Страницы
Список всех страниц в документе:
openpencil pages design.figПеременные
Список дизайн-переменных и их коллекций:
openpencil variables design.figРежим работы с приложением
Когда настольное приложение запущено, опустите аргумент файла — CLI подключится по RPC и будет работать с активным холстом:
openpencil tree # просмотр текущего документа
openpencil eval -c "..." # запрос к редакторуЛинтинг дизайна
Проверяйте документы на соответствие правилам именования, вёрстки, структуры и доступности:
openpencil lint design.fig
openpencil lint design.pen --preset strict
openpencil lint design.fig --rule color-contrast
openpencil lint design.fig --list-rulesИспользуйте --json для машиночитаемого вывода.
JSON-вывод
Все команды поддерживают --json для машиночитаемого вывода — передавайте в jq, используйте в CI-скриптах или обрабатывайте другими инструментами:
openpencil tree design.fig --json | jq '.[] | .name'