form-compile

/form-compile — Генерация Form.xml из JSON DSL

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "form-compile" with this command: npx skills add arman-kudaibergenov/1c-ai-development-kit/arman-kudaibergenov-1c-ai-development-kit-form-compile

/form-compile — Генерация Form.xml из JSON DSL

Принимает компактное JSON-определение формы (20–50 строк) и генерирует полный корректный Form.xml (100–500+ строк) с namespace-декларациями, автогенерированными companion-элементами, последовательными ID.

При проектировании формы с нуля (5+ элементов или нечёткие требования) — вызовите /form-patterns для загрузки справочника: архетипы, конвенции именования, продвинутые паттерны. Для простых форм (1–3 поля, пользователь описал что нужно) — не нужно.

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

/form-compile <JsonPath> <OutputPath>

Параметры

Параметр Обязательный Описание

JsonPath да Путь к JSON-определению формы

OutputPath да Путь к выходному файлу Form.xml

Команда

powershell.exe -NoProfile -File .claude/skills/form-compile/scripts/form-compile.ps1 -JsonPath "<json>" -OutputPath "<xml>"

JSON DSL — справка

Структура верхнего уровня

{ "title": "Заголовок формы", "properties": { "autoTitle": false, ... }, "events": { "OnCreateAtServer": "ПриСозданииНаСервере" }, "excludedCommands": ["Reread"], "elements": [ ... ], "attributes": [ ... ], "commands": [ ... ], "parameters": [ ... ] }

  • title — заголовок формы (multilingual). Можно указать и в properties , но лучше на верхнем уровне

  • properties — свойства формы: autoTitle , windowOpeningMode , commandBarLocation , saveDataInSettings , width , height и др.

  • events — обработчики событий формы (ключ: имя события 1С, значение: имя процедуры)

  • excludedCommands — исключённые стандартные команды

Элементы (ключ определяет тип)

DSL ключ XML элемент Значение ключа

"group"

UsualGroup "horizontal" / "vertical" / "alwaysHorizontal" / "alwaysVertical" / "collapsible"

"input"

InputField имя элемента

"check"

CheckBoxField имя

"label"

LabelDecoration имя (текст задаётся через title )

"labelField"

LabelField имя

"table"

Table имя

"pages"

Pages имя

"page"

Page имя

"button"

Button имя

"picture"

PictureDecoration имя

"picField"

PictureField имя

"calendar"

CalendarField имя

"cmdBar"

CommandBar имя

"popup"

Popup имя

Общие свойства (все типы элементов)

Ключ Описание

name

Переопределить имя (по умолчанию = значение ключа типа)

title

Заголовок элемента

visible: false

Скрыть (синоним: hidden: true )

enabled: false

Сделать недоступным (синоним: disabled: true )

readOnly: true

Только чтение

on: [...]

События с автоименованием обработчиков

handlers: {...}

Явное задание имён обработчиков: {"OnChange": "МоёИмя"}

Допустимые имена событий (on )

Компилятор предупреждает о неизвестных событиях. Имена регистрозависимы — используйте точно как указано.

Форма (events ): OnCreateAtServer , OnOpen , BeforeClose , OnClose , NotificationProcessing , ChoiceProcessing , OnReadAtServer , BeforeWriteAtServer , OnWriteAtServer , AfterWriteAtServer , BeforeWrite , AfterWrite , FillCheckProcessingAtServer , BeforeLoadDataFromSettingsAtServer , OnLoadDataFromSettingsAtServer , ExternalEvent , Opening

input / picField: OnChange , StartChoice , ChoiceProcessing , AutoComplete , TextEditEnd , Clearing , Creating , EditTextChange

check: OnChange

table: OnStartEdit , OnEditEnd , OnChange , Selection , ValueChoice , BeforeAddRow , BeforeDeleteRow , AfterDeleteRow , BeforeRowChange , BeforeEditEnd , OnActivateRow , OnActivateCell , Drag , DragStart , DragCheck , DragEnd

label / picture: Click , URLProcessing

labelField: OnChange , StartChoice , ChoiceProcessing , Click , URLProcessing , Clearing

button: Click

pages: OnCurrentPageChange

Поле ввода (input)

Ключ Описание Пример

path

DataPath — привязка к данным "Объект.Организация"

titleLocation

Размещение заголовка "none" , "left" , "top"

multiLine: true

Многострочное поле текстовое поле, комментарий

passwordMode: true

Режим пароля (звёздочки) поле ввода пароля

choiceButton: true

Кнопка выбора ("...") ссылочное поле

clearButton: true

Кнопка очистки ("X")

spinButton: true

Кнопка прокрутки числовые поля

dropListButton: true

Кнопка выпадающего списка

markIncomplete: true

Пометка незаполненного обязательные поля

skipOnInput: true

Пропускать при обходе Tab

inputHint

Подсказка в пустом поле "Введите наименование..."

width / height

Размер числа

autoMaxWidth: false

Отключить авто-ширину для фиксированных полей

horizontalStretch: true

Растягивать по ширине

Чекбокс (check)

Ключ Описание

path

DataPath

titleLocation

Размещение заголовка

Надпись-декорация (label)

Ключ Описание

title

Текст надписи (обязательно)

hyperlink: true

Сделать ссылкой

width / height

Размер

Группа (group)

Значение ключа задаёт ориентацию: "horizontal" , "vertical" , "alwaysHorizontal" , "alwaysVertical" , "collapsible" .

Ключ Описание

showTitle: true

Показывать заголовок группы

united: false

Не объединять рамку

representation

"none" , "normal" , "weak" , "strong"

children: [...]

Вложенные элементы

Таблица (table)

Важно: таблица требует связанный реквизит формы типа ValueTable с колонками (см. раздел "Связки").

Ключ Описание

path

DataPath (привязка к реквизиту-таблице)

columns: [...]

Колонки — массив элементов (обычно input )

changeRowSet: true

Разрешить добавление/удаление строк

changeRowOrder: true

Разрешить перемещение строк

height

Высота в строках таблицы

header: false

Скрыть шапку

footer: true

Показать подвал

commandBarLocation

"None" , "Top" , "Auto"

searchStringLocation

"None" , "Top" , "Auto"

Страницы (pages + page)

Ключ (pages) Описание

pagesRepresentation

"None" , "TabsOnTop" , "TabsOnBottom" и др.

children: [...]

Массив page

Ключ (page) Описание

title

Заголовок вкладки

group

Ориентация внутри страницы

children: [...]

Содержимое страницы

Кнопка (button)

Ключ Описание

command

Имя команды формы → Form.Command.Имя

stdCommand

Стандартная команда: "Close" → Form.StandardCommand.Close ; с точкой: "Товары.Add" → Form.Item.Товары.StandardCommand.Add

defaultButton: true

Кнопка по умолчанию

type

"usual" , "hyperlink" , "commandBar"

picture

Картинка кнопки

representation

"Auto" , "Text" , "Picture" , "PictureAndText"

locationInCommandBar

"Auto" , "InCommandBar" , "InAdditionalSubmenu"

Командная панель (cmdBar)

Ключ Описание

autofill: true

Автозаполнение стандартными командами

children: [...]

Кнопки панели

Выпадающее меню (popup)

Ключ Описание

title

Заголовок подменю

children: [...]

Кнопки подменю

Используется внутри cmdBar для группировки кнопок в подменю:

{ "cmdBar": "Панель", "children": [ { "popup": "Добавить", "title": "Добавить", "children": [ { "button": "ДобавитьСтроку", "stdCommand": "Товары.Add" }, { "button": "ДобавитьИзДокумента", "command": "ДобавитьИзДокумента", "title": "Из документа" } ]} ]}

Реквизиты (attributes)

{ "name": "Объект", "type": "DataProcessorObject.Загрузка", "main": true } { "name": "Итого", "type": "decimal(15,2)" } { "name": "Таблица", "type": "ValueTable", "columns": [ { "name": "Номенклатура", "type": "CatalogRef.Номенклатура" }, { "name": "Количество", "type": "decimal(10,3)" } ]}

  • savedData: true — сохраняемые данные

Команды (commands)

{ "name": "Загрузить", "action": "ЗагрузитьОбработка", "shortcut": "Ctrl+Enter" }

  • title — заголовок (если отличается от name)

  • picture — картинка команды

Система типов

DSL XML

"string" / "string(100)"

xs:string

  • StringQualifiers

"decimal(15,2)"

xs:decimal

  • NumberQualifiers

"decimal(10,0,nonneg)"

с AllowedSign=Nonnegative

"boolean"

xs:boolean

"date" / "dateTime" / "time"

xs:dateTime

  • DateFractions

"CatalogRef.XXX"

cfg:CatalogRef.XXX

"DocumentRef.XXX"

cfg:DocumentRef.XXX

"ValueTable"

v8:ValueTable

"ValueList"

v8:ValueListType

"Type1 | Type2"

составной тип

Связки: элемент + реквизит

Таблица и некоторые поля требуют связанный реквизит. Элемент ссылается на реквизит через path .

Таблица — элемент table

  • реквизит ValueTable :

{ "elements": [ { "table": "Товары", "path": "Объект.Товары", "columns": [ { "input": "Номенклатура", "path": "Объект.Товары.Номенклатура" } ]} ], "attributes": [ { "name": "Объект", "type": "DataProcessorObject.Загрузка", "main": true, "columns": [ { "name": "Товары", "type": "ValueTable", "columns": [ { "name": "Номенклатура", "type": "CatalogRef.Номенклатура" } ]} ] } ] }

Или, если таблица привязана к реквизиту формы (не к Объект):

{ "elements": [ { "table": "ТаблицаДанных", "path": "ТаблицаДанных", "columns": [ { "input": "Наименование", "path": "ТаблицаДанных.Наименование" } ]} ], "attributes": [ { "name": "ТаблицаДанных", "type": "ValueTable", "columns": [ { "name": "Наименование", "type": "string(150)" } ]} ] }

Паттерны

Диалог загрузки файла

{ "title": "Загрузка из файла", "properties": { "autoTitle": false }, "events": { "OnCreateAtServer": "ПриСозданииНаСервере" }, "elements": [ { "group": "horizontal", "name": "ГруппаФайл", "children": [ { "input": "ИмяФайла", "path": "ИмяФайла", "title": "Файл", "inputHint": "Выберите файл...", "choiceButton": true, "on": ["StartChoice"] }, { "check": "ПерваяСтрокаЗаголовок", "path": "ПерваяСтрокаЗаголовок" } ]}, { "input": "Результат", "path": "Результат", "multiLine": true, "height": 8, "readOnly": true, "title": "Лог" }, { "group": "horizontal", "name": "ГруппаКнопок", "children": [ { "button": "Загрузить", "command": "Загрузить", "defaultButton": true }, { "button": "Закрыть", "stdCommand": "Close" } ]} ], "attributes": [ { "name": "Объект", "type": "ExternalDataProcessorObject.ЗагрузкаИзФайла", "main": true }, { "name": "ИмяФайла", "type": "string" }, { "name": "ПерваяСтрокаЗаголовок", "type": "boolean" }, { "name": "Результат", "type": "string" } ], "commands": [ { "name": "Загрузить", "action": "ЗагрузитьОбработка", "shortcut": "Ctrl+Enter" } ] }

Мастер (wizard) с шагами

{ "title": "Мастер настройки", "properties": { "autoTitle": false }, "elements": [ { "pages": "СтраницыМастера", "pagesRepresentation": "None", "children": [ { "page": "Шаг1", "title": "Параметры", "children": [ { "input": "Параметр1", "path": "Параметр1" } ]}, { "page": "Шаг2", "title": "Результат", "children": [ { "input": "Итог", "path": "Итог", "readOnly": true } ]} ]}, { "group": "horizontal", "name": "Навигация", "children": [ { "button": "Назад", "command": "Назад", "title": "< Назад" }, { "button": "Далее", "command": "Далее", "title": "Далее >" } ]} ], "attributes": [ { "name": "Объект", "type": "ExternalDataProcessorObject.Мастер", "main": true }, { "name": "Параметр1", "type": "string" }, { "name": "Итог", "type": "string" } ], "commands": [ { "name": "Назад", "action": "НазадОбработка" }, { "name": "Далее", "action": "ДалееОбработка" } ] }

Список с фильтром и таблицей

{ "title": "Просмотр данных", "elements": [ { "group": "horizontal", "name": "Фильтр", "children": [ { "input": "Период", "path": "Период", "on": ["OnChange"] }, { "input": "Организация", "path": "Организация", "on": ["OnChange"] } ]}, { "table": "Данные", "path": "Данные", "changeRowSet": true, "columns": [ { "input": "Дата", "path": "Данные.Дата" }, { "input": "Сумма", "path": "Данные.Сумма" }, { "input": "Комментарий", "path": "Данные.Комментарий" } ]} ], "attributes": [ { "name": "Объект", "type": "ExternalDataProcessorObject.Просмотр", "main": true }, { "name": "Период", "type": "date" }, { "name": "Организация", "type": "string" }, { "name": "Данные", "type": "ValueTable", "columns": [ { "name": "Дата", "type": "date" }, { "name": "Сумма", "type": "decimal(15,2)" }, { "name": "Комментарий", "type": "string(200)" } ]} ] }

Автогенерация

  • Companion-элементы: ContextMenu, ExtendedTooltip и др. создаются автоматически

  • Обработчики событий: "on": ["OnChange"] → ОрганизацияПриИзменении

  • Namespace: все 17 namespace-деклараций

  • ID: последовательная нумерация, AutoCommandBar = id="-1"

  • Unknown keys: выводится предупреждение о нераспознанных ключах

Верификация

/form-validate <OutputPath> — проверка корректности XML /form-info <OutputPath> — визуальная сводка структуры

Особенности для внешних обработок (EPF)

  • Тип главного реквизита: ExternalDataProcessorObject.ИмяОбработки (не DataProcessorObject )

  • DataPath: используйте реквизиты формы (ИмяРеквизита ), а не Объект.ИмяРеквизита — у внешних обработок нет реквизитов объекта в метаданных

  • Ссылочные типы: CatalogRef.XXX , DocumentRef.XXX допустимы в XML, но для сборки EPF потребуется база с целевой конфигурацией (см. /epf-build )

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

1c-query-opt

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

skd-edit

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

1c-project-init

No summary provided by upstream source.

Repository SourceNeeds Review