Открытие из обработки табличного документа в общей форме "ПечатьДокументов" с помощью БСП

01.09.15

Разработка - БСП (Библиотека стандартных подсистем)

В статье описан механизм создания обработки, табличный документ из которой можно непосредственно вывести в типовую форму печати БП 3.0 и УТ 11.1 (редакция БСП начиная с 2.2.4.43, где-то начало 2015 года). С помощью данного механизма удобно отлаживать печатные формы или создавать внешние обработки, выводящие что-нибудь на печать.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
(только для физ. лиц)
Открытие ТД из формы обработки в форме ПечатьДокументов.epf
.epf 9,69Kb
11 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

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

Оформить подписку и скачать решение со скидкой

В модуле формы размещаем команду печати с вызовом процедуры на клиенте. В связи с тем, что обработка параллельно используется для формирования внешней печатной формы, то процедура формирования табличного документа находится в модуле обработки и вызвать непосредственно с клиента её мы не можем, следовательно, вызовем серверную процедуру, которой передаем параметр и которая в свою очередь вызывает функцию, формирующую табличный документ.

&НаКлиенте
Перем ТабДокумент;

&НаСервере
Процедура ПолучитьТабличныйДокумент(ТабДокумент)
	Обработка = РеквизитФормыВЗначение("Объект");
	ТабДокумент = Обработка.ПечатьВнешняя(Неопределено, Неопределено);
КонецПроцедуры

&НаКлиенте
Процедура КомандаПечать(Команда)	
	ПолучитьТабличныйДокумент(ТабДокумент);
...

процедура печати в модуле обработки

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

При открытии общей формы "ПечатьДокументов", все важные процессы происходят в процедуре "ПриСозданииНаСервере" и вызываемых ею других процедурах и функциях, в целом основная загвоздка была в том, что переменная "КоллекцияПечатныхФорм" при получении данных из внешней печатной формы и стандартной процедуры печати возвращала таблицу значения, но из модуля формы на клиенте таблицу значений передать в открываемую форму нельзя, по этой причине нужно эмулировать таблицу в виде Структуры входящий в Массив. 

//Для стандартных печатных форм используется таблица значений, но создать её на клиенте нельзя
	//по этой причине воспользуемся массивом и структурой 
	КоллекцияПечатныхФормСтруктура = Новый Структура;
	КоллекцияПечатныхФормСтруктура.Вставить("СинонимМакета"        , Неопределено);
	КоллекцияПечатныхФормСтруктура.Вставить("Экземпляров"          , 1);
	КоллекцияПечатныхФормСтруктура.Вставить("ИмяМакета"            , Неопределено);
	КоллекцияПечатныхФормСтруктура.Вставить("ПолныйПутьКМакету"    , Неопределено);
	КоллекцияПечатныхФормСтруктура.Вставить("ИмяФайлаПечатнойФормы", Неопределено);
	КоллекцияПечатныхФормСтруктура.Вставить("ТабличныйДокумент"    , ТабДокумент);	
	КоллекцияПечатныхФорм = Новый Массив;
	КоллекцияПечатныхФорм.Добавить(КоллекцияПечатныхФормСтруктура);
	
	ПараметрыПечати = Новый Структура("ДополнительныеПараметры", Новый Структура);
	//если значение будет Ложь, то система попытается восстановить пользовательские настройки, которых у нас нет
	ПараметрыПечати.Вставить("ПереопределитьПользовательскиеНастройкиКоличества", Истина);	
	//заголовок печатной формы
	ПараметрыПечати.Вставить("ЗаголовокФормы", "Заголовок моей печатной формы");
	
	ПараметрыОткрытия = Новый Структура;
	//не важно, какое значение лишь бы было заполнено, иначе будет ошибка
	ПараметрыОткрытия.Вставить("ИсточникДанных"       , "ВнешняяОбработка");
	ПараметрыОткрытия.Вставить("ПараметрыПечати"      , ПараметрыПечати);	
	ПараметрыОткрытия.Вставить("КоллекцияПечатныхФорм", КоллекцияПечатныхФорм);	
	ОткрытьФорму("ОбщаяФорма.ПечатьДокументов", ПараметрыОткрытия);	
	
КонецПроцедуры

Пример обработки можно скачать ниже.

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

Печатная форма печать внешняя печать

См. также

БСП (Библиотека стандартных подсистем) Программист Платные (руб)

Синтакс-помощник БСП - cправочник по библиотекам стандартных подсистем и электронных документов. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП и БЭД.

1800 руб.

21.11.2024    7801    39    24    

42

Анализ учета БСП (Библиотека стандартных подсистем) 1С v8.3 1С:Библиотека стандартных подсистем Бесплатно (free)

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

22.05.2025    2374    100    seperblunt    7    

22

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

В этой статье я расскажу, как в конфигурации 1С:ERP 2.5 при начале работы системы настроить открытие своих нетиповых форм (в том числе и из внешних обработок). Данную методику можно использовать как на тонком клиенте, так и на мобильном или веб-клиенте, а также в мобильном приложении.

12.05.2025    2427    PROSTO-1C    1    

16

БСП (Библиотека стандартных подсистем) Роли и права Программист 1С v8.3 1С:Библиотека стандартных подсистем Бесплатно (free)

Наткнулся на костыль по работе с ролями. Хочу поделиться, как не попасть на это странное поведение БСП.

07.05.2025    6031    dsdred    32    

87

БСП (Библиотека стандартных подсистем) Обновление 1С Программист 1C:ERP Бесплатно (free)

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

29.04.2025    2540    krasnoshchekovpavel    7    

18

БСП (Библиотека стандартных подсистем) Механизмы платформы 1С Программист 1С v8.3 Бесплатно (free)

Описание способа создания глобального обработчика оповещений (событие формы), не привязанного к какой-то конкретной форме.

01.04.2025    1679    krasnoshchekovpavel    0    

10

БСП (Библиотека стандартных подсистем) Программист 1С v8.3 1С:Библиотека стандартных подсистем Россия Бесплатно (free)

Как создать внешнюю печатную форму для конфигураций на базе БСП с желанной всеми разработчиками фишкой - автоматическим открытием обработки в конфигураторе с остановкой отладчика внутри процедуры Печать() при выполнении интерактивной команды печати.

24.03.2025    2351    GeraltSnow    6    

32

БСП (Библиотека стандартных подсистем) Программист 1С v8.3 Бесплатно (free)

Добавим метки в новый документ средствами БСП.

10.02.2025    5820    John_d    24    

56
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. infostartfilipich 17.02.16 12:27 Сейчас в теме
Спасибо, пригодилось!
2. vis_tmp 32 18.11.16 09:17 Сейчас в теме
Большое спасибо - всё работает!
3. vis_tmp 32 18.11.16 09:33 Сейчас в теме
http://infostart.ru/public/402197/

А вот есть ещё похожий вариант - только там "КоллекцияПечатныхФорм" формируется не вручную, а вызовом типовой функции.
4. waol 320 20.01.17 17:19 Сейчас в теме
5. Sangre1999 52 29.03.19 11:31 Сейчас в теме
Спасибо пригодилось, единственное пришлось добавить:
КоллекцияПечатныхФормСтруктура.Вставить("ОфисныеДокументы" , "");
Оставьте свое сообщение