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

12.07.20

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

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Настройка колонок для вывода в отчет:
.erf 12,01Kb
4
4 Скачать (1 SM) Купить за 1 850 руб.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

 

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

 

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

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

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

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

Отчеты

См. также

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

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

5000 руб.

14.01.2016    55640    17    23    

43

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

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

6000 руб.

16.01.2015    63952    45    60    

83

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

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

2400 руб.

29.06.2020    19949    28    6    

44

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

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

20.08.2024    23558    mrXoxot    44    

130

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

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    12075    smielka    37    

105

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

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

27.12.2023    18375    1228    elcoan    53    

125

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

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

3 стартмани

10.04.2023    12900    167    acces969    31    

126

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

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

1 стартмани

05.07.2022    8016    kalyaka    6    

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

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


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