feat(form-decompile,form-compile): свойства поля DataSet динсписка — presentationExpression + appearance

Обычное поле набора <Field DataSetFieldField> может нести:
- <dcssch:presentationExpression> (выражение представления поля, 30 форм) — строка;
- <dcssch:appearance> (формат/оформление поля, ~9 форм) — dcscor:item SettingsParameterValue
  (тот же блок, что в условном оформлении: параметр→значение с типизацией).

DSL: settings.fields[].presentationExpression (строка) + fields[].appearance (объект
{параметр:значение}). Декомпилятор: захват presentationExpression + appearance через
существующий Get-SettingsAppearance. Компилятор (ps1+py): presentationExpression перед
valueType, appearance после valueType (порядок исходника, подтверждён корпус-сигнатурами);
appearance переиспользует Emit-AppearanceValue/emit_appearance_value.

Выборка 36 форм с field pres/appearance: match 33/36, 0 потерь pres/appearance (остаток
3 формы — несвязанные нюансы пустого value параметра / пустого LocalStringType). Кейс
dynamic-list-form (+явное поле Code с presentationExpression+appearance Формат/ЦветТекста)
сертифицирован загрузкой в 1С. Регресс 43/43, ps1==py (общий снэпшот на обоих рантаймах).

Остаток field-свойств (BACKLOG): useRestriction/attributeUseRestriction/inputParameters/
order на обычном <Field> + 2 раскрытых нюанса (пустой xs:string value vs nil; пустой
LocalStringType self-closing vs пара).

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
Nick Shirokov
2026-06-12 19:52:19 +03:00
parent 73b07a6fbc
commit dab122c166
6 changed files with 51 additions and 4 deletions
@@ -1,4 +1,4 @@
# form-compile v1.140 — Compile 1C managed form from JSON or object metadata
# form-compile v1.141 — Compile 1C managed form from JSON or object metadata
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
param(
[string]$JsonPath,
@@ -5626,8 +5626,16 @@ function Emit-Attributes {
Emit-MLItems -val $fld.title -indent "$si`t`t"
X "$si`t</dcssch:title>"
}
# presentationExpression поля — перед valueType (порядок исходника)
if ($fld.presentationExpression) { X "$si`t<dcssch:presentationExpression>$(Esc-Xml "$($fld.presentationExpression)")</dcssch:presentationExpression>" }
# valueType поля набора (тип значения; вычисляемые/кастомные поля)
if ($fld.valueType) { Emit-DLValueType -typeStr "$($fld.valueType)" -indent "$si`t" }
# appearance поля (формат/оформление) — после valueType (порядок исходника)
if ($fld.appearance) {
X "$si`t<dcssch:appearance>"
foreach ($prop in $fld.appearance.PSObject.Properties) { Emit-AppearanceValue -key $prop.Name -val $prop.Value -indent "$si`t`t" }
X "$si`t</dcssch:appearance>"
}
X "$si</Field>"
}
}
@@ -1,5 +1,5 @@
#!/usr/bin/env python3
# form-compile v1.140 — Compile 1C managed form from JSON or object metadata
# form-compile v1.141 — Compile 1C managed form from JSON or object metadata
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
import argparse
import copy
@@ -5373,9 +5373,18 @@ def emit_attributes(lines, attrs, indent, conditional_appearance=None):
lines.append(f'{si}\t<dcssch:title xsi:type="v8:LocalStringType">')
emit_ml_items(lines, f'{si}\t\t', fld['title'])
lines.append(f'{si}\t</dcssch:title>')
# presentationExpression поля — перед valueType (порядок исходника)
if fld.get('presentationExpression'):
lines.append(f'{si}\t<dcssch:presentationExpression>{esc_xml(str(fld["presentationExpression"]))}</dcssch:presentationExpression>')
# valueType поля набора (тип значения; вычисляемые/кастомные поля)
if fld.get('valueType'):
emit_dl_value_type(lines, fld['valueType'], f'{si}\t')
# appearance поля (формат/оформление) — после valueType (порядок исходника)
if fld.get('appearance'):
lines.append(f'{si}\t<dcssch:appearance>')
for ak, av in fld['appearance'].items():
emit_appearance_value(lines, ak, av, f'{si}\t\t')
lines.append(f'{si}\t</dcssch:appearance>')
lines.append(f'{si}</Field>')
# Вычисляемые поля DataSet (<CalculatedField>) — после Field*, до Parameter*.
emit_calc_fields(lines, s.get('calculatedFields'), si)
@@ -1,4 +1,4 @@
# form-decompile v0.113 — Decompile 1C managed Form.xml to JSON DSL (draft)
# form-decompile v0.114 — Decompile 1C managed Form.xml to JSON DSL (draft)
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
# ВНИМАНИЕ: раундтрип не гарантируется. Навык исключён из авто-использования моделью.
param(
@@ -2614,6 +2614,11 @@ if ($attrsNode) {
# valueType поля набора (тип значения; вычисляемые/кастомные поля). Грамматика типа.
$fvt = $fn.SelectSingleNode("dcssch:valueType", $ns)
if ($fvt) { $fvtVal = Decompile-Type $fvt; if ($fvtVal) { $fo['valueType'] = $fvtVal } }
# presentationExpression (выражение представления поля) + appearance (формат/оформление поля)
$fpe = Get-Child $fn 'presentationExpression'
if ($null -ne $fpe -and $fpe -ne '') { $fo['presentationExpression'] = $fpe }
$fappNode = $fn.SelectSingleNode("dcssch:appearance", $ns)
if ($fappNode) { $fap = Get-SettingsAppearance $fappNode; if ($fap -and $fap.Count -gt 0) { $fo['appearance'] = $fap } }
[void]$fields.Add($fo)
}
$so['fields'] = @($fields)
+1 -1
View File
@@ -940,7 +940,7 @@ Forgiving-синонимы типа: XML-имя (`SpreadSheetDocumentField`) и
| `query` | string | Текст запроса (`ManualQuery=true`). Поддерживает `@file.sql` (путь относительно JSON) |
| `dynamicDataRead` | bool | Динамическое считывание. **Умолчание `true`** — указывать только для отключения (`false`) |
| `autoFillAvailableFields` | bool | Автозаполнение доступных полей (`<AutoFillAvailableFields>`). **Умолчание `true`** — указывать только для отключения (`false`; тогда поля берутся из явного запроса, не авто). Эмитится первым в `<Settings>` |
| `fields` | array | Явные поля набора (редко): `{ field, dataPath?, title?, valueType?, nested? }` — для переопределения заголовка/типа. `valueType` — тип значения поля (грамматика типа). `nested: true` помечает поле-вложенный набор (`DataSetFieldNestedDataSet` = реквизит табличной части объекта; дефолт — `DataSetFieldField`). Обычно поля выводятся из запроса автоматически |
| `fields` | array | Явные поля набора (редко): `{ field, dataPath?, title?, valueType?, presentationExpression?, appearance?, nested? }` — для переопределения свойств поля. `valueType` — тип значения (грамматика типа). `presentationExpression` — выражение представления поля (строка). `appearance` — оформление/формат поля: объект `{ Параметр: Значение }` (та же грамматика, что `appearance` условного оформления, напр. `{ "Формат": "ДЛ=9", "ЦветТекста": "web:Gray" }`). `nested: true` помечает поле-вложенный набор (`DataSetFieldNestedDataSet` = реквизит табличной части объекта; дефолт — `DataSetFieldField`). Обычно поля выводятся из запроса автоматически |
| `calculatedFields` | array | Вычисляемые поля набора (см. ниже) |
| `parameters` | array | Параметры схемы запроса (`DataCompositionSchemaParameter`) — см. ниже |
| `order` | array | Сортировка списка (см. ниже) |
@@ -20,6 +20,10 @@
{ "name": "Список", "type": "DynamicList", "useAlways": ["~Артикул", "Список.Code", "Description"], "settings": {
"mainTable": "Catalog.Товары", "dynamicDataRead": true, "autoSaveUserSettings": false,
"parameters": [ { "name": "ВыборТовара", "type": "CatalogRef.Товары", "valueListAllowed": true, "value": null } ],
"fields": [
{ "field": "Code", "title": "Код", "presentationExpression": "\"№\" + Code",
"appearance": { "Формат": "ДЛ=9", "ЦветТекста": "web:Gray" } }
],
"grouping": "Description > Code",
"calculatedFields": [
"Метка [Метка строки]: string = Code + \" \" + Description #noFilter #noGroup",
@@ -100,6 +100,27 @@
<Settings xsi:type="DynamicList">
<ManualQuery>false</ManualQuery>
<DynamicDataRead>true</DynamicDataRead>
<Field xsi:type="dcssch:DataSetFieldField">
<dcssch:dataPath>Code</dcssch:dataPath>
<dcssch:field>Code</dcssch:field>
<dcssch:title xsi:type="v8:LocalStringType">
<v8:item>
<v8:lang>ru</v8:lang>
<v8:content>Код</v8:content>
</v8:item>
</dcssch:title>
<dcssch:presentationExpression>"№" + Code</dcssch:presentationExpression>
<dcssch:appearance>
<dcscor:item xsi:type="dcsset:SettingsParameterValue">
<dcscor:parameter>Формат</dcscor:parameter>
<dcscor:value xsi:type="xs:string">ДЛ=9</dcscor:value>
</dcscor:item>
<dcscor:item xsi:type="dcsset:SettingsParameterValue">
<dcscor:parameter>ЦветТекста</dcscor:parameter>
<dcscor:value xsi:type="v8ui:Color">web:Gray</dcscor:value>
</dcscor:item>
</dcssch:appearance>
</Field>
<CalculatedField>
<dcssch:dataPath>Метка</dcssch:dataPath>
<dcssch:expression>Code + " " + Description</dcssch:expression>