Сохранить в список блоков landing.landing.favoriteBlock
Scope:
landingКто может выполнять метод: пользователь с правом «редактирование» сайта
Метод landing.landing.favoriteBlock создает копию блока страницы и сохраняет ее в список блоков как шаблон. При успешном выполнении метод возвращает идентификатор новой копии блока.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
lid* |
Идентификатор страницы. Идентификатор страницы можно получить методом landing.landing.getList, а также из результата методов landing.landing.add, landing.landing.addByTemplate и landing.landing.copy |
|
block* |
Идентификатор блока. Идентификатор блока можно получить методом landing.block.getList с параметром |
|
meta |
Параметры сохраненного блока (подробное описание). Если параметр не передан, метод сохраняет копию блока без дополнительных переопределений |
Параметр meta
|
Название |
Описание |
|
name |
Название сохраненной копии блока в списке блоков. Это пользовательское название сохраненной копии. Оно не заменяет стандартное название блока. Если параметр не передан, используется исходное название блока |
|
Раздел или список разделов, в которых будет показан сохраненный блок. Если параметр не передан, блок будет показан в тех же разделах, что и исходный блок. Можно использовать коды разделов из метода landing.block.getrepository. Если передать код, которого нет в стандартном репозитории, для него будет создан отдельный раздел |
|
|
preview |
Идентификатор файла картинки превью. Передайте ID файла с картинкой, заранее загруженного методом landing.block.uploadfile для исходного блока. Метод сохраняет этот ID как превью сохраненной копии блока. Если файл уже привязан к исходному блоку как пользовательское превью, эта привязка изменится только после успешного завершения метода. Если метод завершится ошибкой, привязка к исходному блоку не изменится. Если параметр не передан или равен |
|
tpl_code |
Код шаблона страницы, с которым нужно связать сохраненный блок. Передача этого параметра эквивалентна включенному чекбоксу «Привязать к текущему стилю» в редакторе. Значение можно взять из поля Этот параметр сохраняется вместе с метаданными сохраненного блока и используется редактором при работе с такими блоками. Если параметр не передан, специальная привязка к коду шаблона не сохраняется |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-d '{
"lid": 351,
"block": 6428,
"meta": {
"name": "Блок с преимуществами",
"section": ["text", "features"],
"preview": 918273,
"tpl_code": "bitrix24"
}
}' \
"https://**put.your-domain-here**/rest/**user_id**/**webhook_code**/landing.landing.favoriteBlock.json"
curl -X POST \
-H "Content-Type: application/json" \
-d '{
"lid": 351,
"block": 6428,
"meta": {
"name": "Блок с преимуществами",
"section": ["text", "features"],
"preview": 918273,
"tpl_code": "bitrix24"
},
"auth": "**put_access_token_here**"
}' \
"https://**put.your-domain-here**/rest/landing.landing.favoriteBlock.json"
try
{
const response = await $b24.callMethod(
'landing.landing.favoriteBlock',
{
lid: 351,
block: 6428,
meta: {
name: 'Блок с преимуществами',
section: ['text', 'features'],
preview: 918273,
tpl_code: 'bitrix24'
}
}
);
const result = response.getData().result;
console.info('ID сохраненной копии:', result);
}
catch (error)
{
console.error(error);
}
try {
$response = $b24Service
->core
->call(
'landing.landing.favoriteBlock',
[
'lid' => 351,
'block' => 6428,
'meta' => [
'name' => 'Блок с преимуществами',
'section' => ['text', 'features'],
'preview' => 918273,
'tpl_code' => 'bitrix24',
],
]
);
$result = $response
->getResponseData()
->getResult();
echo 'Успех: ' . var_export($result, true);
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Ошибка при сохранении блока в список блоков: ' . $e->getMessage();
}
BX24.callMethod(
'landing.landing.favoriteBlock',
{
lid: 351,
block: 6428,
meta: {
name: 'Блок с преимуществами',
section: ['text', 'features'],
preview: 918273,
tpl_code: 'bitrix24'
}
},
function(result)
{
if (result.error())
{
console.error(result.error());
}
else
{
console.info('ID сохраненной копии:', result.data());
}
}
);
require_once('crest.php');
$result = CRest::call(
'landing.landing.favoriteBlock',
[
'lid' => 351,
'block' => 6428,
'meta' => [
'name' => 'Блок с преимуществами',
'section' => ['text', 'features'],
'preview' => 918273,
'tpl_code' => 'bitrix24',
],
]
);
if (isset($result['error']))
{
echo 'Ошибка: ' . $result['error_description'];
}
else
{
echo '<pre>';
print_r($result['result']);
echo '</pre>';
}
Обработка ответа
HTTP-статус: 200
{
"result": 28619,
"time": {
"start": 1773958609,
"finish": 1773958609.566006,
"duration": 0.5660059452056885,
"processing": 0,
"date_start": "2026-03-20T01:16:49+03:00",
"date_finish": "2026-03-20T01:16:49+03:00",
"operating_reset_at": 1773959209,
"operating": 0.21611928939819336
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Идентификатор сохраненной копии блока |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "BLOCK_NOT_FOUND",
"error_description": "Блок не найден в лендинге"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
|
|
Не передан обязательный параметр |
|
|
Передан неверный тип в параметре |
|
|
Страница не найдена или недоступна текущему пользователю. Ошибка может относиться как к странице |
|
|
Блок с идентификатором |
|
|
Не удалось создать копию блока в репозитории блоков |
|
|
Версия блока не поддерживается текущей версией продукта |
|
|
Недостаточно прав на изменение блока |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Добавить блок на страницу `landing.landing.addblock`
- Копировать блок на страницу `landing.landing.copyblock`
- Удалить блок со страницы `landing.landing.deleteblock`
- Переместить блок ниже `landing.landing.downblock`
- Скрыть блок на странице `landing.landing.hideblock`
- Отметить блок как удаленный `landing.landing.markdeletedblock`
- Снять отметку удаления с блока `landing.landing.markundeletedblock`
- Переместить блок на страницу `landing.landing.moveblock`
- Показать блок на странице `landing.landing.showblock`
- Удалить из сохраненного списка блоков `landing.landing.unFavoriteBlock`
- Переместить блок выше `landing.landing.upblock`