РеСольДо. Действие 1: Динамическое отражение структуры и значений табличных частей документа

17.05.24

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

Данная публикация является первой в цикле публикаций, посвящённых используемых технологий в решении РеСольДо. Основная цель публикаций - поделиться используемыми технологиями с читателями, которые смогут воспользоваться представленными материалами для решения своих практических задач. Задача №1: Динамическое отражение структуры и значений табличных частей документа на форме.

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

Наименование Файл Версия Размер
Обработка для динамического отражения структуры и значений табличных частей документа 'Авансовый отчет'
.epf 7,40Kb
0
.epf 1.0 7,40Kb Скачать

Данная публикация является первой в цикле публикаций, посвящённых используемых технологий в решении РеСольДо. Основная цель публикаций поделиться используемыми технологиями с читателями, которые смогут воспользоваться представленными материалами для решения своих практических задач. Каждая публикация будет посвящена описанию отдельной задачи с приведением описания её решения. Автор не претендует на новаторство – большинство (если не все) из предложенных технологий ранее уже были представлены публике.


Задача №1: Динамическое отражение структуры и значений табличных частей документа на форме

Первой решаемой задачей будет динамическое отражение структуры и значений всех табличных частей выбранного документа. Для экспериментов возьмём документ ‘Авансовый отчет’, который представлен в большинстве учётных решений 1С. Также его наименование в разных конфигурациях 1С не отличается (в отличие от документов поступлений/реализаций, наименование которых отличается в 1С:Бухгалтерия, 1С:УНФ и 1С:ERP).

 

Решение задачи №1

Для начала создадим внешнюю обработку с единственным реквизитом ‘АвансовыйОтчет’ с соответствующим типом.

 

 

Затем создадим форму и вынесем реквизит ‘АвансовыйОтчет’ на неё. Также активируем ‘КнопкуВыбора’.

 

 

Создадим два события. Сначала ‘ПриСозданииНаСервере’.

 

 

Для события напишем код, который при создании формы на сервере будет программно создавать элемент формы ‘Страницы’.

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

Теперь создадим второе событие ‘АвансовыйОтчетПриИзменении’, которое будет инициализироваться при изменении (выборе) документа ‘Авансовый отчет’.

 

 

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

&НаКлиенте
Процедура АвансовыйОтчетПриИзменении(Элемент)
	
	СоздатьСтраницыСТЧДокументаНаФорме();
	
КонецПроцедуры

Создадим процедуру ‘СоздатьСтраницыСТЧДокументаНаФорме’ со следующим кодом:

&НаСервере
Процедура СоздатьСтраницыСТЧДокументаНаФорме() Экспорт	
	
	ВидРасходногоДокумента = "АвансовыйОтчет";
	МассивДобавленныхЭлементов = Новый Массив;
	ТабличныеЧасти = Метаданные.Документы[ВидРасходногоДокумента].ТабличныеЧасти;   	
	
	ПерваяЗаполненнаяСтраница = "";
	
	// добавим страницу с ТЧ документа
	Для Каждого ТекСтрока Из ТабличныеЧасти Цикл 
		
		КоличествоСтрокВТЧ = Объект[ВидРасходногоДокумента][ТекСтрока.Имя].Количество();
		ЕстьДанныеВТекТЧ = Объект[ВидРасходногоДокумента][ТекСтрока.Имя].Количество() > 0;
		
		ТекТЧДокумента = Объект[ВидРасходногоДокумента][ТекСтрока.Имя];
		
		РеквизитыТабличнойЧасти = ТабличныеЧасти[ТекСтрока.Имя].Реквизиты;
		// эти страницы надо добавить
		НазваниеЭлементаДляДобавления = "Страница" + ТекСтрока.Имя;
		ТакойЭлементУжеЕсть = ОбщегоНазначенияКлиентСервер.ЕстьРеквизитИлиСвойствоОбъекта(ЭтаФорма.Элементы, НазваниеЭлементаДляДобавления);
		Если ТакойЭлементУжеЕсть Тогда
			// страница была создана ранее
		Иначе
			СтраницаНастройкаТЧ = ЭтаФорма.Элементы.Добавить(НазваниеЭлементаДляДобавления,Тип("ГруппаФормы"), ЭтаФорма.Элементы.СтраницаСДТЧ);
			СтраницаНастройкаТЧ.Вид = ВидГруппыФормы.Страница;			
		КонецЕсли;
		
		ЭтаФорма.Элементы[НазваниеЭлементаДляДобавления].Заголовок = ТекСтрока.Синоним + " ("+ КоличествоСтрокВТЧ + ")";		
		
		// сохраним название первой заполненной страницы
		Если Не ЗначениеЗаполнено(ПерваяЗаполненнаяСтраница) и КоличествоСтрокВТЧ > 0 Тогда
			ПерваяЗаполненнаяСтраница = НазваниеЭлементаДляДобавления;
		КонецЕсли;
		
		ТЧДляСоздания = "ДТЧ" + ТекСтрока.Имя;
		ТакойЭлементУжеЕсть = ОбщегоНазначенияКлиентСервер.ЕстьРеквизитИлиСвойствоОбъекта(ЭтаФорма, ТЧДляСоздания);
		Если ТакойЭлементУжеЕсть Тогда
			// страница была создана ранее
		Иначе
			нРеквизиты = Новый Массив;
			нРеквизиты.Добавить(Новый РеквизитФормы(ТЧДляСоздания, Новый ОписаниеТипов("ТаблицаЗначений"),, ТекСтрока.Синоним));
			ЭтаФорма.ИзменитьРеквизиты(нРеквизиты);
			
			РеСольДоЭлемент = ЭтаФорма.Элементы.Добавить(ТЧДляСоздания, Тип("ТаблицаФормы"), СтраницаНастройкаТЧ); 
			РеСольДоЭлемент.ПутьКДанным = ТЧДляСоздания; 
			РеСольДоЭлемент.КоманднаяПанель.Видимость = Ложь;
			
			// создаем элементы табличной части
			нРеквизиты = Новый Массив;
			
			нРеквизиты.Добавить(Новый РеквизитФормы("Выбрана", Новый ОписаниеТипов("Булево"), ТЧДляСоздания, "Выбрана"));				
			
			Для Каждого ТекРеквизитТЧ ИЗ РеквизитыТабличнойЧасти Цикл
				нРеквизиты.Добавить(Новый РеквизитФормы(ТекРеквизитТЧ.Имя, Новый ОписаниеТипов(ТекРеквизитТЧ.Тип), ТЧДляСоздания, ТекРеквизитТЧ.Синоним));
			КонецЦикла;
			
			ЭтаФорма.ИзменитьРеквизиты(нРеквизиты);  
			
			// описываем элементы
			// создаем для всех ТЧ поле выбора строк
			РеСольДоЭлемент = ЭтаФорма.Элементы.Добавить(ТЧДляСоздания + "Выбрана", Тип("ПолеФормы"), ЭтаФорма.Элементы[ТЧДляСоздания]); 
			РеСольДоЭлемент.Вид = ВидПоляФормы.ПолеФлажка; 
			РеСольДоЭлемент.ПутьКДанным = ТЧДляСоздания + ".Выбрана"; 
			
			РеСольДоЭлемент.Видимость = Истина;
			
			Для Каждого ТекРеквизитТЧ ИЗ РеквизитыТабличнойЧасти Цикл
				РеСольДоЭлемент = ЭтаФорма.Элементы.Добавить(ТЧДляСоздания + ТекРеквизитТЧ.Имя, Тип("ПолеФормы"), ЭтаФорма.Элементы[ТЧДляСоздания]); 
				// поле ввода
				РеСольДоЭлемент.Вид = ВидПоляФормы.ПолеВвода; 
				РеСольДоЭлемент.ПутьКДанным = ТЧДляСоздания + "." + ТекРеквизитТЧ.Имя; 
			КонецЦикла;
			
		КонецЕсли;
				
		ЭтаФорма[ТЧДляСоздания].Загрузить(ТекТЧДокумента.Выгрузить());
		
	КонецЦикла;
	
	Если ЗначениеЗаполнено(ПерваяЗаполненнаяСтраница) Тогда
		// сделаем активной первую заполненную страницу
		Элементы.СтраницаСДТЧ.ТекущаяСтраница = ЭтаФорма.Элементы[ПерваяЗаполненнаяСтраница];
	КонецЕсли;
	
КонецПроцедуры

После этого сохраним обработку, откроем её в режиме ‘Предприятие’ и после выбора документа ‘Авансовый отчет’ должны отразиться табличные части документа.

 

 

Особенность предложенного решения заключается в следующем:

- табличные части и их реквизиты создаются на форме программно;

- каждая новая табличная часть создаётся как отдельная страница на форме;

- программно создаётся столбец ‘Выбрана’ с типом Булево;

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

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

Разработка и тестирование обработки осуществлялись на типовой конфигурации «1С:Бухгалтерия предприятия, редакция 3.0 (3 3.0.152.23)» и платформе 1С:Предприятие 8.3 (8.3.22.2239). Работать данная обработка должна практически на любой типовой управляемой конфигурации 1С, содержащий документ ‘Авансовый отчет’.

Структура табличных частей документа динамический интерфейс

См. также

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 руб.

02.09.2020    131938    721    390    

763

Infostart PrintWizard - создание и редактирование печатных форм в 1С 8.3

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

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

18000 руб.

06.10.2023    9625    28    6    

51

Infostart УДиФ: Управление данными и формами 1С

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

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

10000 руб.

10.11.2023    5673    16    2    

39

PowerTools

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

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

3600 руб.

14.01.2013    180209    1097    0    

871

OneDebugger - инструмент для отладки кода без использования режима конфигуратора

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

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

5400 руб.

17.05.2024    6701    15    12    

42

Бустер Конвертации данных 3 (Infostart Toolkit)

Инструментарий разработчика Программист 8.3.14 1С:Конвертация данных Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

15000 руб.

07.10.2021    15500    3    12    

38

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    100433    240    97    

299

[ЕХТ] Фреймворк для Расширений 1С

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

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    18957    7    8    

42
Оставьте свое сообщение