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

09.11.16

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

См. также

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

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

5000 руб.

14.01.2016    55468    17    23    

43

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

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

2400 руб.

29.06.2020    19753    28    6    

44

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

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

20.08.2024    22067    mrXoxot    44    

128

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

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

27.05.2024    11119    smielka    37    

105

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

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

27.12.2023    18001    1226    elcoan    53    

125

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

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

3 стартмани

10.04.2023    12685    167    acces969    31    

126

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

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

1 стартмани

05.07.2022    7471    kalyaka    6    

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