mxl-dsl

$npx mdskill add SteelMorgan/1c-agent-based-dev-framework/mxl-dsl

Generates 1C spreadsheet documents (MXL) using a JSON DSL for creating areas, cells, fonts, and styles in printed forms.

  • Helps create printable forms as tabular documents for 1C applications.
  • Integrates with 1C's SpreadsheetDocument system via XML templates and compile commands.
  • Decides based on JSON input specifying document structure, parameters, and styling.
  • Presents results as XML files ready for use in 1C templates or EPF layouts.

SKILL.md

.github/skills/mxl-dslView on GitHub ↗
---
name: mxl-dsl
description: JSON DSL для генерации табличных документов 1С (MXL) с областями, ячейками, шрифтами и стилями. Используй при mxl compile для печатных форм.
---

# MXL DSL

JSON DSL для генерации табличных документов 1С (SpreadsheetDocument).

## Когда применять

| Триггер | Действие |
|---------|----------|
| Нужно создать печатную форму (табличный документ) | `mxl compile` с JSON DSL |
| Нужно добавить область в шаблон | Описать в `areas`, перекомпилировать |
| Нужно использовать параметры в ячейках | `parameters` + `[ИмяПараметра]` в text |
| Нужно применить стили | `fonts` + `styles` + `style` в ячейке |
| Нужно анализировать существующий макет | `mxl info <Template.xml>` |
| Нужно обратная конвертация XML → JSON | `mxl decompile <Template.xml> <output.json>` |

## Команда compile

```bash
xml-gen mxl compile [--format designer|edt] <input.json> <output.xml>
```

**output.xml** — путь к Template.xml или макету в EPF: `.../Templates/<Name>/Ext/Template.xml`

## Команда info

Анализ структуры макета: области, параметры, колонки.

```bash
xml-gen mxl info <Template.xml>
```

## Команда decompile

Обратная конвертация Template.xml → JSON DSL.

```bash
xml-gen mxl decompile <Template.xml> <output.json>
```

## Структура DSL

### Минимальный документ

```json
{
  "areas": [
    {
      "name": "Header",
      "rows": [
        {"cells": [{"text": "Заголовок"}]}
      ]
    }
  ]
}
```

### Области (areas)

```json
{
  "name": "ИмяОбласти",
  "rows": [
    {"cells": [
      {"text": "Текст ячейки"},
      {"text": "Объединённая", "span": 3},
      {"text": "[Параметр]", "style": "HeaderStyle"}
    ]}
  ]
}
```

### Шрифты и стили

```json
{
  "fonts": {
    "HeaderFont": {"face": "Arial", "size": 14, "bold": true}
  },
  "styles": {
    "HeaderStyle": {
      "font": "HeaderFont",
      "horizontalAlignment": "Center",
      "border": "all",
      "borderWidth": "thick"
    }
  }
}
```

### Параметры

```json
{
  "parameters": [
    {"name": "Организация", "type": "CatalogRef.Организации"},
    {"name": "ДатаНачала", "type": "date"}
  ]
}
```

Использование в ячейках: `{"text": "[Организация]"}`

### Свойства ячеек

| Свойство | Описание |
|----------|----------|
| `text` | Текст ячейки |
| `span` | Объединение ячеек (colspan) |
| `style` | Имя стиля |

### Свойства стилей

`font`, `horizontalAlignment` (Left/Center/Right), `verticalAlignment`, `border` (all/top/bottom/left/right), `borderWidth` (thin/thick), `textPlacement` (Wrap/Block), `format` (ЧДЦ=2, ДФ=dd.MM.yyyy)

## Правильно / Неправильно

```json
// ❌ Неправильно — параметр в ячейке без скобок (не подставится при выводе)
{"cells": [{"text": "Организация"}]}

// ✅ Правильно — [ИмяПараметра] для подстановки
{"cells": [{"text": "[Организация]"}]}
```

> 1С ищет `[Имя]` в тексте области и подставляет значение из параметров при выводе. Без скобок — статический текст.

## Использование областей в BSL-коде

Имена областей из DSL (поле `"name"`) напрямую используются в BSL при выводе печатной формы:

```bsl
// ПечатнаяФорма — имя макета в обработке (соответствует name в epf add-template)
ТД = ЭтотОбъект.ПолучитьМакет("ПечатнаяФорма");
ТабДок = Новый ТабличныйДокумент;

// "Header", "Row", "Footer" — значения поля "name" из DSL-секции areas
ОбластьШапка = ТД.ПолучитьОбласть("Header");
ТабДок.Вывести(ОбластьШапка);

Для Каждого Строка Из ДанныеДляВывода Цикл
    ОбластьСтрока = ТД.ПолучитьОбласть("Row");
    ОбластьСтрока.Параметры.Наименование = Строка.Наименование;
    ОбластьСтрока.Параметры.Сумма       = Строка.Сумма;
    ТабДок.Вывести(ОбластьСтрока);
КонецЦикла;

ОбластьПодвал = ТД.ПолучитьОбласть("Footer");
ТабДок.Вывести(ОбластьПодвал);
```

> Имена параметров областей (`Параметры.Наименование`) должны совпадать с ключами из DSL-поля `"params"` соответствующей области.


---
depends_on: []
metadata:
  category: 1c-development
  version: "1.0"
---

More from SteelMorgan/1c-agent-based-dev-framework

SkillDescription
1c-ai-agent-cliCLI 1C BSL Agent Framework — tools/install.py (clone, install). Используй при клонировании репозитория, установке компонентов в проект, настройке IDE (Cursor, Claude Code, Windsurf, VS Code+Continue).
agent-debugПаттерн отладочных сообщений для 1С BSL. Используй, когда стандартная диагностика (event-log, скриншоты) не даёт понять фактическое поведение системы — нужно вставить временные точки логирования в код, запустить тест и проанализировать записи ЖР.
agent-developmentCreate custom subagents for specialized AI tasks. Use when the user wants to create a new type of subagent, set up task-specific agents, configure code reviewers, debuggers, or domain-specific assistants with custom prompts.
agent-development-ext>
agent-git-workflowStandardizes git workflow for the AI agent in the sandbox devcontainer: work in agent/<task>-<yyyymmdd>, integrate via agent, never push to main/master, open PRs via GitHub CLI. Use when the user asks to create branches, push changes, open PRs, or follow this sandbox repo setup.
auto-skill-bootstrapDeterministic helper to inventory existing project skills, detect missing capability coverage, search skills.sh via Skills CLI, and (optionally) install missing skills under a trust policy. Uses skills-manifest.json + state.json to stay idempotent across changing requirements.
code-navigationНавигация по коду (Code Navigation). Навык учит агента **эффективно перемещаться по BSL-коду** с помощью LSP (Language Server Protocol).
config-operationsОперации с конфигурацией 1С (CF) — init, info, edit, validate. Используй при создании конфигурации, анализе структуры, изменении свойств и ChildObjects, валидации Configuration.xml.
epf-buildСобрать EPF/ERF из XML-исходников. Используй после внесения временных диагностических правок в разобранную обработку.
epf-dumpРазобрать EPF/ERF в XML-исходники. Используй, когда нужно быстро получить исходный код внешней обработки или отчета для анализа и временной модификации.