Программная установка отборов в типовых отчетах

05.03.24

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

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

Скачать исходный код

Наименование Файл Версия Размер
Программная установка отборов в типовых отчетах:
.zip 10,60Kb
6
.zip 10,60Kb 6 Скачать

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

Общая последовательность действий при установке отборов представлена на схеме:

 

 

На схеме красным цветом представлен сторонний объект, вызывающий отчет. Это может быть документ, обработка и т.д. Синим цветом - вызываемый отчет и его модуль. Процедуры и функции этого модуля вызываются при выводе отчета в общей форме. Зелёным цветом - общая форма "ФормаОтчета".

Рассмотрим последовательность выполняемых процедур для установки отбора в отчёте:

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

2. Открывается форма отчета с передачей параметров. Поскольку у отчета нет своей формы, то открывается общая форма "ФормаОтчета" и все параметры передаются в эту общую форму.

3. Перед тем, как открыться, в форме отчета срабатывают несколько процедур. В первую очередь это процедура ПриСозданииНаСервере(), в которой выполняются следующие действия:

  • СохранитьПараметрыФормы() - процедура вызывает общий модуль ВариантыОтчетов и его процедура СохраняемыеПараметрыФормыОтчета(Параметры). Параметры, пришедшие в форму сохраняются в реквизит формы "ФормаПараметры" для того чтобы их можно было использовать не только при создании формы на сервере, но и в других процедурах и функциях.
  • НастройкиОтчета = НастройкиОтчета(ОтчетОбъект) - в форму отчета получают все настройки из ОтчетОбъект (основной реквизит формы - сам вызываемый отчет), а так же заполняются настройки, необходимые для выполнения дальнейших алгоритмов формирования отчета. Настройки из ОтчетОбъект получают обращением к процедуре в модуле отчета ОпределитьНастройкиФормы(...). Одной из ключевых настроек для программной установки отбора является возможность вызова процедуры модуля отчета "ПриСозданииНаСервере" 
Настройки.События.ПриСозданииНаСервере = Истина;
  • Вызов процедуры ОпределитьНастройкиФормы() происходит внутри конструкции ПОПЫТКА ... ИСКЛЮЧЕНИЕ...КОНЕЦПОПЫТКИ так как в отчёте подобная процедура может и не использоваться. В случае, если этой функции в отчете нет, то происходит исключение, внутри которого проверятся не является ли отчет внешним и если является, то настройки заполняются типовыми значениями.
  • В том случае если в настройках в структуре "События" установлено, что должна использоваться процедура ПриСозданииНаСервере() выполняемого отчета, то данная процедура выполняется.
Если НастройкиОтчета.События.ПриСозданииНаСервере Тогда
	ОтчетОбъект.ПриСозданииНаСервере(ЭтотОбъект, Отказ, СтандартнаяОбработка);
КонецЕсли;

4. В процедуре ПриСозданииНаСервере() модуля отчета проверяется есть ли у формы параметр "ПараметрКоманды" и по имени команды определяется как должен использоваться данный параметр - в реквизит формы "ФормаПараметры" в свойство "Отбор" вставляется указание по какому полю устанавливать отбор и порядок отбора, указанный ранее в "ПараметрКоманды" - вид сравнения и значение сравнения.

5. Опуская выполнение процедуры формы ПередЗагрузкойВариантаНаСервере() переходим к процедуре ПриЗагрузкеВариантаНаСервере(). В данной процедуре вызывается общий модуль "ОтчетыСервер", в процедуре УстановитьФиксированныеОтборы(...) и используется реквизит формы "ФормаПараметры"

ОтчетыСервер.УстановитьФиксированныеОтборы(ФормаПараметры.Отбор, Отчет.КомпоновщикНастроек.Настройки,
			НастройкиОтчета);

В теле этой процедуры вызывается следующий общий модуль где и анализируется необходимость и создание элемента отбора.

ОбщегоНазначенияКлиентСервер.УстановитьЭлементОтбора(ОтборыКД, Имя, Значение, ВидСравненияКД, Представление, Истина, РежимОтображения, Идентификатор);

На этом работу с программной установкой отборов можно считать завершённой.

Учитывая вышеизложенное, хотелось бы привести два примера. Первый продемонстрирует работу с отчетом, в модуле которого уже есть процедура "ПриСозданииНаСервере" и данная процедура заявлена в параметрах как используемая. Второй пример позволит обозначить системе что данная процедура будет использоваться, хотя ранее её применение не подразумевалось.

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

Пример 1. Буду использовать типовой отчет "ТоварыНаСкладахПоСрокамГодности". В модуле отчета уже указано, что процедура "ПриСозданииНаСервере" должна использоваться. В этой процедуре прописано, что возможен отбор по Номенклатуре в случае использования одного из вариантов отчета. В расширении пропишем возможность указывать отбор по складу в зависимости от имени команды.
Представляю программный код расширения с внесёнными правками в процедуру с дерективой &Вместо


&Вместо("ПриСозданииНаСервере")
Процедура ИО_ПриСозданииНаСервере(ЭтаФорма, Отказ, СтандартнаяОбработка)
	
	Параметры = ЭтаФорма.Параметры;
	
	Если Параметры.Свойство("ПараметрКоманды") Тогда
		
		Если Параметры.Свойство("ОписаниеКоманды")
			И Параметры.ОписаниеКоманды.Свойство("ДополнительныеПараметры") Тогда
			
			Если Параметры.ОписаниеКоманды.ДополнительныеПараметры.ИмяКоманды = "ОстаткиНоменклатурыПоСрокамГодности" Тогда
				ЭтаФорма.ФормаПараметры.Отбор.Очистить();
				ЭтаФорма.ФормаПараметры.Отбор.Вставить("Номенклатура", Параметры.ПараметрКоманды);
			КонецЕсли;   
			//++ добавим в расширении другой отбор - по складу (потребуется изменить имя команды - его и указать при вызове отчета)
			Если Параметры.ОписаниеКоманды.ДополнительныеПараметры.ИмяКоманды = "КакоеТоДругоеИмяКомандыСогласноСтандартам1С" Тогда
				ЭтаФорма.ФормаПараметры.Отбор.Очистить();
				ЭтаФорма.ФормаПараметры.Отбор.Вставить("Склад", Параметры.ПараметрКоманды);
			КонецЕсли;
			//--
		Иначе
			ЭтаФорма.ФормаПараметры.Отбор.Вставить("ПересчетТоваров", Параметры.ПараметрКоманды);
		КонецЕсли;
		
	КонецЕсли;

КонецПроцедуры

Соответственно процедуры вызова данного отчета с отбором отдельно по номенклатуре и отдельно по складу (процедура СписокТоваровПоАртикулу() составляет список значений номенклатуры по заданному на форме артикулу):

&НаКлиенте
Процедура ПоказатьТоварыНаСкладахПоСрокамГодности(Команда)
	
	СписокНоменклатуры.Очистить();
	
	СписокТоваровПоАртикулу(); 
	
	////визуальная проверка непустого списка для тестирования
	//Для Каждого ТекСтр Из СписокНоменклатуры Цикл
	//	Сообщить(ТекСтр.Значение);
	//КонецЦикла;
	
	ПараметрыФормы = Новый Структура;
	//ПараметрыФормы.Вставить("КлючВарианта", "ПоНоменклатуреКонтекст");  
	ПараметрыФормы.Вставить("КлючВарианта", "ОстаткиТоваровПоСрокамГодности");
	ПараметрыФормы.Вставить("ПараметрКоманды", Новый Структура("ВидСравнения, ПравоеЗначение", ВидСравненияКомпоновкиДанных.ВСписке, СписокНоменклатуры));
	ПараметрыФормы.Вставить("ОписаниеКоманды", Новый Структура("ДополнительныеПараметры", Новый Структура("ИмяКоманды", "ОстаткиНоменклатурыПоСрокамГодности")));
	ПараметрыФормы.Вставить("СформироватьПриОткрытии", Истина);
	ОткрытьФорму("Отчет.ТоварыНаСкладахПоСрокамГодности.Форма", ПараметрыФормы, ЭтаФорма, Истина);

КонецПроцедуры

&НаКлиенте
Процедура ПоказатьТоварыПоСКЛАДУПоСрокамГодности(Команда)
	
	ПараметрыФормы = Новый Структура;
	//ПараметрыФормы.Вставить("КлючВарианта", "ПоНоменклатуреКонтекст");  
	ПараметрыФормы.Вставить("КлючВарианта", "ОстаткиТоваровПоСрокамГодности");
	ПараметрыФормы.Вставить("ПараметрКоманды", Новый Структура("ВидСравнения, ПравоеЗначение", ВидСравненияКомпоновкиДанных.Равно, СкладОстатка));
	ПараметрыФормы.Вставить("ОписаниеКоманды", Новый Структура("ДополнительныеПараметры", Новый Структура("ИмяКоманды", "КакоеТоДругоеИмяКомандыСогласноСтандартам1С")));
	ПараметрыФормы.Вставить("СформироватьПриОткрытии", Истина);
	ОткрытьФорму("Отчет.ТоварыНаСкладахПоСрокамГодности.Форма", ПараметрыФормы, ЭтаФорма, Истина);

КонецПроцедуры

Результат работы обеих процедур обработки и работы БСП:

 

 

Если кого-то удивит, что по артикулу в отбор кроме крупы гречневой попало ещё и молоко, то спешу успокоить: в Демо базе ERP обе номенклатуры проходят под одним артикулом (см.Молоко "Домик в деревне" 4,5%). Так что никакой ошибки нет )))))))))))))))))) оставим это на совести создателей демо-базы.

 

 

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

Программный код, используемый в расширении: 


&Вместо("ОпределитьНастройкиФормы")
Процедура ИО_ОпределитьНастройкиФормы(Форма, КлючВарианта, Настройки)
	// Вставить содержимое метода.
	ПродолжитьВызов(Форма, КлючВарианта, Настройки); 
	Настройки.События.ПриСозданииНаСервере = Истина;
КонецПроцедуры    


Процедура ПриСозданииНаСервере(ЭтаФорма, Отказ, СтандартнаяОбработка) Экспорт
	
	Параметры = ЭтаФорма.Параметры;
	
	Если Параметры.Свойство("ПараметрКоманды") Тогда
		
		Если Параметры.Свойство("ОписаниеКоманды")
			И Параметры.ОписаниеКоманды.Свойство("ДополнительныеПараметры") Тогда
			
			Если Параметры.ОписаниеКоманды.ДополнительныеПараметры.ИмяКоманды = "ВыполнениеСборкиОтгрузкиТоваров" Тогда
				ЭтаФорма.ФормаПараметры.Отбор.Вставить("Склад", Параметры.ПараметрКоманды);
			КонецЕсли;
			Если Параметры.ОписаниеКоманды.ДополнительныеПараметры.ИмяКоманды = "ВыполнениеСборкиОтгрузкиТоваровНоменклатура" Тогда
				ЭтаФорма.ФормаПараметры.Отбор.Вставить("Номенклатура", Параметры.ПараметрКоманды);
			КонецЕсли;
            //Так же можно установить сразу два и более отборов в открываемом отчете
			
		КонецЕсли;
		
	КонецЕсли;
	
КонецПроцедуры

Ещё раз обращаю внимание, что в данном отчете не было процедуры ПриСозданииНаСервере() поэтому в расширении добавлена данная процедура. А в процедуре ИО_ОпределитьНастройкиФормы() указана необходимость использовать данное событие.
В обработке для вызова данного отчета с отбором применяется следующий программный код:

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

&НаКлиенте
Процедура ПоказатьТоварыКОтгрузкеТовар(Команда)
	
	СписокНоменклатуры.Очистить();
	
	СписокТоваровПоАртикулу(); 

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

&НаКлиенте
Процедура ПоказатьТоварыКОтгрузкеСкладТовар(Команда)  
	
     //процедура позволяет сформировать отчет с двумя отборами

КонецПроцедуры

Результат работы программного кода:

 

 

 

 

Помимо вышеописанных вариантов в прилагаемом архиве в расширении и в обработке смоделирована возможность указать сразу два отбора: по номенклатуре и по складу.

На этом завершаю статью. Буду признателен за ценные дополнения.
Расширение и обработка тестировались на платформе 1С:Предприятие 8.3.23.1865, в конфигурации 1С:ERP Управление предприятием 2 (2.5.14.74) ДЕМО. 

БСП ФормаОтчета Отборы

См. также

Богатый редактор картинок, хранимых в базе, с возможностью РИСОВАНИЯ. Редактор внешних файлов картинок. Объект, расширяющий возможности работы с картинками из встроенного языка (Три в одном) + Обработка «Стандартизация картинок»

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

6000 руб.

16.01.2015    62093    43    59    

81

[Расширения] Динамическое управление видимостью и доступностью элементов форм (УФ) (8.3.6+)

Работа с интерфейсом Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

5000 руб.

14.01.2016    54696    16    21    

42

Управление дашбордами

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

2400 руб.

29.06.2020    16906    22    4    

36

Новогоднее оформление для 1С

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

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

27.12.2023    11163    761    elcoan    45    

106

Конструктор HTML, CSS и javascript

Инструментарий разработчика Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

10.04.2023    9889    153    acces969    31    

119

Модель состояния для MVC

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

1 стартмани

05.07.2022    3941    kalyaka    4    

29

Табло очереди заказов на экран телевизора

WEB-интеграция Работа с интерфейсом Платформа 1С v8.3 1С:Розница 2 Платные (руб)

Связка из веб-приложения и расширения для 1С: Розница 2.3.

3600 руб.

29.04.2022    12294    1    5    

10

Условное оформление элементов форм в пользовательском режиме 1С (управление видимостью и доступностью элементов форм)

Работа с интерфейсом Платформа 1С v8.3 Платные (руб)

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

6000 руб.

18.01.2022    8953    1    2    

6
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. anosin 29 06.03.24 20:22 Сейчас в теме
а можно блоксхему да и копии экранов както побольше масштабом?
miandrew; +1 Ответить
2. KawaNoNeko 110 07.03.24 11:30 Сейчас в теме
(1) копии экранов вряд ли, а по блок-схеме правой кнопкой мыши и открыть в новом окне. Там будет большая картинка.
3. EugeneerS 10.03.24 02:17 Сейчас в теме
Программные отборы при открытии реализованы штатно почти во всех типовых. Достаточно увидеть как в карточке товара открывается множество типовых отчетов с отбором и так далее.Там это все готовое.

Я буквально на днях решал совсем другую задача. Это любые отборы и параметры (как например период) для создания типовых отчетов БЕЗ открытия. А получением самого результата (табличного документа) для его размещения в других формах.
В принципе все это реализовал. Достаточно не сложно. Специалисты средней руки это все очень быстро реализуют если им надо будет.
4. KawaNoNeko 110 11.03.24 09:32 Сейчас в теме
(3) А я так и написал в статье. Только более развёрнуто. Да и вообще в 1С по-русски программируют: взял да и прочитал без переводчика и сразу всё понял и начал разбираться.
Но если Вы опишите Ваше решение то будет тоже хорошо.
5. VinnieThePOOH 147 21.03.24 07:24 Сейчас в теме
(4) Вот так, например, я делаю формирование типового отчета с программной установкой отбора по организации

	Таб = Новый ТабличныйДокумент;
	Таб.АвтоМасштаб = Истина;
	
	ОтчетШР = Отчеты.ШтатноеРасписаниеНачисления.Создать();
	ОтчетШР.КомпоновщикНастроек.ЗагрузитьНастройки(ОтчетШР.СхемаКомпоновкиДанных.ВариантыНастроек.Т3.Настройки);
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("КлючВарианта", "Т3");
		
	Сведения = СведенияОбОтветственныхЛицах.СведенияОбОтветственныхЛицах(РеквизитыСобытия.Организация, "ГлавныйБухгалтер,РуководительКадровойСлужбы,ДолжностьРуководителяКадровойСлужбы", ДатаДляПечати);
	
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("НомерДокумента", "");
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("ДатаДокумента", "");
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("ДатаАктуальности", ДатаДляПечати);
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("ГлавныйБухгалтер", Сведения.ГлавныйБухгалтер);
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("РуководительКадровойСлужбы", Сведения.РуководительКадровойСлужбы);
	ОтчетШР.КомпоновщикНастроек.ПользовательскиеНастройки.ДополнительныеСвойства.Вставить("ДолжностьРуководителяКадровойСлужбы", Сведения.ДолжностьРуководителяКадровойСлужбы);
		
	Настройки = ОтчетШР.КомпоновщикНастроек.Настройки;
		
	Отбор = Настройки.Отбор;
	Отбор.Элементы.Очистить();
	ОбщегоНазначенияКлиентСервер.ДобавитьЭлементКомпоновки(Отбор, "Организация", ВидСравненияКомпоновкиДанных.Равно, РеквизитыСобытия.Организация);
		
	ОтчетШР.СкомпоноватьРезультат(Таб);
	
	Таб.АвтоМасштаб = Истина;
	Таб.ОриентацияСтраницы = ОриентацияСтраницы.Ландшафт;

Показать
МимохожийОднако; +1 Ответить
6. МимохожийОднако 141 21.03.24 08:36 Сейчас в теме
(5) Можешь привести пример, чтобы отбирать не по организации, а по некоторому списку подразделений? Возможен ли универсальный подход, чтобы сделать отбор не для одного отчета, а для некоторой группы?
Оставьте свое сообщение