Кнопку вызова конструктора выражений

Обновлено: 05.11.2024

При разработке отчетов с применением Системы компоновки данных (СКД) требуется составлять выражения на языке СКД, которые применяются для описания вычисляемых полей, ресурсов, условий связи, параметров макета и т.п. Эти выражения часто бывают довольно сложными, например, такими:

КОГДА &Периодичность = 6 ТОГДА Формат(Период, "ДФ=dd.MM.yy")

КОГДА &Периодичность = 7 ТОГДА Формат(НачалоПериода(Период, "Неделя"), "ДФ=dd.MM.yy") + " - " + Формат(КонецПериода(Период, "Неделя"), "ДФ=dd.MM.yy")

КОГДА &Периодичность = 8 ТОГДА Формат(НачалоПериода(Период, "Декада"), "ДФ=dd.MM.yy") + " - " + Формат(КонецПериода(Период, "Декада"), "ДФ=dd.MM.yy")

КОГДА &Периодичность = 9 ТОГДА Формат(Период, "ДФ = 'MMMM yy'")

КОГДА &Периодичность = 10 ТОГДА Формат(Период, "ДФ='к ""кв."" yyyy'")

КОГДА &Периодичность = 11 ТОГДА

КОГДА Квартал(Период) < 2 ТОГДА Формат(Период, "ДФ = '""1 полугодие"" yy'")

ИНАЧЕ Формат(Период, "ДФ = '""2 полугодие"" yy'")

КОГДА &Периодичность = 12 ТОГДА Формат(Период, "ДФ = 'yyyy'")

К сожалению, в Редакторе СКД средства конструирования подобных сложных выражений на сегодняшний день отсутствуют, и их приходится полностью выписывать вручную.

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

Она представляет из себя внешний отчет КонструкторВыраженийСКД.erf, в который нужно загрузить схему того отчета, для которого нужно построить выражения.

Чтобы воспользоваться Конструктором, нужно:

а) выгрузить схему компоновки данных, для которой нужно построить выражения, в xml -файл (стандартная операция СКД);

б) загрузить этот xml -файл в макет ОСНОВНАЯ_СХЕМА_КОМПОНОВКИ_ДАННЫХ внешнего отчета Конструктор выражений СКД;

в) сохранить отчет Конструктор выражений СКД;

г) запустить отчет Конструктор выражений СКД в управляемом режиме 1С:Предприятие (можно из тонкого клиента).

После запуска отчета в режиме 1С:Предприятие появляется форма, которая содержит:

а) списки доступных полей загруженной схемы компоновки данных (доступные поля выбора, порядка, а также параметры данных);

б) список конструкций языка СКД;

в) текстовое поле для формирования выражения, в которое можно перетаскивать указанные элементы выражений мышью (drag ' n ' drop ):

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

По нажатию соответствующей кнопки на форме открывается Конструктор форматной строки, в котором можно настроить формат; после его закрытия форматная строка появляется в тексте выражения - в том месте, где стоял текстовый курсор.

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

Если перед нажатием кнопки копирования в буфер обмена некий фрагмент текста был выделен, то в буфер обмена копируется выделенный фрагмент, если выделения не было, то копируется весь текст выражения.

После того, как все нужные выражения составлены, форму Конструктора можно закрыть. При закрытии формы в буфер обмена помещается текст из текстового поля - таким образом выполняется страховка потери текста сформированного выражения при случайном закрытии формы Конструктора выражений СКД.

Читайте также: