Уж 2019 на дворе, а самое частое упоминание общего объекта ФорматированныйДокумент практически не встречается без HTML. Для тех немногих, кого эти четыре буквы заставляют кривиться и посвящается этот практикум.
Метод, естественно, не новый, сначала пришлось изобрести велосипед, а потом уже поиском увидел похожий функционал в типовых. Но это как раз тот вариант, когда чтобы правильно задать вопрос, надо знать половину ответа.
Иногда пользователям отдается на откуп загрузка каких то данных, результат загрузки которых желательно раскрасить если и не всеми цветами радуги, то хотя бы светофором.
Один из вариантов – это использовать Форматированную строку. Следите за руками:
Создаём на форме загрузки поле с видом «Поле форматированного документа»
В модуле формы создаем массив, где будем хранить результаты работы обработки построчно
СуперполнаяСтрока=Новый ФорматированнаяСтрока(ПолнаяСтрока);
НашЛог.УстановитьФорматированнуюСтроку(СуперПолнаяСтрока);
ЭтаФорма.Журнал=НашЛог;
Затем уже собственно кладём результаты загрузки, любым приемлемым способом. Например
Попытка
ТекНоменклатура.Записать();
Строка1 = Новый ФорматированнаяСтрока(Строка(ВыборкаДетальныеЗаписи.Номенклатура),,WebЦвета.Зеленый);
Строка2 = Новый ФорматированнаяСтрока("Записана:", Новый Шрифт(,,Истина,));
ОбщаяСтрока = Новый ФорматированнаяСтрока(Строка2," ",Строка1,Символы.ПС);
ПолнаяСтрока.Добавить(ОбщаяСтрока);
Исключение
Строка1 = Новый ФорматированнаяСтрока(Строка(ВыборкаДетальныеЗаписи.Номенклатура),,WebЦвета.Красный);
Строка2 = Новый ФорматированнаяСтрока("Не записана:", Новый Шрифт(,,Истина,));
ОбщаяСтрока = Новый ФорматированнаяСтрока(Строка2," ",Строка1,Символы.ПС);
ПолнаяСтрока.Добавить(ОбщаяСтрока);
КонецПопытки;
Пояснять, как мне кажется, ничего не надо. Форматированные строки прекрасно друг в друга складываются, получаем красивую глазастую картинку не используя HTML. Если, конечно, не забудем вишенку на торте:
СуперполнаяСтрока=Новый ФорматированнаяСтрока(ПолнаяСтрока);
НашЛог.УстановитьФорматированнуюСтроку(СуперПолнаяСтрока);
ЭтаФорма.Журнал=НашЛог;
Создаем «Крайнюю» форматированную строку из заполненного нами массива и отображаем в форме
К статье прикладываю обработку, присваивающую артикул номенклатуры по одному из дополнительному реквизиту, использующую данный метод отображения лога. Иногда просят в УПД в поле «Код» указывать либо внутренний артикул производителя, либо штрихкод либо ещё какую-нибудь уникальную строку. У нас же на каждую номенклатуру в допреквизитах хранятся артикулы всех поставщиков, и нам их туда подставить несложно. (Да, я в курсе про «Номенклатуру поставщика» но реализация её в конфигурации далека от идеальной, в тому же она используется в приходных документах, а не в реализациях) В случае если документы уходят по ЭДО, не всегда есть возможность поменять в коде «Чужой» обработки ЭДО артикул или код на допреквизит, поэтому применяется данный костыль
Обработка протестирована на платформе 8.3.13.1644, работает в конфигурации Управление торговлей, редакция 11 (11.4.6.188) но думаю, без проблем будет работать в KA и выше по списку.