Создать иерархический справочник «Номенклатура» для хранения сведений о товарах и услугах. В форме списка, по аналогии с реальными прикладными решениями, сделать таблицу для групп и таблицу для элементов с отбором элементов по активной группе. Выглядеть это должно примерно так:
1. Создать перечисление ТипыНоменклатуры со значениями Товар, Услуга.
2. Создать справочник Номенклатура (синоним «Товар, услуга»):
* с неограниченной иерархией групп и элементов.
* с реквизитами ПолноеНаименование (строка неограниченной длины) и Тип (ПеречислениеСсылка.ТипыНоменклатуры), определенными только для элементов. Сделать тип обязательным к заполнению.
3. Включить его в роль БазовыеПрава с правом на чтение, редактирование, изменение, удаление и запись (но не на интерактивное удаление).
4. Создать форму списка, в которой:
* отключить автозаполнение общей командной панели — её заменит командная панель списка элементов;
* создать общую группу с горизонтальной группировкой элементов, в которой разместить две группы с вертикальным расположением: правую — для дерева групп номенклатуры, левую — для списка элементов;
* в автоматически созданном динамическом списке Список установить отбор по условию ЭтоГруппа = Ложь, а соответствующую таблицу формы перетащить в левую группу. Выбрать для нее режим отображения «Список»;
* из состава команд таблицы формы «Список» исключить команду «Создать группу» — она будет только в командной панели дерева групп;
* создать динамический список Группы с основной таблицей Справочник.Номенклатура и отбором по условию ЭтоГруппа = Истина;
* перетащить динамический список Группы на форму в правую группу и для этой таблицы выбрать режим отображения «Дерево»;
* исключить из состава её команд команду «Создать» (элемент) — она останется только для списка элементов;
* реализовать для таблицы Группы обработчик события ПриАктивизацииСтроки, в котором установить отбор по значению текущей группы. Для установки использовать коллекцию элементов отбора компоновки данных (Список.Отбор.Элементы), в которой:
* сперва попытаться перебором найти ранее установленный отбор по значению свойства ЛевоеЗначение — оно будет равно полю компоновки данных, созданному вами по имени «Родитель»;
* при его наличии установить новое значение свойства ПравоеЗначение, а при его отсутствии добавить новый элемент отбора, установив ЛевоеЗначение, ПравоеЗначение, ВидСравнения и Использование. Обратите внимание: в качестве вида сравнения следует указывать элемент предопределенного перечисления ВидСравненияКомпоновкиДанных, а не ВидСравнения.
Создать справочник «Упаковки», подчинённый справочнику «Номенклатура» и хранящий сведения о возможных упаковках товаров с указанием количества единиц товара в каждой упаковке. В реальных прикладных решениях, как правило, в документах товарного учета указывается товар, упаковка и количество упаковок, а общее количество единиц программа рассчитывает сама.