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

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

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

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

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

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

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

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

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

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

ОбластьКолонкиЯчейки = Область1.ТекущаяОбласть;
ОбластьКолонкиЯчейки.Примечание.Текст = ЗначениеПримечания;

ОбластьКолонкиЯчейки.ПараметрРасшифровки="РасшифровкаЗаказа";
Область1.Параметры.РасшифровкаЗаказа= ЗначениеРасшифровки;

ПолеТабличногоДокумента.ВставитьОбласть(ОбластьКолонкиЯчейки,ПолеТабличногоДокумента.Область(Счетчик,2,Счетчик,2),ТипСмещенияТабличногоДокумента.ПоГоризонтали);
ПолеТабличногоДокумента.УдалитьОбласть(ПолеТабличногоДокумента.Область(Счетчик,3,Счетчик,3),ТипСмещенияТабличногоДокумента.ПоГоризонтали);

КонецЦикла;

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

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

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

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

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

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

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

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

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

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

4 Comments

  1. Ibrogim

    Жду комментариев и конструктивной критики )

    Reply
  2. triviumfan

    (1) Наткнулся на статью) Правда я не понимаю, почему при создании макета полей СКД с примечаниями они все равно не отображаются при выводе в табдок результата отчета. Значит решение только такое — костыльное?

    Reply
  3. Ibrogim

    (2) Нет. Но в статье ещё и интерактивное изменение и хранение примечаний рассматривается. В принципе достаточно полезный функционал

    Reply
  4. triviumfan

    (1) Хотелось бы сделать работу с примечаниями через обработку расшифровки) Правда платформенная фича работы с табдоком возможна только если он не в режиме чтения…

    Reply

Leave a Comment

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