Дата последнего изменения: 16.11.2023
С версии 21.600.0 Главного модуля доступны новые методы объекта грида. Цель их внедрения - упростить и уменьшить объем кода, требующийся для создания своей админской страницы со списком элементов.
Для работы со списками элементов в main есть два класса:
 - предназначен исключительно для страниц Административного раздела.
                
			
		
		 - предназначен исключительно для страниц Административного раздела.  (наследник CAdminList) - используется, если административный список выводится в магазине Б24.
                
			
		
		 (наследник CAdminList) - используется, если административный список выводится в магазине Б24.В коде страниц, использующих эти классы, имеется множество обращений к $_REQUEST для получения текущего режима страницы, текущего группового действия, измененных данных и т.п. Например, таких:
$bExcel = isset($_REQUEST["mode"]) && ($_REQUEST["mode"] == "excel"); // режим выгрузки в Excel
!isset($_REQUEST["mode"]) || $_REQUEST["mode"]=='list' || $_REQUEST["mode"]=='frame' // все, кроме Excel и окна настроек
switch($_REQUEST['action']) // получение идентификатора групповой операции
Ниже приводится список новых методов, предназначенных для упрощения разработки новых страниц и правки уже существующих.
Грид может работать в нескольких режимах:
Ранее получение текущего режима сводилось к анализу ключа mode в $_REQUEST. Вместо этого предлагается использовать методы объекта грида:
public function getCurrentMode(): string // получение режима работы
вернет одну из констант класса:
public const MODE_PAGE = 'normal'; - обычный вывод страницы;public const MODE_LIST = 'list'; - обновление содержимого грида без полной перезагрузки;public const MODE_ACTION = 'frame'; - обработка результатов быстрого редактирования;public const MODE_EXPORT = 'excel'; - выгрузка в псевдо-Excel;public const MODE_CONFIG = 'settings'; - показ формы настроек.Режим определяется в момент инициализации объекта грида.
Старый код:
$sTableID = "tbl_user"; $lAdmin = new CAdminUiList($sTableID); $excelMode = ($_REQUEST["mode"] == "excel");
Новый:
$sTableID = "tbl_user"; $lAdmin = new CAdminUiList($sTableID); $excelMode = $lAdmin->getCurrentMode() === \CAdminList::MODE_EXPORT;
Чтобы каждый раз не писать большой объем кода для сравнения с константой, добавлены вспомогательные методы:
| 
 | 
Таким образом, предыдущий пример превращается в такой код:
$sTableID = "tbl_user"; $lAdmin = new CAdminUiList($sTableID); $excelMode = $lAdmin->isExportMode();
Типичный код обработки на странице
if ($lAdmin->EditAction())
{
	if (is_array($_REQUEST['FIELDS']))
	{
		foreach($_REQUEST['FIELDS'] as $ID=>$arFields)
	{
		$ID = (int)$ID;
		if ($ID <= 0)
			continue;
		if (!$lAdmin->IsUpdated($ID))
			continue;
		// дальше код, сохраняющий данные одной строки
		}
	}
}
можно заменить на такой:
if ($lAdmin->EditAction())
{
	foreach ($lAdmin->getEditFields() as $ID=>$arFields)
	{
		//код, сохраняющий данные одной строки
	}
}
Метод
public function getEditFields(): array
возвращает массив записей, которые были изменены (с предварительной проверкой, что ключи непустые).
Дополнительно (если в гриде используется вывод и редактирование файлов) есть метод:
public function convertFilesToEditFields(): void
для копирования присланных файлов в общий массив полей. Т.е. предыдущий код слегка расширяем:
if ($lAdmin->EditAction())
{
	$lAdmin->convertFilesToEditFields();
	foreach ($lAdmin->getEditFields() as $ID=>$arFields)
	{
		//код, сохраняющий данные одной строки
	}
}
Типичный код обработки групповых операций:
if ($arID = $lAdmin->GroupAction()
{
	if ($_REQUEST['action_target']=='selected')
	{
		// в $arID выбираем идентификаторы всех строки
	}
	foreach ($arID as $ID)
	{
		switch ($_REQUEST['action']) // получение ID действия
		{
		...
		}
	}
}
можно упростить так:
if ($arID = $lAdmin->GroupAction()
{
	$actionId = $lAdmin->getAction();
	if ($actionId === null)
	{
		continue;
	}
	if ($lAdmin-> isGroupActionToAll())
	{
		// в $arID выбираем все идентификаторы строк
	}
	foreach ($arID as $ID)
	{
		switch ($actionId) // действия
		{
		...
		}
	}
}
| 
 | 
