form-info
$
npx mdskill add SteelMorgan/1c-agent-based-dev-framework/form-infoAnalyzes 1C managed form structure from Form.xml to reveal elements, attributes, commands, and events for form module development and handler analysis.
- Helps developers understand form layouts and behaviors when writing form modules or analyzing event handlers.
- Integrates with Bash for command execution and uses Read and Glob tools for file access and path resolution.
- Parses XML data to extract and summarize form properties, focusing on non-default settings and structural components.
- Presents results in a structured text format with headers, property lists, and pagination for large outputs.
SKILL.md
.github/skills/form-infoView on GitHub ↗
---
name: form-info
description: Анализ структуры управляемой формы 1С (Form.xml) — элементы, реквизиты, команды, события. Используй для понимания формы — при написании модуля формы, анализе обработчиков и элементов
argument-hint: <FormPath>
allowed-tools:
- Bash
- Read
- Glob
---
# /form-info — Компактная сводка формы
## Использование
```
/form-info <FormPath>
```
## Параметры
| Параметр | Обязательный | По умолчанию | Описание |
|-----------|:------------:|--------------|---------------------------------------------|
| FormPath | да | — | Путь к файлу Form.xml |
| Limit | нет | `150` | Макс. строк вывода (защита от переполнения) |
| Offset | нет | `0` | Пропустить N строк (для пагинации) |
## Команда
```bash
python3 scripts/form-info.py -FormPath "<путь к Form.xml>"
```
С пагинацией:
```bash
python3 scripts/form-info.py -FormPath "<путь>" -Offset 150
```
## Чтение вывода
### Заголовок
```
=== Form: ФормаДокумента — "Реализация товаров и услуг" (Documents.РеализацияТоваровУслуг) ===
```
Для заимствованных форм расширения (с `<BaseForm>`):
```
=== Form: ФормаЭлемента [EXTENSION] (Catalogs.Валюты) ===
```
### Properties — свойства формы
Только нестандартные свойства (отличающиеся от умолчания):
```
Properties: AutoTitle=false, WindowOpeningMode=LockOwnerWindow, CommandBarLocation=Bottom
```
### Events — обработчики событий формы
```
Events:
OnCreateAtServer -> ПриСозданииНаСервере
OnOpen -> ПриОткрытии
```
Для расширений с callType:
```
Events:
OnCreateAtServer[After] -> Расш1_ПриСозданииПосле
OnOpen[Before] -> Расш1_ПриОткрытии
```
### Elements — дерево UI-элементов
Компактное дерево с типами, привязками к данным, флагами и событиями:
```
Elements:
├─ [Group:AH] ГруппаШапка
│ ├─ [Input] Организация -> Объект.Организация {OnChange}
│ └─ [Input] Договор -> Объект.Договор [visible:false] {StartChoice}
├─ [Table] Товары -> Объект.Товары
│ ├─ [Input] Номенклатура -> Объект.Товары.Номенклатура {OnChange}
│ └─ [Input] Сумма -> Объект.Товары.Сумма [ro]
└─ [Pages] Страницы
├─ [Page] Основное (5 items)
└─ [Page] Печать (2 items)
```
**Сокращения типов элементов:**
| Сокращение | Элемент |
|---|---|
| `[Group:V]` | UsualGroup Vertical |
| `[Group:H]` | UsualGroup Horizontal |
| `[Group:AH]` | UsualGroup AlwaysHorizontal |
| `[Group:AV]` | UsualGroup AlwaysVertical |
| `[Group]` | UsualGroup (ориентация по умолчанию) |
| `[Input]` | InputField |
| `[Check]` | CheckBoxField |
| `[Label]` | LabelDecoration |
| `[LabelField]` | LabelField |
| `[Picture]` | PictureDecoration |
| `[PicField]` | PictureField |
| `[Calendar]` | CalendarField |
| `[Table]` | Table |
| `[Button]` | Button |
| `[CmdBar]` | CommandBar |
| `[Pages]` | Pages |
| `[Page]` | Page (показывает кол-во элементов вместо раскрытия) |
| `[Popup]` | Popup |
| `[BtnGroup]` | ButtonGroup |
**Флаги** (только при отклонении от умолчания):
- `[visible:false]` — элемент скрыт (Visible=false)
- `[enabled:false]` — элемент недоступен (Enabled=false)
- `[ro]` — ReadOnly=true
- `,collapse` — Behavior=Collapsible (для групп)
**Привязка к данным**: `-> Объект.Поле` — DataPath
**Привязка к команде**: `-> ИмяКоманды [cmd]` — команда формы, `-> Close [std]` — стандартная команда
**События**: `{OnChange, StartChoice}` — имена обработчиков; `{OnChange[Before]}` — с callType для расширений
**Заголовок**: `[title:Текст]` — только если отличается от имени элемента
### Attributes — реквизиты формы
```
Attributes:
*Объект: DocumentObject.РеализацияТоваров (main)
Валюта: CatalogRef.Валюты
Итого: decimal(15,2)
Таблица: ValueTable [Номенклатура: CatalogRef.Номенклатура, Кол: decimal(10,3)]
Список: DynamicList -> Catalog.Пользователи
```
- `*` и `(main)` — основной реквизит формы (MainAttribute)
- Типы ValueTable/ValueTree раскрывают колонки в `[...]`
- DynamicList показывает MainTable через `->`
### Parameters — параметры формы
```
Parameters:
Ключ: DocumentRef.ЗакупкаТоваров (key)
Основание: DocumentRef.*
```
- `(key)` — ключевой параметр (KeyParameter)
### Commands — команды формы
```
Commands:
Печать -> ПечатьДокумента [Ctrl+P]
Заполнить -> ЗаполнитьОбработка
```
Для расширений с callType на Action:
```
Commands:
Подбор -> Расш1_ПодборПеред[Before], Расш1_ПодборПосле[After]
```
Формат: `Имя -> Обработчик [Сочетание]`
### BaseForm (расширения)
Для заимствованных форм в конце выводится:
```
BaseForm: present (version 2.17)
```
## Пропускаемые данные
Визуальные свойства, автогенерированные ExtendedTooltip/ContextMenu, мультиязычные обёртки, namespace-декларации, атрибуты id. Для деталей — grep по имени элемента.
## Защита от переполнения
Вывод ограничен 150 строками. При превышении используй `-Offset N` и `-Limit N` для пагинации.