Отладка обработки по заполнению табличной части в конфигурации под замком. 1С 8.3

05.06.23

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

Применяется в типовых конфигурациях 1С 8.3, в которых запрещены изменения конфигурации. Тестировалось на ЗУП 3.1 КОРП платформа 8.3.20, режим совместимости конфигурации 8.3.17.

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

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

Для доработки надо:

  • Добавить 2 реквизита формы: ВидОбработки (тип строка) и Назначение (тип Список значений с типом Строка)
     
  • Добавить следующий код в процедуры модуля формы обработки:
     
  1. Процедура ПриСозданииНаСервере
     
    
    &НаСервере
    Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
    	
    	// прочитаем сведения о внешней обработке
    	Об = РеквизитФормыВЗначение("Объект");
    	Попытка
    	// заполняются реквизиты для поиска открытого окна объекта, для которого предназначена обработка
    		СведОбр = Об.СведенияОВнешнейОбработке();
    		ВидОбработки = СведОбр.Вид;
    		Для каждого ОбНаз из СведОбр.Назначение Цикл
    			мд = Метаданные.НайтиПоПолномуИмени(ОбНаз);
    			Назначение.Добавить(ОбНаз, ?(ЗначениеЗаполнено(мд.ПредставлениеОбъекта), мд.ПредставлениеОбъекта, мд.Синоним));
    		КонецЦикла;
    	Исключение
    	КонецПопытки;
    	
    КонецПроцедуры
    
    
  2. Процедура ПриОткрытии
     
    
    &НаКлиенте
    Процедура ПриОткрытии(Отказ)
    	
    	Если ВладелецФормы = Неопределено Тогда
    		// этот код выполняется, когда форма открыта не из документа (используется для отладки кода обработки через Файл - Открыть)
    		Окна = ПолучитьОкна();
    		Для каждого тОкно из Окна Цикл
    			//Окно изменяемого документа будет точно не основным, а вспомогательным, поэтому
    			//сразу пропускаем основное окно, а далее идем на не очень хороший способ поиска открытого окна
    			//изменяемого документа. Мы просто переберем все окна, а в заголовке какого встретится
    			//Наименование нужного документа - будем его изменять
    			Если НЕ тОкно.Основное Тогда
    				Нашли = Ложь;
    				Для каждого ОбНаз из Назначение Цикл
    					Если Найти(тОкно.Заголовок, ОбНаз.Представление) Тогда
    						ОбНаз.Пометка = Истина;
    						Нашли = Истина;
    						Прервать;
    					КонецЕсли;
    				КонецЦикла;
    				Если Нашли Тогда
    					//Код находится в цикле на тот случай, если открытых окон изменяемого документа больше одного
    					
    					//Далее мы получаем объект найденной открытой формы и помещаем её в переменную
    					//В объекте содержатся все реквизиты (элементы) формы
    					Объект.Ссылка = тОкно.Содержимое[0].Объект.Ссылка;
    					Прервать;
    				КонецЕсли;
    			КонецЕсли;
    		КонецЦикла;
    	КонецЕсли;
    	
    КонецПроцедуры
    
    
  3. Процедура ВыполнитьЗаполнение (вызывается по кнопке формы)
     
    
    &НаКлиенте
    Процедура ВыполнитьЗаполнение(Команда)
    	
    	Если Не ВладелецФормы = Неопределено Тогда
    		НовыйОбъект = ВладелецФормы.Объект;
    	ИначеЕсли НЕ Объект.Ссылка.Пустая() Тогда
    		Для каждого ОбНаз из Назначение Цикл
    			Если ОбНаз.Пометка Тогда
    				ИмяОб = ОбНаз.Значение;
    				Прервать;
    			КонецЕсли;
    		КонецЦикла;
    		ВладелецФормы = ОткрытьФорму(ИмяОб+".Форма.ФормаДокумента", Новый Структура("Ключ", Объект.Ссылка));
    		НовыйОбъект = ВладелецФормы.Объект;
    	Иначе
    		Сообщить("Не выбран документ!");
    		Возврат;
    	КонецЕсли;	
    	
    	ДопПарам = Новый Структура("НовыйОбъект", НовыйОбъект);
    	
    	ОповещСогласияЗаполнить = Новый ОписаниеОповещения("ОбработкаСогласияЗаполнить", ЭтотОбъект, ДопПарам);
    	ПоказатьВопрос(ОповещСогласияЗаполнить, "Табличная часть документа будет очищена. Продолжить", РежимДиалогаВопрос.ДаНет);
    КонецПроцедуры
    
    

При создании на сервере формы обработки заполняются добавленные реквизиты формы видом обработки и списком документов, для которых предназначена обработка.

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

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

В процедуре ВыполнитьЗаполнение для отлаживаемой обработки осуществляется поиск имени объекта в списке реквизита Назначение, для которого была установлена пометка в процедуре ПриОткрытии, и открывается форма этого документа.

После заполнения документа выполняется функция
 

КопироватьДанныеФормы(НовыйОбъект, ВладелецФормы.Объект)

копирующая данные формы в данные формы открытого документа, и форма обработки заполнения закрывается.

Если надо заполнять не только ТЧ документов, но и других объектов, то несложно допилить код обработки самостоятельно.

Заполнение табличных частей отладка 8.3

См. также

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

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

15500 руб.

02.09.2020    177594    986    403    

943

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

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

8400 руб.

20.08.2024    19099    127    70    

131

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

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

15000 руб.

10.11.2023    12793    53    33    

72

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

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

22200 руб.

06.10.2023    18751    49    19    

82

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

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

9360 руб.

17.05.2024    28906    100    48    

146

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

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

20000 руб.

07.10.2021    18612    7    32    

43

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

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

3600 руб.

27.12.2024    1710    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. triviumfan 99 05.06.23 14:20 Сейчас в теме
Делал похожий костыль, да, оказалось, что неочевидно всё.
2. itmind 309 07.06.23 05:01 Сейчас в теме
Почему бы просто не вывести поле выбора ссылки на форму внешней обработки? Тогда не нужно будет искать открытое окно.
3. sml 41 07.06.23 09:05 Сейчас в теме
(2) не всегда надо открывать окно формы обработки при заполнении ТЧ
4. ZergKRSK 130 20.06.24 15:32 Сейчас в теме
На обработке заполнения ТЧ создается форма, поле с выбором Ссылки и команда, всё. Зачем весь этот огород так и не понял.
Оставьте свое сообщение