[БСП] Расшифровка внешнего отчета другим вариантом

19.12.24

Разработка - Работа с интерфейсом

Пример программной расшифровки внешнего отчета другим вариантом этого же отчета средствами БСП.

Изначально нужно было вывести совсем простенький отчет по статистике заказов клиентов по разным параметрам. Отчет подключен как дополнительный, имеет вот такой вид:

 

 

Для раскрашивания блоков нарисовал соответствующий простенький макет:

 

 

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

Первый вариант решения, который решил попробовать - использовать функцию ВычислитьВыражениеСГруппировкойМассив, чтобы собрать массивы нужных документов в вычисляемые поля и эти вычисляемые поля запихнуть в параметры расшифровки соответствующих полей макета. Например:

Свернуть(Массив(ВЫБОР КОГДА ОтмененныхЗаказов > 0 ТОГДА ЗаказКлиента ИНАЧЕ ЗНАЧЕНИЕ(Документ.ЗаказКлиента.ПустаяСсылка) КОНЕЦ))

Такой массив в группировке детальных записей выводилось без проблем, а вот в качестве параметра расшифровки передать не получалось: просто-напросто в программной обработке этого параметра не было.

Идею с параметрами расшифровки решил не оставлять, но совместить её с расшифровкой другим вариантом этого же отчета. У внешнего отчета назначена общая форма из БСП ФормаОтчета в качестве основной, поэтому потребуется вклиниться в обработку расшифровки этой формы:

 

 

Видим, здесь идет вызов переопределяемой процедуры ОтчетыКлиентПереопределяемый.ОбработкаРасшифровки - заимствуем ее в расширение с директивой &После

&После("ОбработкаРасшифровки")
Процедура рзн_ОбработкаРасшифровки(ЭтаФорма, Элемент, Расшифровка, СтандартнаяОбработка)
	
	ПолноеИмяОтчета = ЭтаФорма.НастройкиОтчета.ПолноеИмя;
	КлючТекущегоВарианта = ЭтаФорма.КлючТекущегоВарианта;
	
	Если ПолноеИмяОтчета = "ВнешнийОтчет.sfxОтчетПоKPI" Тогда
		
		СтруктураРасшифровки = ОтчетыУТВызовСервераПереопределяемый.СформироватьДанныеРасшифровки(Расшифровка, ЭтаФорма.ОтчетДанныеРасшифровки);
		рзн_РасшифроватьОтчетПоKPI(ЭтаФорма, СтруктураРасшифровки, СтандартнаяОбработка)
		
	КонецЕсли;
	
КонецПроцедуры

Здесь сразу оговоримся, что работа ведется в конфигурации "1С:Комплексная автоматизация 2.5", поэтому для получения данных расшифровки используется функция ОтчетыУТВызовСервераПереопределяемый.СформироватьДанныеРасшифровки. Структуру расшифровки вы можете самостоятельно программно сформировать, по этому вопросу есть много статейю

Теперь нужно подумать непосредственно о том, какие параметры расшифровки нужно использовать. Для подсчета количества документов у меня используются в запросе числовые поля для каждого из типа заказов. Например, для подсчета всех заказов используется поле КоличествоЗаказов, которое всегда заполняется цифрой 1. Для подсчета отмененных заказов используется поле ОтмененныхЗаказов: если заказ отменен, то в поле будет 1, иначе - 0. Такие поля будем использовать для отбора в варианте отчета, который добавим для расшифровки.

В общем виде для всех параметров расшифровки используем поле РасшифровкаЗаказов = Истина, чтобы понимать, что для расшифровки будем использовать открытие этого отчета с другим ключом варианта. Второй параметр будет определять признак колонки: отмененные заказы, все заказы, предоплаченные заказы и т.д. В итоге параметр расшифровки будет иметь следующий вид:

 

 

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

Теперь нам осталось проверить параметры расшифровки и открыть другой вариант отчета с нужными отборами.

 
 Листинг кода

 

Если есть более простой или альтернативные способы - рад увидеть их в комментариях!

Расшифровка отчет БСП внешний макет другой

См. также

БСП (Библиотека стандартных подсистем) Программист Платные (руб)

Синтакс-помощник БСП - cправочник по библиотекам стандартных подсистем и электронных документов. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП и БЭД.

1800 руб.

21.11.2024    4296    17    15    

20

Работа с интерфейсом Системный администратор Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Платные (руб)

Механизм «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

5000 руб.

14.01.2016    55610    17    23    

43

Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    19925    28    6    

44

Работа с интерфейсом Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Это инструкция по дизайну форм в среде 1С. Гайд охватывает рекомендации и стандарты для оптимизации пользовательского интерфейса. В гайде содержатся указания по использованию элементов интерфейса, включая как основные, так и продвинутые аспекты. Предоставляются также примеры и антипримеры для наглядного понимания принципов дизайна

20.08.2024    23378    mrXoxot    44    

130

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    18332    1228    elcoan    53    

125

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    12865    167    acces969    31    

126

Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    7928    kalyaka    6    

33
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. rozer 313 21.12.24 18:15 Сейчас в теме
Ну раз у вас БСП то параметры проще получать можно

Настройки = КомпоновщикНастроек.ПолучитьНастройки();
КомпоновкаДанныхКлиентСервер.ПолучитьПараметр(Настройки, "СуперПуперПараметр");
RocKeR_13; +1 Ответить
Оставьте свое сообщение