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