Примечания в отчётах (вывод, хранение, изменение)

09.11.16

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

Эта микро статья о добавлении интерактива отчёту в виде возможности работы с примечаниями.

Например, у нас есть отчёт по заказам покупателей. Необходимо дать возможность пользователям добавлять, сохранять, изменять примечания для определённых заказов (в общем случае для любого объекта),

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

1) Вывод примечаний

К сожалению, примечания нельзя вставить в уже выведенную область (поправьте меня, если я ошибаюсь)

Если вы выводите отчёт вручную (методом .Вывести() ), то проблем никаких нет, вставляем примечсание через свойство .Примечание.Текст . 

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

Код будет примерно такой:

	 ПолеТабличногоДокумента=  ЭлементыФормы.Результат;
	 Свойство=ПроверитьСоздатьСвойство("Примечание");
	 НачальнаяВысота = ПолеТабличногоДокумента.ВысотаТаблицы; 	 
	 Для Счетчик = 1 по НачальнаяВысота Цикл
		 Область1 = ПолеТабличногоДокумента.ПолучитьОбласть(Счетчик,2,Счетчик,2);
		 ЗначениеРасшифровки="";
		 Попытка
			 ЗначениеРасшифровки = ДанныеРасшифровки.Элементы[Область1.ТекущаяОбласть.Расшифровка].ПолучитьПоля()[0].Значение;
		 Исключение
			 Продолжить;
		 КонецПопытки;
		 Если Не ТипЗНЧ(ЗначениеРасшифровки)=Тип("ДокументСсылка.ЗаказПокупателя") Тогда
			 Продолжить;  
		 КонецЕсли;
		 МенЗап=РегистрыСведений.ЗначенияСвойствОбъектов.СоздатьМенеджерЗаписи();
		 МенЗап.Объект= ЗначениеРасшифровки;
		 МенЗап.Свойство= Свойство;
		 МенЗап.Прочитать();
		 Если Не МенЗап.Выбран() Тогда
			 Продолжить;  
		 КонецЕсли;
		 ЗначениеПримечания= МенЗап.Значение;
		 
		 ОбластьКолонкиЯчейки = Область1.ТекущаяОбласть;
		 ОбластьКолонкиЯчейки.Примечание.Текст = ЗначениеПримечания;
		 
		 ОбластьКолонкиЯчейки.ПараметрРасшифровки="РасшифровкаЗаказа";
		 Область1.Параметры.РасшифровкаЗаказа= ЗначениеРасшифровки;
		 
		 ПолеТабличногоДокумента.ВставитьОбласть(ОбластьКолонкиЯчейки,ПолеТабличногоДокумента.Область(Счетчик,2,Счетчик,2),ТипСмещенияТабличногоДокумента.ПоГоризонтали);
		 ПолеТабличногоДокумента.УдалитьОбласть(ПолеТабличногоДокумента.Область(Счетчик,3,Счетчик,3),ТипСмещенияТабличногоДокумента.ПоГоризонтали);
		 
	 КонецЦикла;	

2) Добавление, удаление, редактирование примечаний и их сохранение в объекте

Будем использовать стандартный механизм работы с примечаниями ТД  (правой кнопкой мыши по ячейке, пункты "Вставить/Изменить примечание", "Удалить примечание" использовать не будем, считаем что изменение примечание на пустую строку это и есть его удаление)

Добавим форме реквизит "ТекущийЗаказ", при активизации ячейки, если она "нужная", то записываем в этот реквизит значение расшифровки.

Далее ПриИзмененииСодержимогоОбласти если область имеет тип "РисунокТабличногоДокумента" и заполнен "ТекущийЗаказ", то запишем в его доп. свойство примечание

Процедура РезультатПриАктивизацииОбласти(Элемент)   
	ЗначениеРасшифровки="";
	Попытка
	ЗначениеРасшифровки = ДанныеРасшифровки.Элементы[Элемент.ТекущаяОбласть.Расшифровка].ПолучитьПоля()[0].Значение;
    Исключение
	
	КонецПопытки;
	Если ТипЗНЧ(ЗначениеРасшифровки)=Тип("ДокументСсылка.ЗаказПокупателя") Тогда
		  ЭтаФорма.ТекущийЗаказ =ЗначениеРасшифровки;
	КонецЕсли;
КонецПроцедуры

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

Тут есть один нюанс: Если кроме примечаний вы хотите использовать расшифровку (например, переходить в заказ), то нужно обеспечить пользователю возможность переключать режим "ТолькоПросмотр", т.к. когда он истина, то работает расшифровка, но не работает управление примечаниями, а когда "ложь", то наоборот.

Я решил эту проблему добавлением на форму кнопки, переключающей этот режим

Процедура ДействияФормыДействие6(Кнопка)
	ПолеТабличногоДокумента=  ЭлементыФормы.Результат  ;
	ПолеТабличногоДокумента.ТолькоПросмотр=Не  ПолеТабличногоДокумента.ТолькоПросмотр;
КонецПроцедуры

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

Примечания отчеты комментарии

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

28800 руб.

27.03.2025    56405    31    25    

45

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36000 руб.

28.08.2025    2703    1    2    

4

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

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

6000 руб.

14.01.2016    58242    20    25    

46

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

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

5160 руб.

29.06.2020    22865    32    6    

51

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

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

5040 руб.

06.10.2020    12852    8    8    

14

Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

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

20.08.2024    43395    mrXoxot    44    

138

Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

27.05.2024    24834    smielka    38    

111
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Ibrogim 1350 09.11.16 15:09 Сейчас в теме
Жду комментариев и конструктивной критики )
2. triviumfan 102 17.04.18 15:14 Сейчас в теме
(1) Наткнулся на статью) Правда я не понимаю, почему при создании макета полей СКД с примечаниями они все равно не отображаются при выводе в табдок результата отчета. Значит решение только такое - костыльное?
3. Ibrogim 1350 17.04.18 17:54 Сейчас в теме
(2) Нет. Но в статье ещё и интерактивное изменение и хранение примечаний рассматривается. В принципе достаточно полезный функционал
4. triviumfan 102 23.04.18 09:22 Сейчас в теме
(1) Хотелось бы сделать работу с примечаниями через обработку расшифровки) Правда платформенная фича работы с табдоком возможна только если он не в режиме чтения...
Для отправки сообщения требуется регистрация/авторизация