Боль
Открываешь иконочный React-компонент — и привет:

У Zed есть отличный нативный preview для отдельных .svg-файлов. Но для SVG, лежащего внутри JSX, — ничего. Так же, кстати, и в большинстве других редакторов.
Почему task, а не расширение
Очевидное решение — расширение для Zed. Но extension API у Zed пока не даёт того, что для этого нужно: открыть произвольный буфер в превью-режиме по команде из самого расширения. Когда API дорастёт — с радостью перепишу. А пока — Zed-таск + маленькая CLI.

Что делает svg-react-preview
Ставите курсор куда угодно внутрь svg-тега в .tsx/.jsx и запускаете таск. Дальше CLI:
Парсит файл через swc, находит ближайший охватывающий .
Нормализует его в валидный standalone .svg: className → class, strokeWidth → stroke-width, динамические {props} заменяются на дефолты (24, currentColor, …) или выкидываются, спред {...props} дропается, PascalCase-компоненты превращаются в плейсхолдер-
Пишет результат в $TMPDIR/svg-react-preview/<хеш>.svg (имя — стабильный xxhash от исходника, повторное превью не плодит файлы).
Открывает его через
zed <path>— Zed показывает preview-вкладку рядом с исходником.
Платформы
macOS — полностью автоматически. AppleScript открывает файл в Zed, синтезирует Cmd+Shift+V для preview-режима, потом Cmd+Shift+[ + Cmd+W чтобы закрыть лишнюю текстовую вкладку. На выходе — ровно одна preview-вкладка за запуск. Цена: на первом запуске нужно дать Zed.app права в Системные настройки → Конфиденциальность → Универсальный доступ (macOS блокирует синтетические нажатия без этого).
Linux / Windows — файл открывается как текст, один Ctrl+Shift+V переключает в preview. Зато никаких permission-диалогов.
Установка
cargo install --git https://github.com/Segodnya/svg-react-preview
Бинарь падает в ~/.cargo/bin/svg-react-preview — убедитесь, что он в PATH.
Дальше в Zed: Zed → CLI → Install zed Shell Command (нужен zed на PATH, чтобы CLI могла открывать файлы в вашем уже запущенном Zed).
В ~/.config/zed/tasks.json:
[ { "label": "Preview SVG (cursor)", "command": "svg-react-preview", "env": { "SVG_REACT_PREVIEW_FILE": "{ZED_FILE}", "SVG_REACT_PREVIEW_ROW": "{ZED_ROW}", "SVG_REACT_PREVIEW_COLUMN": "${ZED_COLUMN}" }, "use_new_terminal": false, "allow_concurrent_runs": true, "reveal": "no_focus", "hide": "on_success", "save": "none" } ]
И опционально хоткей в ~/.config/zed/keymap.json:
[ { "context": "Editor", "bindings": { "alt-shift-v": ["task::Spawn", { "task_name": "Preview SVG (cursor)" }] } } ]
Готово. Курсор в <svg></svg> → Alt+Shift+V → в новой вкладке отрендеренная иконка.
Что под капотом:
Rust, swc для парсинга TSX/JSX.
На macOS — osascript для AppleScript-управления Zed (открыть файл, дослать хоткей, закрыть лишнюю вкладку). Хоткей настраивается через SVG_REACT_PREVIEW_HOTKEY, можно полностью отключить (=none) если в Zed свой кейбиндинг.
Полный набор CI: clippy pedantic+nursery, llvm-cov с гейтом 95%, cargo-deny, cargo-audit, cargo-machete, cargo-udeps, cargo-mutants. Hook через cargo-husky.
Сам буду пользоваться. Но интересно, насколько боль общая:
Удобно ли?
Linux/Windows-пользователи: ручной Ctrl+Shift+V — приемлемо или стоит автоматизировать?
Какие JSX-паттерны парсер уронит? Реальные примеры из ваших кодовых баз — лучшие тесты :).
Контрибьюшен приветствуется: github.com/Segodnya/svg-react-preview
P.S. Параллельно положил пост на r/Zed. Если штука вам зашла — будет здорово, если поддержите там апвоутом или комментарием: ссылка.
