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

19.12.24

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

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

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

 

 

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

 

 

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

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

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

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

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

 

 

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

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

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

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

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

 

 

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

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

 
 Листинг кода

 

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

Синтакс-помощник БСП

Решение «Синтакс-помощник БСП» помогает разработчикам быстро находить нужные методы, модули и примеры реализации в рамках Библиотеки стандартных подсистем (БСП). Полезен как новичкам, так и опытным специалистам — ускоряет разработку и повышает качество кода благодаря готовым шаблонам и примерам решений.

Вступайте в нашу телеграмм-группу Инфостарт

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

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

31720 руб.

27.03.2025    85199    60    42    

72

Адаптация типовых решений БСП (Библиотека стандартных подсистем) Кадровый учет ЭДО и ОФД 1C:Бухгалтерия 1С:Зарплата и кадры 7.7 1C:ERP 1С:ЗУП 1С:УТ 1С:ДО Платные (руб)

Наше расширение 1С Госключ обеспечивает интеграцию любой конфигурации 1С на базе БСП с мобильным приложением «Госключ», позволяя сотрудникам подписывать кадровые документы (КЭДО) и документы материальной ответственности (МОЛ, ПБ) усиленной электронной подписью прямо со смартфона. Решение автоматизирует формирование и отправку документов на подпись, отслеживает статусы подписания и хранит подписанные файлы непосредственно в базе 1С

25000 руб.

06.03.2026    896    1    0    

3

Работа с интерфейсом Рабочее место 1С:Предприятие 8 1C:Бухгалтерия 1С:Комплексная автоматизация 2.х Платные (руб)

Универсальный редактор картинок 1С предназначен для обработки изображений в режиме «Предприятие», с возможностью рисовать на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). В комплект поставки включены Расширения для легкого подключения данного функционала в БК, УТ, КА и ERP. Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Обработка будет особенно полезна тем, кто вносит картинки в базу. Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6100 руб.

16.01.2015    68727    46    60    

85

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

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

5246 руб.

29.06.2020    25061    34    6    

53

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

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

3254 руб.

21.11.2024    13254    47    26    

54

Консолидация данных Работа с интерфейсом Программист Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 1C:ERP Узбекистан Беларусь Кыргызстан Россия Казахстан Платные (руб)

Знакомая ситуация? Пользователи, особенно менеджеры, уверены: отборов много не бывает. Идут пожелания добавить в форму списка еще один быстрый фильтр, еще два, еще пять... В итоге интерфейс превращается в нагромождение полей отбора, а потребность в «самом главном» отборе, который «вот прямо сейчас нужен», все равно не закрыта. Универсальное расширение, которое решает эту проблему элегантно и технологично. С его помощью в любую форму списка можно легко добавить панель настраиваемых кнопок-закладок, каждая из которых применяет сложный фильтр-запрос, а так же показывает актуальное количество элементов в реальном времени.

6088 руб.

17.10.2025    2351    3    0    

2

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36600 руб.

28.08.2025    8335    2    2    

6

Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

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

20.08.2024    50803    mrXoxot    44    

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

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