Настройка колонок для вывода в отчет

12.07.20

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

Иногда возникает задача вывести в отчет по запросу не все колонки, а только определенные.

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

Наименование Файл Версия Размер
Настройка колонок для вывода в отчет:
.erf 12,01Kb
4
.erf 12,01Kb 4 Скачать

Есть рабочий отчет. Отчет сильно "навороченый". В запросе связываются множество таблиц, объектов. В отчете множество колонок, расчет значений которых настраивется при помощи элементов управления на форме.

Отчет нужный. Позволяет просмотреть ситуацию в различных разрезах.

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

Или, например, нужно ограничить вывод в зависимости от роли пользователя.

Да, конечно, при помощи СКД эта задача решается элементарно. На первый взгляд...

Но, с учетом множества настроек, не так просто программно заставить СКД выводить то, что нужно, и туда, куда нужно.

Есть готовый  рабочий отчет. Есть готовый запрос. Макет вывода -- нарисован и настроен...

И у меня есть пара простых функций, которые позволяют решить эту задачу за считанные минуты.

Что нужно сделать.

1. На форму добавить либо список, либо таблицу с перечнем выводимых колонок, в которой пользователь может отмечать, что и в какой последовательности ему нужно вывести (или как-то определить список программно);

2. В макете все эти колонки (вертикальные области)  назвать соответствующим образом;

3. Добавить в модуль формы 3 процедуры (см. далее);

4. В коде, перед выводом результата, вызовы типа "ОбластьЗаголовок = Макет.ПолучитьОбласть("Заголовок");" заменить на "ОбластьЗаголовок = Макеты.Заголовок".

Вот, собственно, и все.

Для демонстрации вложил совершенно абстрактный отчет с совершенно абстрактными данными.

 

 

А вот необходимые процедуры:

 

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

Процедура ДобавитьКолонкуКШаблону(Макет, Макеты, ИмяКолонки)
	Для каждого Ш Из Макеты Цикл
		Если Ш.Значение = Неопределено Тогда
			Шаблон = Новый ТабличныйДокумент;
		Иначе
			Шаблон = Ш.Значение;
		КонецЕсли; 
		
		Источник = Макет.ПолучитьОбласть(Ш.Ключ + "|" + ИмяКолонки);
		ПрисоединитьКМакету(Шаблон, Источник);
		
		Макеты.Вставить(Ш.Ключ, Шаблон);
	КонецЦикла; 
КонецПроцедуры

Процедура ПрисоединитьКМакету(Получатель, Источник)
	кП = Получатель.ШиринаТаблицы;
	Получатель.Присоединить(Источник);
	
	Для с=1 По Источник.ВысотаТаблицы Цикл
	Для к=1 По Источник.ШиринаТаблицы Цикл
		ячИ = Источник.Область	(с, к);
		ячП = Получатель.Область(с, кП+к);
		ячП.Заполнение 	= ячИ.Заполнение;
		ячП.Расшифровка = ячИ.Расшифровка;
		ячП.ПараметрРасшифровки = ячИ.ПараметрРасшифровки;
		Если ячИ.Заполнение = ТипЗаполненияОбластиТабличногоДокумента.Параметр Тогда
			ячП.Параметр = ячИ.Параметр;
		ИначеЕсли ячИ.Заполнение = ТипЗаполненияОбластиТабличногоДокумента.Шаблон Тогда
			ячП.Текст = ячИ.Текст;
		КонецЕсли; 
	КонецЦикла; 
	КонецЦикла; 
КонецПроцедуры

(Отчет протестирован не версии платформы 1С:Предприятие 8.3 (8.3.6.2530))

Отчеты

См. также

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

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

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

2400 руб.

29.06.2020    17087    23    4    

37

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

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

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

27.12.2023    11529    769    elcoan    46    

107

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

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

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

2 стартмани

10.04.2023    10110    156    acces969    31    

119

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

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

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

1 стартмани

05.07.2022    4111    kalyaka    4    

31

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

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

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

3600 руб.

29.04.2022    12476    1    6    

11

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

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

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

6000 руб.

18.01.2022    9057    1    2    

6

Программный интерфейс для доработки форм

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

Реализовал простой способ программного создания новых элементов, команд и реквизитов на форме.

25.11.2021    9884    AtamanovYS    19    

139
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Rain_man 21.07.20 14:13 Сейчас в теме
А если отчёт "таблица" (строки, колонки) и используются макеты, которые "макет ресурсов", причём, разные макеты ресурсов - свой для каждого уровня группировки?
2. user847462 14 07.08.20 14:06 Сейчас в теме
"Макет ресурсов" -- это из СКД. Статья как раз о том, как решить задачу без помощи СКД для обычного отчета.
В обычном макете можете конструировать/определять формат вывода любых уровней группировок. Речь идет только о выборе необходимых колонок и их порядке в отчете.

Горизонтальные области перечисляются в конструкции:
	// Перечень горизонтальных областей макета, используемых для вывода группировок и данных
	Макеты = Новый Структура("Заголовок,ШапкаТаблицы,ОбщиеИтоги,Период,Исполнитель,Детали"); 


Далее добавляете нужные колонки:
	ДобавитьКолонкуКШаблону(Макет, Макеты, "ИмяВертикальнойОбласти");
Оставьте свое сообщение