Платформа 3V/Формы/Источники данных/Справочник/Фильтрация/От значений выражения: различия между версиями

Материал из 3v-wiki
Перейти к навигации Перейти к поиску
Строка 79: Строка 79:
 
| parameters || Виды параметров и ссылки на детальную настройку каждого вида в JSON описана на странице [[Платформа 3V/Формы/Параметры выражений и отчетов|'''Параметры выражений и отчетов''']]
 
| parameters || Виды параметров и ссылки на детальную настройку каждого вида в JSON описана на странице [[Платформа 3V/Формы/Параметры выражений и отчетов|'''Параметры выражений и отчетов''']]
 
|}
 
|}
 +
 +
===Пример===
 +
В клиентской карточке размещен чек-бокс, при включении которого из справочника "Контрагенты" отфильтровываются только элементы вида ПАО и ООО. Если чек-бокс отключен, то отфильтровываются остальные элементы.
 +
 +
[[Файл:Screenshot 2021-04-23 at 17.32.33|мини|слева]]
 +
 +
<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": 48,
 +
  "name": "Пример фильтра от значений в выражении (EntryExpressionFilterDto)",
 +
  "description": null,
 +
  "title": "Пример фильтра от значений в выражениие",
 +
  "entrySettings": null,
 +
  "uiSources": [
 +
    {
 +
      "id": 1,
 +
      "caption": "Галочка",
 +
      "enable": true,
 +
      "visible": true,
 +
      "hint": null,
 +
      "doActionOnChangeValue": true,
 +
      "onAfterChangeValueConditionalActions": null,
 +
      "onAfterChangeValueByClientConditionalActions": null,
 +
      "rebuildDependentsObjectOnChange": true,
 +
      "enableRuleIds": [],
 +
      "visibleRuleIds": [],
 +
      "access": null,
 +
      "isValueChanged": true,
 +
      "expressionId": null,
 +
      "discriminator": "BoolSourceEntry"
 +
    },
 +
    {
 +
      "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,
 +
      "dataSourceId": 3,
 +
      "discriminator": "DictionarySourceEntry",
 +
      "hasMultipleValue": true
 +
    }
 +
  ],
 +
  "entryDataSources": [
 +
    {
 +
      "dictionaryId": 47,
 +
      "hierarchyId": null,
 +
      "filter": {
 +
        "expressionId": 10,
 +
        "attribute": {
 +
          "id": 21,
 +
          "discriminator": "OwnAttributeDefinitionDto"
 +
        },
 +
        "conditionType": "AttributeInCollection",
 +
        "inversion": false,
 +
        "conditionId": null,
 +
        "discriminator": "EntryExpressionFilterDto"
 +
      },
 +
      "sortingOptions": null,
 +
      "groupingOptions": null,
 +
      "dictionaryAttributes": [],
 +
      "defaultValue": [],
 +
      "defaultValueExpressionId": null,
 +
      "parameterId": null,
 +
      "dictionarySourceSelectionMode": "SelectAll",
 +
      "dataSourceAttributesAdditionsSettings": [],
 +
      "externalFileStorageUrl": null,
 +
      "filePrefix": null,
 +
      "defaultNewElementSettings": null,
 +
      "id": 3,
 +
      "name": "Контрагенты",
 +
      "isReadOnly": false,
 +
      "dataEditRuleIds": [],
 +
      "beforeSaveDataActions": [],
 +
      "afterSaveDataActions": [],
 +
      "discriminator": "DictionaryDataSource"
 +
    }
 +
  ],
 +
  "parameters": [],
 +
  "binaryConditionsRules": [],
 +
  "submitValidateRules": [],
 +
  "expressions": [
 +
    {
 +
      "id": 10,
 +
      "expression": "if([1]='true', [2], [3])",
 +
      "returnFirstParameterValue": false,
 +
      "parameters": [
 +
        {
 +
          "uiSourceId": 1,
 +
          "id": 1,
 +
          "allowMultipleValues": false,
 +
          "discriminator": "EntryExpressionUiSourceParameterDto"
 +
        },
 +
        {
 +
          "id": 2,
 +
          "allowMultipleValues": true,
 +
          "discriminator": "EntryExpressionConstantParameterDto",
 +
          "value": [
 +
            3,
 +
            5
 +
          ]
 +
        },
 +
        {
 +
          "id": 3,
 +
          "allowMultipleValues": true,
 +
          "discriminator": "EntryExpressionConstantParameterDto",
 +
          "value": [
 +
            1,
 +
            2,
 +
            4,
 +
            6,
 +
            7,
 +
            8
 +
          ]
 +
        }
 +
      ],
 +
      "comment": null
 +
    }
 +
  ],
 +
  "controlsValueCalculateRules": [],
 +
  "actions": [],
 +
  "conditionActionIdsOnOpen": [],
 +
  "conditionalActions": [],
 +
  "selectionSets": [],
 +
  "reportTemplates": [],
 +
  "useNewDependenciesBuilder": null
 +
}
 +
 +
</syntaxhighlight>
 +
</div></div>

Версия 14:36, 23 апреля 2021

!!! СТРАНИЦА НАХОДИТСЯ В СТАДИИ РАЗРАБОКИ!!!
Фильтр по значению выражения используется в тех случаях, когда необходимо отфильтровать данные по нескольким параметрам (см. пример). Ниже представлена структура фильтра.

 1  "filter": {
 2         "expressionId": 10,
 3         "attribute": {
 4           "id": 21,
 5           "discriminator": "OwnAttributeDefinitionDto"
 6         },
 7         "conditionType": "AttributeInCollection",
 8         "inversion": false,
 9         "conditionId": null,
10         "discriminator": "EntryExpressionFilterDto"
11       },

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

Свойство Описание
expressionId id выражения
attribute Атрибут текущего источника - справочника, элемент которого будет выбран по заданному параметру. Указывается номер Id и тип атрибута в данном случае собственный (OwnAttributeDefinitionDto), так как используются данные текущего справочника.
discriminator EntryExpressionFilterDto
conditionType Тип условий
inversion В значении "false" источник-справочник принимает значения, которые удовлетворяют фильтру, в значении "true" - все значения, которые наоборот не удовлетворяют ему
conditionId Условия, при которых применяется фильтр

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

 1  "expressions": [
 2     {
 3       "id": 10,
 4       "expression": "if([1]='true', [2], [3])",
 5       "returnFirstParameterValue": false,
 6       "parameters": [
 7         {
 8           "uiSourceId": 1,
 9           "id": 1,
10           "allowMultipleValues": false,
11           "discriminator": "EntryExpressionUiSourceParameterDto"
12         },
13         {
14           "id": 2,
15           "allowMultipleValues": true,
16           "discriminator": "EntryExpressionConstantParameterDto",
17           "value": [
18             3,
19             5
20           ]
21         },
22         {
23           "id": 3,
24           "allowMultipleValues": true,
25           "discriminator": "EntryExpressionConstantParameterDto",
26           "value": [8]
27         }
28       ],

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

Свойство Описание
Id id выражения, на которое ссылается фильтр
expression Выражение описывается через параметры (операнды), которые описываются внутри данного блока ниже. Более подробно об этом элементе можно найти на странице Выражения
returnFirstParameterValue Флаг получения в выражении отметки первого параметра в блоке "parameters" без учета самого выражения, написанного в "expression"
parameters Виды параметров и ссылки на детальную настройку каждого вида в JSON описана на странице Параметры выражений и отчетов

Пример

В клиентской карточке размещен чек-бокс, при включении которого из справочника "Контрагенты" отфильтровываются только элементы вида ПАО и ООО. Если чек-бокс отключен, то отфильтровываются остальные элементы.

JSON серверной карточки
  1 {
  2   "id": 48,
  3   "name": "Пример фильтра от значений в выражении (EntryExpressionFilterDto)",
  4   "description": null,
  5   "title": "Пример фильтра от значений в выражениие",
  6   "entrySettings": null,
  7   "uiSources": [
  8     {
  9       "id": 1,
 10       "caption": "Галочка",
 11       "enable": true,
 12       "visible": true,
 13       "hint": null,
 14       "doActionOnChangeValue": true,
 15       "onAfterChangeValueConditionalActions": null,
 16       "onAfterChangeValueByClientConditionalActions": null,
 17       "rebuildDependentsObjectOnChange": true,
 18       "enableRuleIds": [],
 19       "visibleRuleIds": [],
 20       "access": null,
 21       "isValueChanged": true,
 22       "expressionId": null,
 23       "discriminator": "BoolSourceEntry"
 24     },
 25     {
 26       "trimSpaces": false,
 27       "defaultValue": null,
 28       "value": null,
 29       "id": 2,
 30       "caption": "Контрагент",
 31       "enable": true,
 32       "visible": true,
 33       "hint": null,
 34       "doActionOnChangeValue": false,
 35       "onAfterChangeValueConditionalActions": null,
 36       "onAfterChangeValueByClientConditionalActions": null,
 37       "rebuildDependentsObjectOnChange": true,
 38       "enableRuleIds": [],
 39       "visibleRuleIds": [],
 40       "access": null,
 41       "isValueChanged": false,
 42       "dataSourceId": 3,
 43       "discriminator": "DictionarySourceEntry",
 44       "hasMultipleValue": true
 45     }
 46   ],
 47   "entryDataSources": [
 48     {
 49       "dictionaryId": 47,
 50       "hierarchyId": null,
 51       "filter": {
 52         "expressionId": 10,
 53         "attribute": {
 54           "id": 21,
 55           "discriminator": "OwnAttributeDefinitionDto"
 56         },
 57         "conditionType": "AttributeInCollection",
 58         "inversion": false,
 59         "conditionId": null,
 60         "discriminator": "EntryExpressionFilterDto"
 61       },
 62       "sortingOptions": null,
 63       "groupingOptions": null,
 64       "dictionaryAttributes": [],
 65       "defaultValue": [],
 66       "defaultValueExpressionId": null,
 67       "parameterId": null,
 68       "dictionarySourceSelectionMode": "SelectAll",
 69       "dataSourceAttributesAdditionsSettings": [],
 70       "externalFileStorageUrl": null,
 71       "filePrefix": null,
 72       "defaultNewElementSettings": null,
 73       "id": 3,
 74       "name": "Контрагенты",
 75       "isReadOnly": false,
 76       "dataEditRuleIds": [],
 77       "beforeSaveDataActions": [],
 78       "afterSaveDataActions": [],
 79       "discriminator": "DictionaryDataSource"
 80     }
 81   ],
 82   "parameters": [],
 83   "binaryConditionsRules": [],
 84   "submitValidateRules": [],
 85   "expressions": [
 86     {
 87       "id": 10,
 88       "expression": "if([1]='true', [2], [3])",
 89       "returnFirstParameterValue": false,
 90       "parameters": [
 91         {
 92           "uiSourceId": 1,
 93           "id": 1,
 94           "allowMultipleValues": false,
 95           "discriminator": "EntryExpressionUiSourceParameterDto"
 96         },
 97         {
 98           "id": 2,
 99           "allowMultipleValues": true,
100           "discriminator": "EntryExpressionConstantParameterDto",
101           "value": [
102             3,
103             5
104           ]
105         },
106         {
107           "id": 3,
108           "allowMultipleValues": true,
109           "discriminator": "EntryExpressionConstantParameterDto",
110           "value": [
111             1,
112             2,
113             4,
114             6,
115             7,
116             8
117           ]
118         }
119       ],
120       "comment": null
121     }
122   ],
123   "controlsValueCalculateRules": [],
124   "actions": [],
125   "conditionActionIdsOnOpen": [],
126   "conditionalActions": [],
127   "selectionSets": [],
128   "reportTemplates": [],
129   "useNewDependenciesBuilder": null
130 }