<?if(!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)die();
use \Bitrix\Main\Loader;
use \Bitrix\Highloadblock as HL;
if ( Loader::IncludeModule('highloadblock') )
{
/**
* @var array Массивы описывающие свойства типа справочник
*/
$arHighloadProperties = array(
&$arResult["PROPERTIES"]['SPORT_SPR'],
&$arResult["PROPERTIES"]['VID_SPR']
);
foreach ($arHighloadProperties as &$arHighloadProperty)
{
/**
* @var string название таблицы справочника
*/
$sTableName = $arHighloadProperty['USER_TYPE_SETTINGS']['TABLE_NAME'];
if ( !empty($sTableName) && !empty($arHighloadProperty["VALUE"]) )
{
/**
* @var array Описание Highload-блока
*/
$hlblock = HL\HighloadBlockTable::getRow([
'filter' => [
'=TABLE_NAME' => $sTableName
],
]);
if ( $hlblock )
{
/**
* Магия highload-блоков компилируем сущность, чтобы мы смогли с ней работать
*
*/
$entity = HL\HighloadBlockTable::compileEntity( $hlblock );
$entityClass = $entity->getDataClass();
$arRecords = $entityClass::getList([
'filter' => [
'UF_XML_ID' => $arHighloadProperty["VALUE"]
],
]);
foreach ($arRecords as $record)
{
/**
* Тут любые преобразования с записью, полученной из таблицы.
* Я транслировал почти все напрямую.
*
* Нужно помнить, что например в UF_FILE возвращается ID файла,
* а не полный массив описывающий файл
*/
$arRecord = [
'ID' => $record['ID'],
'UF_NAME' => $record['UF_NAME'],
'UF_SORT' => $record['UF_SORT'],
'UF_XML_ID' => $record['UF_XML_ID'],
'UF_LINK' => $record['UF_LINK'],
'UF_DESCRIPTION' => $record['UF_DESCRIPTION'],
'UF_FULL_DESCRIPTION' => $record['UF_FULL_DESCRIPTION'],
'UF_DEF' => $record['UF_DEF'],
'UF_FILE' => [],
'~UF_FILE' => $record['UF_FILE'],
];
/**
* Не очень быстрое решение - сколько записей в инфоблоке, столько файлов и получим
* Хорошо было бы вынести под код и там за 1 запрос все получить, а не плодить
* по дополнительному запросу на каждый файл
*/
if ( !empty($arRecord['~UF_FILE']) )
{
$arRecord['UF_FILE'] = \CFile::getById($arRecord['~UF_FILE'])->fetch();
}
//$arResult["PROPERTIES"][$key]['EXTRA_VALUE'][] = $arRecord;
$arHighloadProperty['EXTRA_VALUE'][] = $arRecord;
}
}
}
}
}
$arHighloadProperty['EXTRA_VALUE'][] = $arRecord;
$arResult["PROPERTIES"]['TEST']['EXTRA_VALUE'][] = $arRecord;
но сами картинки выбрать будет нельзя, только править код (ссылки на изображения, которые сначала загрузить нужно), верно?
Я думал, что можно создать инфоблок по типу слайдера, где будет привязка к разделу нужному
Array("CODE"=>["CML2_ARTICLE","CML2_BAR_CODE"]));
if($ar_props = $db_props->Fetch())
$arFields["TITLE"] .= " ".$ar_props["VALUE"]; // Добавим свойство в конец заголовка индексируемого элемента
while( $ar_props = $db_props->Fetch() )
{
$arFields["TITLE"] .= " ".$ar_props["VALUE"];
}
2) Кеш сбрасывали?