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

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