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

61 lines
5.5 KiB
Markdown
Raw Normal View History

2023-01-18 18:20:42 +02:00
# Задание к занятию «Регистры сведений»
2020-05-03 12:53:49 +02:00
2023-01-18 18:20:42 +02:00
## Задача 1. «Цены»
2020-05-03 12:53:49 +02:00
### Описание задачи
2023-01-18 18:20:42 +02:00
Создать периодический регистр сведений «Цены» для хранения цен номенклатуры с историей.
2020-05-05 10:53:45 +02:00
2020-05-03 12:53:49 +02:00
### Требования к результату
2023-01-18 18:20:42 +02:00
Выгрузка информационной базы (.dt) с конфигурацией из предыдущих заданий с новым регистром «Цены», который:
2020-05-05 10:53:45 +02:00
2020-05-09 21:18:57 +02:00
* содержит измерение Номенклатура, ресурс Цена и реквизит Установил;
2020-05-05 10:53:45 +02:00
* является периодическим с точностью до секунды;
* скрыт из командного интерфейса.
2023-01-18 18:20:42 +02:00
В форме списка справочника «Номенклатура» должен находиться динамический список с ценами и соответствующая ему таблица.
2020-05-05 10:53:45 +02:00
Список должен быть отобран по активному товару (услуге) и упорядочен по убыванию дат.
2020-05-09 21:18:57 +02:00
При создании новых записей регистра Цены в реквизит Установил должен автоматически подставляться текущий сотрудник.
2020-05-05 10:53:45 +02:00
2020-05-03 12:53:49 +02:00
### Процесс выполнения
2023-01-18 18:20:42 +02:00
1. Создать регистр сведений «Цены», в котором:
* указать периодичность «До секунды»;
* добавить ведущее измерение «Номенклатура», ресурс «Цена» и реквизит «Установил» (СправочникСсылка.Сотрудники);
* снять флажок «Использовать стандартные команды», чтобы скрыть его из командного интерфейса (мы сделаем интерфейс лучше, чем предоставляет платформа автоматически);
* в модуле набора записей реализовать обработчик события ОбработкаЗаполнения, в котором:
* обойти все записи как элементы коллекции ЭтотОбъект;
* для каждой записи заполнить реквизит Установил значением по умолчанию (текущим сотрудником).
2. Включить в состав роли БазовыеПрава.
3. В форме списка справочника «Номенклатура» из предыдущих заданий:
* создать динамический список «Цены» с основной таблицей «РегистрСведений.Цены»;
* вывести его таблицей формы под таблицей с группами номенклатуры;
* в обработчике ПриАктивизацииСтроки таблицы с элементами номенклатуры установить отбор по измерению «Номенклатура» аналогично отбору элементов при активизации группы;
* поскольку установка отбора динамического списка — операция популярная, лучше создать для неё процедуру в общем модуле, например, ОбщегоНазначенияКлиентСервер.УстановитьЭлементОтбораДинамическогоСписка().
## Задача 2. «История цен»
2020-05-03 12:53:49 +02:00
### Описание задачи
2023-01-18 18:20:42 +02:00
Создать отчёт, выводящий историю цен номенклатуры.
2020-05-05 10:53:45 +02:00
2020-05-03 12:53:49 +02:00
### Требования к результату
2023-01-18 18:20:42 +02:00
Выгрузка информационной базы (.dt) с Отчётом «История цен», который:
2020-05-05 10:53:45 +02:00
* построен на СКД;
2023-01-18 18:20:42 +02:00
* на первом уровне группировок выводит номенклатуру по иерархии, а на уровне детальных записей — период, упорядоченный по убыванию, цену и сотрудника, установившего её.
2020-05-05 10:53:45 +02:00
2020-05-03 12:53:49 +02:00
### Процесс выполнения
2020-05-05 10:53:45 +02:00
2023-01-18 18:20:42 +02:00
Создать отчёт «История цен», в котором:
* создать основную схему компоновки данных;
* добавить в неё набор данных — запрос;
* открыв «Конструктор запроса», добавить таблицу «РегистрыСведений.Цены» со всеми её полями;
* на закладке «Настройка» в варианте «Основной» добавить группировки:
* Номенклатура — Иерархия (под корнем «Отчёт»);
* Пустую (детальные записи, под группировкой «Номенклатура»);
* в «Выбранные поля» перетащить поля Номенклатура, Период, Установил и Цена;
* на закладке «Сортировка» добавить сортировку по номенклатуре (по возрастанию) и по периоду (по убыванию);
* проверить отчёт в режиме Предприятия.