Найти в Дзене
Владимир Жирицкий

1С. Создать программно таблицу значений.

&НаСервере

Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)

МассивТипаВыбора = Новый Массив;

МассивТипаВыбора.Добавить(Тип("ТаблицаЗначений"));

ОписаниеТипаВыбора = Новый ОписаниеТипов(МассивТипаВыбора);

МассивРеквизитов = Новый Массив;

МассивРеквизитов.Добавить(Новый РеквизитФормы("ТаблицаРасписания", ОписаниеТипаВыбора, "", "ТЗН"));


КД = Новый КвалификаторыДаты(ЧастиДаты.Время);

МассивКД = Новый Массив;

МассивКД.Добавить(Тип("Дата"));

ОписаниеТиповВремя = Новый ОписаниеТипов(МассивКД, , ,КД);

ТЗ = Новый ТаблицаЗначений;
ТЗ.Колонки.Добавить("С", ОписаниеТиповВремя);
ТЗ.Колонки.Добавить("До", ОписаниеТиповВремя);
ТЗ.Колонки.Добавить("ФИО");
ТЗ.Колонки.Добавить("Примечание");//ФИО и Примечание - строки

Для Каждого Колонка Из ТЗ.Колонки Цикл

МассивРеквизитов.Добавить(Новый РеквизитФормы(Колонка.Имя, Колонка.ТипЗначения,"ТаблицаРасписания"));

КонецЦикла;
ИзменитьРеквизиты(МассивРеквизитов);
ТаблицаПолейВыбора = Элементы.Добавить("ТЗН", Тип("ТаблицаФормы"));
ТаблицаПолейВыбора.ПутьКДанным = "ТаблицаРасписания";
ТаблицаПолейВыбора.Отображение = ОтображениеТаблицы.Список;

Для Каждого Колонка Из ТЗ.Колонки Цикл

НовыйЭлемент = Элементы.Добавить(Колонка.Имя, Тип("ПолеФормы"), ТаблицаПолейВыбора);
НовыйЭлемент.Вид = ВидПоляФормы.ПолеВвода;
НовыйЭлемент.ПутьКДанным = "ТаблицаРасписания." + Колонка.Имя;
НовыйЭлемент.Ширина = 10;

КонецЦикла;

ТаблицаПолейВыбора.УстановитьДействие("Выбор","ТЗНВыбор");

ЗначениеВРеквизитФормы(ТЗ, "ТаблицаРасписания");

КонецПроцедуры