2020-06-23 18:09:00 +02:00
|
|
|
# Задание к занятию "Текстовые документы"
|
2020-05-31 18:38:56 +02:00
|
|
|
|
2020-06-23 19:37:07 +02:00
|
|
|
## Задача 1 Создать команду печати прайс-листа в справочнике Номенклатура
|
2020-06-23 18:09:00 +02:00
|
|
|
|
|
|
|
### Описание задачи
|
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
Добавим возможность формировать прайс-лист в справочнике Номенклатура.
|
2020-06-23 18:19:17 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
В прайс выведем актуальную цену номенклатуры.
|
2020-06-23 18:09:00 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
Формирование прайса реализуем через печатную форму и общий макет.
|
2020-06-23 18:09:00 +02:00
|
|
|
|
|
|
|
### Требования к результату
|
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
Общий макет имеет тип Текстовый документ.
|
|
|
|
|
|
|
|
Содержит структуру для формирования прайс листа - цену и номенклатуру.
|
|
|
|
|
|
|
|
Цена номенклатуры определяется на текущую дату.
|
2020-06-23 18:09:00 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
Есть возможность вывести на печать из формы списка номенклатуры, не открывая форму элемента.
|
2020-06-23 18:09:00 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
Прайс формируется на основе выделенных строк в форме списка Номенклатура.
|
|
|
|
|
|
|
|
Можно выделить одну или несколько строк для формирования печатной формы.
|
2020-06-23 19:40:49 +02:00
|
|
|
|
2020-06-23 18:09:00 +02:00
|
|
|
### Процесс выполнения
|
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
1. Добавим общий макет "МакетПрайсЛист" с типом Текстовый документ
|
2020-06-23 18:09:00 +02:00
|
|
|
|
|
|
|
Пример текста
|
2020-06-23 18:56:10 +02:00
|
|
|
```
|
2020-06-23 18:22:04 +02:00
|
|
|
#Область ШапкаПрайса
|
|
|
|
#Поле ТекущаяДата
|
|
|
|
[ Дата]
|
2020-06-23 18:09:00 +02:00
|
|
|
#КонецОбласти
|
|
|
|
|
|
|
|
#Область ТабличнаяЧастьЗаголовок
|
|
|
|
---------------------------------
|
|
|
|
Товар | Цена, рублей
|
|
|
|
#КонецОбласти
|
|
|
|
|
|
|
|
#Область ТабличнаяЧастьСтрока
|
|
|
|
#Поле Номенклатура
|
|
|
|
#Формат "ЧЦ=12; ЧДЦ=2;ЧРД=."
|
|
|
|
#Забивать Истина
|
|
|
|
#Поле Цена
|
2020-06-23 18:23:10 +02:00
|
|
|
#Выравнивание Центр
|
2020-06-23 18:09:00 +02:00
|
|
|
---------------------------------
|
|
|
|
[Номенклатура ]|[Цена ]
|
2020-06-23 18:27:14 +02:00
|
|
|
```
|
2020-06-24 09:24:25 +02:00
|
|
|
2. В форму списка номенклатуры добавим команду "Прайс лист".
|
2020-06-23 19:37:07 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
3. Для печати добавим на клиенте процедуру на клиенте.
|
2020-06-23 19:37:07 +02:00
|
|
|
```bsl
|
|
|
|
&НаКлиенте
|
|
|
|
Процедура КомандаПрайсЛист(Команда)
|
|
|
|
|
|
|
|
//выделим несколько строк
|
|
|
|
ВыделенныеСтроки = Элементы.СписокРасширенныйПоискНоменклатура.ВыделенныеСтроки;
|
|
|
|
МассивСтрок = Новый Массив();
|
|
|
|
Для каждого НомерСтроки Из ВыделенныеСтроки Цикл
|
|
|
|
МассивСтрок.Добавить(Элементы.СписокРасширенныйПоискНоменклатура.ДанныеСтроки(НомерСтроки));
|
|
|
|
КонецЦикла;
|
|
|
|
//отправим выделенные строки номенклатуры на печать
|
2020-06-24 09:24:25 +02:00
|
|
|
ПечатнаяФорма = ПечатнаяФормуПрайсЛист(МассивСтрок);
|
2020-06-23 19:37:07 +02:00
|
|
|
ПечатнаяФорма.Показать("Прайс-лист");
|
|
|
|
|
|
|
|
КонецПроцедуры
|
|
|
|
```
|
2020-06-24 09:24:25 +02:00
|
|
|
4. На сервере формируем печатную форму и возращаем на клиент для печати
|
2020-06-23 19:37:07 +02:00
|
|
|
|
|
|
|
```bsl
|
|
|
|
&НаСервере
|
2020-06-24 09:24:25 +02:00
|
|
|
Функция ПечатнаяФормуПрайсЛист(МассивСтрок)
|
2020-06-23 19:37:07 +02:00
|
|
|
|
|
|
|
ПечатнаяФорма = Новый ТекстовыйДокумент;
|
|
|
|
|
|
|
|
Макет = ПолучитьОбщийМакет("МакетПрайсЛист");
|
|
|
|
|
|
|
|
// Получаем область шапки и макета по имени
|
|
|
|
Шапка = Макет.ПолучитьОбласть("ШапкаПрайса");
|
|
|
|
// Заполняем параметр Дата
|
|
|
|
Шапка.Параметры.Дата = ТекущаяДата();
|
|
|
|
// Выводим область в документ
|
|
|
|
ПечатнаяФорма.Вывести(Шапка);
|
|
|
|
|
|
|
|
// Получаем область заголовка
|
|
|
|
ТабличнаяЧастьЗаголовок = Макет.ПолучитьОбласть("ТабличнаяЧастьПрайсаЗаголовок");
|
|
|
|
ПечатнаяФорма.Вывести(ТабличнаяЧастьЗаголовок);
|
|
|
|
|
|
|
|
// Получаем область строк для формирования табличной части в цикле
|
|
|
|
ТабличнаяЧастьСтрока = Макет.ПолучитьОбласть("ТабличнаяЧастьПрайсаСтрока");
|
|
|
|
|
|
|
|
Для каждого СтрокаСписка из МассивСтрок Цикл
|
|
|
|
ТабличнаяЧастьСтрока.Параметры.Номенклатура = СтрокаСписка.Наименование;
|
|
|
|
ТабличнаяЧастьСтрока.Параметры.Цена = 100;
|
|
|
|
ПечатнаяФорма.Вывести(ТабличнаяЧастьСтрока);
|
|
|
|
КонецЦикла;
|
|
|
|
|
|
|
|
// Возвращаем печатную форму обратно на клиент
|
|
|
|
Возврат ПечатнаяФорма;
|
|
|
|
|
|
|
|
КонецФункции
|
|
|
|
```
|
2020-06-23 18:09:00 +02:00
|
|
|
|
2020-06-24 09:24:25 +02:00
|
|
|
5. Получим срез последних по регистру сведений Цены номенклатуры для заполнения цены и вставим в соответствующий параметр
|