Cc-1c-skills mxl-compile

Компиляция табличного документа (MXL) из JSON-определения. Используй когда нужно создать макет печатной формы

install
source · Clone the upstream repo
git clone https://github.com/Nikolay-Shirokov/cc-1c-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/Nikolay-Shirokov/cc-1c-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/mxl-compile" ~/.claude/skills/nikolay-shirokov-cc-1c-skills-mxl-compile && rm -rf "$T"
manifest: .claude/skills/mxl-compile/SKILL.md
source content

/mxl-compile — Компилятор макета из DSL

Принимает компактное JSON-определение макета и генерирует корректный Template.xml для табличного документа 1С. Claude описывает что нужно (области, параметры, стили), скрипт обеспечивает корректность XML (палитры, индексы, объединения, namespace).

Использование

/mxl-compile <JsonPath> <OutputPath>

Параметры

ПараметрОбязательныйОписание
JsonPathдаПуть к JSON-определению макета
OutputPathдаПуть для генерации Template.xml

Команда

powershell.exe -NoProfile -File .claude/skills/mxl-compile/scripts/mxl-compile.ps1 -JsonPath "<путь>.json" -OutputPath "<путь>/Template.xml"

Рабочий процесс

  1. Claude пишет JSON-определение (Write tool) → файл
    .json
  2. Claude вызывает
    /mxl-compile
    для генерации Template.xml
  3. Claude вызывает
    /mxl-validate
    для проверки корректности
  4. Claude вызывает
    /mxl-info
    для верификации структуры

Если макет создаётся по изображению (скриншот, скан печатной формы) — сначала вызвать

/img-grid
для наложения сетки, по ней определить границы колонок и пропорции, затем использовать
"Nx"
ширины +
"page"
для автоматического расчёта размеров.

JSON-схема DSL

Полная спецификация формата:

docs/mxl-dsl-spec.md
(прочитать через Read tool перед написанием JSON).

Краткая структура:

{ columns, page, defaultWidth, columnWidths,
  fonts: { name: { face, size, bold, italic, underline, strikeout } },
  styles: { name: { font, align, valign, border, borderWidth, wrap, format } },
  areas: [{ name, rows: [{ height, rowStyle, cells: [
    { col, span, rowspan, style, param, detail, text, template }
  ]}]}]
}

Ключевые правила:

  • page
    — формат страницы (
    "A4-landscape"
    ,
    "A4-portrait"
    или число). Автоматически вычисляет
    defaultWidth
    из суммы пропорций
    "Nx"
  • col
    — 1-based позиция колонки
  • rowStyle
    — автозаполнение пустот стилем (рамки по всей ширине)
  • Тип заполнения определяется автоматически:
    param
    → Parameter,
    text
    → Text,
    template
    → Template
  • rowspan
    — объединение строк вниз (rowStyle учитывает занятые ячейки)