Платформа 3V/Формы/Источники данных/Отчет/Параметры/На значении выражения (EntryExpressionByExpression): различия между версиями

Материал из 3v-wiki
Перейти к навигации Перейти к поиску
Строка 23: Строка 23:
 
| expressionId || Идентификатор [[Платформа_3V/Формы/Выражения|'''выражения''']]
 
| expressionId || Идентификатор [[Платформа_3V/Формы/Выражения|'''выражения''']]
 
|}
 
|}
 
==Пример использования в качестве параметра выражения==
 
При необходимости вычисления некоторого выражения на основании значения вычисленного с помощью другого выражения, добавленного ранее, используется соответствующий параметр EntryExpressionByExpressionDto
 
 
Кейс: Собрать строковый элемент управления, в котором будет отображаться "Договоры:" + "Наименования договоров"
 
 
"Наименования договоров" собрать из наименований договоров, которые выбраны пользователем в соответствующем элементе управления на справочнике "Договоры" (использовать для этого отдельное выражение на расчет строки с перечнем наименований договоров с помощью выражения [[Платформа_3V/Формы/Параметры_выражений_и_отчетов/На_источнике_-_справочнике_(EntryExpressionDictionarySourceParameterDto)|'''на источнике карточки - справочнике (EntryExpressionDictionarySourceParameterDto)''']])
 
 
И в отдельном выражении добавить перечню договоров фразу "Договоры:"
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:800px; overflow:auto;">
 
<div style="font-weight:bold;line-height:1.6;">JSON серверной карточки</div>
 
<div class="mw-collapsible-content mw-collapsed-content">
 
<syntaxhighlight lang="JSON" line>
 
{
 
"id": 123,
 
"name": "Использование в выражении параметра EntryExpressionByExpressionDto",
 
"description": null,
 
"title": null,
 
"entrySettings": null,
 
"uiSources": [
 
{
 
"dataSourceId": 100,
 
"nameTemplate": "",
 
"displayAttribute": null,
 
"hasMultipleValue": true,
 
"hasNullableValue": false,
 
"maxElements": null,
 
"hasServerFiltration": false,
 
"searchSettings": {
 
"maxElements": null,
 
"minInputChars": 2,
 
"searchMode": "Client",
 
"debounceMs": 300
 
},
 
"id": 1,
 
"caption": "Выпадающий список договоров",
 
"enable": true,
 
"visible": true,
 
"hint": null,
 
"doActionOnChangeValue": true,
 
"onAfterChangeValueConditionalActions": null,
 
"onAfterChangeValueByClientConditionalActions": null,
 
"rebuildDependentsObjectOnChange": true,
 
"enableRuleIds": [],
 
"visibleRuleIds": [],
 
"access": null,
 
"isValueChanged": false,
 
"expressionId": null,
 
"discriminator": "DictionarySourceEntry"
 
},
 
{
 
"trimSpaces": false,
 
"defaultValue": null,
 
"value": null,
 
"id": 2,
 
"caption": "Договоры: 'Наименования договоров' (строка)",
 
"enable": true,
 
"visible": true,
 
"hint": null,
 
"doActionOnChangeValue": false,
 
"onAfterChangeValueConditionalActions": null,
 
"onAfterChangeValueByClientConditionalActions": null,
 
"rebuildDependentsObjectOnChange": true,
 
"enableRuleIds": [],
 
"visibleRuleIds": [],
 
"access": null,
 
"isValueChanged": false,
 
"expressionId": 1001,
 
"discriminator": "StringSourceEntry"
 
}
 
],
 
"entryDataSources": [
 
{
 
"dictionaryId": 38238,
 
"hierarchyId": null,
 
"filter": null,
 
"sortingOptions": null,
 
"groupingOptions": null,
 
"dictionaryAttributes": null,
 
"defaultValueExpressionId": null,
 
"parameterId": null,
 
"dictionarySourceSelectionMode": "None",
 
"dataSourceAttributesAdditionsSettings": [],
 
"externalFileStorageUrl": null,
 
"filePrefix": null,
 
"defaultNewElementSettings": null,
 
"id": 100,
 
"name": "Договоры",
 
"isReadOnly": true,
 
"dataEditRuleIds": [],
 
"beforeSaveDataActions": [],
 
"afterSaveDataActions": [],
 
"discriminator": "DictionaryDataSource"
 
}
 
],
 
"parameters": [],
 
"binaryConditionsRules": [],
 
"submitValidateRules": [],
 
"expressions": [
 
{
 
"id": 1000,
 
"expression": "Concatenate(', ', [1])",
 
"returnFirstParameterValue": false,
 
"parameters": [
 
{
 
"id": 1,
 
"allowMultipleValues": true,
 
"discriminator": "EntryExpressionDictionarySourceParameterDto",
 
"dictionarySourceId": 100,
 
"attributeId": 2,
 
"getFirstElementValue": false,
 
"useAllInstanceElements": false
 
}
 
],
 
"comment": "Получение строки с перечнем наименований выбранных пользователем договоров"
 
},
 
{
 
"id": 1001,
 
"expression": "'Договоры: '+ [1]",
 
"returnFirstParameterValue": false,
 
"parameters": [
 
{
 
"id": 1,
 
"allowMultipleValues": false,
 
"discriminator": "EntryExpressionByExpressionDto",
 
"expressionId": 1000
 
}
 
],
 
"comment": "Добавление к перечню наименований 'Договоры:'"
 
}
 
],
 
"controlsValueCalculateRules": [],
 
"actions": [],
 
"conditionActionIdsOnOpen": [],
 
"conditionalActions": [],
 
"selectionSets": [],
 
"reportTemplates": [],
 
"useNewDependenciesBuilder": null
 
}
 
</syntaxhighlight>
 
</div></div>
 
  
 
==Пример использования в качестве параметра отчета==
 
==Пример использования в качестве параметра отчета==

Версия 11:56, 17 сентября 2021

Параметр, который возращает значение другого выражения, добавленного ранее в серверную карточку, имеет следующую структуру:

1 {
2 	"id": 1,
3 	"allowMultipleValues": false,
4 	"discriminator": "EntryExpressionByExpressionDto",
5 	"expressionId": 1000
6 }

Описание свойств параметра

Свойство Описание
id Идентификатор параметра
allowMultipleValues Флаг об получении результата в виде коллекции значений (true/false)
discriminator EntryExpressionByExpressionDto
expressionId Идентификатор выражения

Пример использования в качестве параметра отчета

При необходимости передать в качестве параметра отчета значение расчетного выражения, используется соответствующий параметр EntryExpressionByExpressionDto

Кейс: Отчет отображает реестр компаний с типом "Публичное акционерное общество", перечень компаний приходит в параметр отчета (id=1) на основании справочника "Компании" без возможности менять перечень пользователем. Также должна учитываться фильтрация элементов по атр."Тип контрагента" (id=21) = "Публичное акционерное общество" (id=3). Также элемент управления отображает отфильтрованные компании без возможности изменения. Сформировать одно, единое выражение с помощью справочника - объекта репозитория (EntryExpressionByDictionaryRequestDto), которое будет использоваться для получения отметки в элементе управления, а также в параметре отчета

JSON серверной карточки
  1 {
  2 	"id": 123,
  3 	"title": "Использование в отчете параметра EntryExpressionByExpressionDto",
  4 	"description": "",
  5 	"uiSources": [
  6 		{
  7 			"dataSourceId": 100,
  8 			"nameTemplate": "",
  9 			"displayAttribute": null,
 10 			"hasMultipleValue": true,
 11 			"hasNullableValue": false,
 12 			"maxElements": null,
 13 			"hasServerFiltration": false,
 14 			"id": 1,
 15 			"caption": "Выпадающий список ПАО",
 16 			"enable": false,
 17 			"visible": true,
 18 			"hint": null,
 19 			"doActionOnChangeValue": false,
 20 			"onAfterChangeValueConditionalActions": null,
 21 			"onAfterChangeValueByClientConditionalActions": null,
 22 			"rebuildDependentsObjectOnChange": true,
 23 			"enableRuleIds": [],
 24 			"visibleRuleIds": [],
 25 			"access": null,
 26 			"isValueChanged": false,
 27 			"expressionId": 1000,
 28 			"discriminator": "DictionarySourceEntry"
 29 		},
 30 {
 31 			"pivotSourceId": 101,
 32 			"doActionOnChangeFocusedCell": false,
 33 			"doActionOnChangeCellValue": false,
 34 			"id": 2,
 35 			"caption": null,
 36 			"enable": false,
 37 			"visible": true,
 38 			"hint": null,
 39 			"caption": "Реестр ПАО",
 40 			"uiDataSource": null,
 41 			"doActionOnChangeValue": false,
 42 			"onAfterChangeValueConditionalActions": null,
 43 			"onAfterChangeValueByClientConditionalActions": null,
 44 			"rebuildDependentsObjectOnChange": true,
 45 			"enableRuleIds": [],
 46 			"visibleRuleIds": [],
 47 			"access": null,
 48 			"isValueChanged": false,
 49 			"expressionId": null,
 50 			"discriminator": "PivotSourceEntry"
 51 		}
 52 	],
 53 	"entryDataSources": [
 54 			{
 55 			"dictionaryId": 536,
 56 			"hierarchyId": null,
 57 			"filter": null,
 58 			"sortingOptions": null,
 59 			"groupingOptions": null,
 60 			"dictionaryAttributes": null,
 61 			"defaultValueExpressionId": null,
 62 			"parameterId": null,
 63 			"dictionarySourceSelectionMode": "None",
 64 			"dataSourceAttributesAdditionsSettings": [],
 65 			"externalFileStorageUrl": null,
 66 			"filePrefix": null,
 67 			"defaultNewElementSettings": null,
 68 			"id": 100,
 69 			"name": "Компании",
 70 			"isReadOnly": true,
 71 			"dataEditRuleIds": [],
 72 			"beforeSaveDataActions": [],
 73 			"afterSaveDataActions": [],
 74 			"discriminator": "DictionaryDataSource"
 75 		},
 76 {
 77 			"pivotId": 31000,
 78 			"parameters": [
 79 				{
 80 					"id": 1,
 81 					"allowMultipleValues": true,
 82 					"discriminator": "EntryExpressionByExpressionDto",
 83 					"expressionId": 1000
 84 				}
 85 			],
 86 			"focusOnFirstCell": true,
 87 			"id": 101,
 88 			"name": "Отчетная информация компаний. Параметр отчета на выражении",
 89 			"isReadOnly": true,
 90 			"dataEditRuleIds": [],
 91 			"beforeSaveDataActions": [],
 92 			"afterSaveDataActions": [],
 93 			"discriminator": "PivotDataSource"
 94 		}
 95 	],
 96 	"parameters": [],
 97 	"binaryConditionsRules": [],
 98 	"expressions": [
 99 		{
100 			"id": 1000,
101 			"expression": "[1]",
102 			"returnFirstParameterValue": false,
103 			"parameters": [
104 				{
105 					"id": 1,
106 					"allowMultipleValues": true,
107 					"discriminator": "EntryExpressionByDictionaryRequestDto",
108 					"dictionaryId": 536,
109 					"attributeId": 1,
110 					"filter": {
111 						"value": [
112 							3
113 						],
114 						"attributeId": 21,
115 						"conditionType": "AttributeInCollection",
116 						"inversion": false,
117 						"conditionId": null,
118 						"discriminator": "ValueConditionalDictionaryFilterDto"
119 					}
120 				}
121 			],
122 			"comment": "Вычисление компаний с типом ПАО"
123 		}
124 	],
125 	"actions": [],
126 	"conditionalActions": [],
127 	"conditionActionIdsOnOpen": []
128 }