Отбор регистраторов для отчетов

23.07.22

Разработка - Инструментарий разработчика

Универсальная встраиваемая обработка для выбора регистраторов в отчетах.

Файлы

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

Наименование Скачано Купить файл
Обработка отбора регистраторов для отчетов
.epf 9,82Kb ver: 2.1.06.21
1 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

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

Оформить подписку и скачать решение со скидкой

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

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

1) Разместить на форме отчёта кнопку для вызова формы выбора регистраторов, наподобие того, как это сделано на фото в данной публикации. 

2) В модуле формы или объекта отчёта задайте глобальную переменную для хранения массива регистраторов:

Перем МассивРегистраторов;


3) В обработчике нажатия кнопки реализовать код, аналогичный этому: 

// Формируем список регистров для отбора регистраторов
СписокРегистров = Новый СписокЗначений;
СписокРегистров.Добавить("РегистрыСведений.ИмяРегистра", "ИмяРегистра");

НастройкаОтбораРегистраторов = Обработки.НастройкаОтбораРегистраторов.Создать();

// Уникальное имя под которым будут храниться настройки регистраторов для данного отчета
НастройкаОтбораРегистраторов.УникальноеИмяНастройки = "ИмяОтчета_Регистраторы"; 	

// Список регистров по которым нужно отобрать регистраторы для отчета
НастройкаОтбораРегистраторов.СписокИменРегистров 	= СписокРегистров; 							

ФормаНастроекРегистров = НастройкаОтбораРегистраторов.ПолучитьФорму("Форма");

Результат = ФормаНастроекРегистров.ОткрытьМодально();

Если Результат <> Неопределено Тогда 
	МассивРегистраторов = Результат;		
КонецЕсли;

Как видно, в первых строках кода мы формируем список значений с именами регистров, по которым будут отбираться регистраторы.

Также не поленитесь задать УникальноеИмяНастройки, если механизм будет использоваться в нескольких отчётах, чтобы настройки разных отчётов не перетирали друг друга. Имя может быть любым, но я для себя выработал удобную комбинацию из имени отчёта и названия механизма. 

4) В обработчике события ПриОткрытии() добавьте блок кода отвечающий за подгрузку ранее установленных настроек регистраторов для отчета:

МассивТиповРегистраторов = РегистрыСведений.ИмяРегистра.СоздатьНаборЗаписей().Отбор.Регистратор.ТипЗначения.Типы();

МассивРегистраторов = Новый Массив;	

Для Каждого ТипРегистратора Из МассивТиповРегистраторов Цикл 

	Для Каждого МетаданныеДокумента Из Метаданные.Документы Цикл 
		Если Тип("ДокументСсылка." + МетаданныеДокумента.Имя) = ТипРегистратора Тогда  	
			МассивРегистраторов.Добавить(ТипРегистратора);
			Прервать;
		КонецЕсли;			
	КонецЦикла;
	
КонецЦикла;

СтруктураНастроек = ВосстановитьЗначение("ИмяОтчета_Регистраторы");

Если СтруктураНастроек <> Неопределено 
	И ТипЗнч(СтруктураНастроек) = Тип("Структура") Тогда 
	
	Для Каждого элСтруктуры Из СтруктураНастроек Цикл
		
		ИндексРегистратора = МассивРегистраторов.Найти(Тип("ДокументСсылка." + элСтруктуры.Ключ));
		
		Если ИндексРегистратора <> Неопределено И НЕ элСтруктуры.Значение Тогда 				
			МассивРегистраторов.Удалить(ИндексРегистратора);				
		КонецЕсли;
		
	КонецЦикла;
	
КонецЕсли;

 

5) Ну и вишенкой на торте - передайте сформированный массив регистраторов в параметры запроса:

Запрос.УстановитьПараметр("ТипыРегистраторов", МассивРегистраторов);


Тестировалось на версиях платформ: 8.3.10.2650, 8.3.17.1549, но ввиду его универсальности никаких ограничений по платформам и конфигурациям на обычных формах не вижу.

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

обработка отчёт отбор регистраторы интерфейс универсальный форма разработка

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    213062    1165    413    

1049

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    40554    222    115    

211

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

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

16000 руб.

10.11.2023    18804    76    39    

92

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    26546    67    30    

96

Инструментарий разработчика Программист 1С v8.3 Платные (руб)

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

9500 руб.

17.05.2024    37641    134    55    

176

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше.<br/> Далее в публикации:<br/> MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    4006    8    10    

14

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    3681    7    0    

12
Для отправки сообщения требуется регистрация/авторизация