1
0
mirror of https://github.com/netology-code/1c-homeworks.git synced 2024-11-24 08:02:20 +02:00
1c-homeworks/homework-5-8.md

108 lines
5.4 KiB
Markdown
Raw Normal View History

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. Получим срез последних по регистру сведений Цены номенклатуры для заполнения цены и вставим в соответствующий параметр