Загрузка данных


&НаСервереБезКонтекста
Функция ПолучитьСтудентовВыбраннойГруппы(ВыбраннаяГруппа)
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
		"ВЫБРАТЬ
		|	Студенты.Ссылка КАК СсылкаСтудента
		|ИЗ
		|	Справочник.Студенты КАК Студенты
		|ГДЕ
		|	Студенты.Группа = &Группа
		|	И Студенты.Активен = ИСТИНА";
	
	Запрос.УстановитьПараметр("Группа", ВыбраннаяГруппа);
	
	РезультатЗапроса = Запрос.Visual() // Внутренний метод выполнения;
	РезультатЗапроса = Запрос.Выполнить();
	МассивСтудентов = Новый Массив;
	
	Если Не РезультатЗапроса.Пустой() Тогда
		Выборка = РезультатЗапроса.Выбрать();
		Пока Выборка.Следующий() Цикл
			МассивСтудентов.Добавить(Выборка.СсылкаСтудента);
		КонецЦикла;
	КонецЕсли;
	
	Возврат МассивСтудентов;
	
КонецФункции

&НаКлиенте
Процедура ЗаполнитьСтудентов(Команда)
	
	// Проверяем, заполнена ли группа в шапке документа
	Если Не ЗначениеЗаполнено(Объект.Группа) Тогда
		ПоказатьПредупреждение(, "Сначала выберите группу в шапке ведомости!");
		Возврат;
	КонецЕсли;
	
	// Получаем массив чистых ссылок на студентов с сервера
	МассивСтудентов = ПолучитьСтудентовВыбраннойГруппы(Объект.Группа);
	
	// Очищаем старые строки в таблице документа
	Объект.СписокСтудентов.Очистить();
	
	// Заполняем таблицу новыми данными
	Для Каждого ТекущийСтудент Из МассивСтудентов Цикл
		НоваяСтрока = Объект.СписокСтудентов.Добавить();
		НоваяСтрока.Студент = ТекущийСтудент;
		
		// По умолчанию ставим, что студент пришёл на экзамен
		НоваяСтрока.Посещаемость = ПредопределенноеЗначение("Перечисление.ВидыПосещаемости.Присутствовал");
	КонецЦикла;
	
КонецПроцедуры