Пункт контекстного меню сообщения IM_CONTEXT_MENU
Scope:
im
Вы можете добавить свой пункт в контекстное меню сообщения в чате.
Код места встройки указывается в параметре PLACEMENT метода placement.bind.
Встройка не отображается в интерфейсе, пока установка приложения не завершена. Проверьте установку приложения
Куда встраивается виджет
|
Код встройки |
Место |
|
|
Пункт контекстного меню сообщения |
Где находится в интерфейсе
Откройте любой чат и наведите курсор на сообщение. В строке действий сообщения нажмите кнопку ... и откройте контекстное меню. Наведите курсор на Еще, чтобы открыть дополнительные пункты меню. Пункт приложения с PLACEMENT=IM_CONTEXT_MENU отображается в конце списка действий над сообщением.
Что получает обработчик
Данные передаются в виде POST-запроса
Array
(
[DOMAIN] => xxx.bitrix24.com
[PROTOCOL] => 1
[LANG] => ru
[APP_SID] => 99c80eff6378726287350416ee5fef0
[AUTH_ID] => 6061e72600631fcd00005a4b00000001f0f1076700000000f69dd5fc643d9ce2fdbc1
[AUTH_EXPIRES] => 3600
[REFRESH_ID] => 50e00aa340631fcd00005a4b00000001f0f1071111116580a5b83c2de639ef28c12
[member_id] => da45a03b265ed12127f8a258d793cc5d
[status] => F
[PLACEMENT] => IM_CONTEXT_MENU
[PLACEMENT_OPTIONS] => {"messageId":84889, "dialogId":"chat1489"}
)
Обязательные параметры отмечены *
|
Параметр |
Описание |
|
DOMAIN* |
Адрес Битрикс24, на котором был вызван обрабтчик виджета |
|
PROTOCOL* |
Защищенный или не защищенный протокол HTTP:
|
|
LANG* |
Язык интерфейса пользователя Битрикс24, который вызвал виджет. Вы можете локализовать язык интерфейса в своём виджете, ориентируясь на это значение |
|
APP_SID |
Строковый идентификатор приложения, зарегистрировавшего обработчик виджета |
|
AUTH_ID |
Авторизационный токен OAuth 2, выписанный для пользователя, вызвавшего виджет. Можно использовать для вызовов REST API от лица этого пользователя |
|
AUTH_EXPIRES |
Время в секундах, после которого авторизационный токен станет неактуальным |
|
REFRESH_ID |
Refresh-токен OAuth 2, выписанный для пользователя, вызвавшего виджет. Можно использовать для обновления авторизационного токена от лица этого пользователя |
|
member_id* |
Уникальный строковый идентификатор Битрикс24, на котором был вызван обработчик виджета. |
|
status |
Тип приложения, зарегистрировавшего обработчик данного виджета. Принимает значения:
|
|
PLACEMENT* |
Код места встройки виджета. Вы можете использовать один и тот же URL обработчика для всех своих виджетов. Значение, которое Битрикс24 будет сообщать в параметре |
|
PLACEMENT_OPTIONS |
Дополнительные данные в виде JSON-строки, определяющие контекст выполнения виджета. Например, это может быть массив, содержащий числовой идентификатор элемента CRM, в карточке которого был вызван обработчик виджета, и т.д. Параметр |
PLACEMENT_OPTIONS
Значение PLACEMENT_OPTIONS передается как JSON-строка с контекстом вызова.
Для IM_CONTEXT_MENU в контекст передаются ключи:
dialogId— идентификатор текущего чатаmessageId— идентификатор выбранного сообщения
OPTIONS при регистрации через placement.bind
Для IM_CONTEXT_MENU метод placement.bind поддерживает параметры OPTIONS.
|
Параметр |
Описание |
|
extranet |
Доступ в экстранете, по умолчанию Возможные значения:
|
|
context |
Контекст показа, по умолчанию Возможные значения:
Если передан |
|
role |
Роль пользователя, по умолчанию Возможные значения:
|
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{
"PLACEMENT": "IM_CONTEXT_MENU",
"HANDLER": "https://your-domain.com/widgets/im-context-menu-handler.php",
"TITLE": "Мой пункт меню",
"LANG_ALL": {
"ru": {
"TITLE": "Мой пункт меню"
},
"en": {
"TITLE": "My menu item"
}
},
"OPTIONS": {
"context": "ALL",
"role": "USER",
"extranet": "N"
},
"auth": "**put_access_token_here**"
}' \
https://**put_your_bitrix24_address**/rest/placement.bind
try
{
const response = await $b24.callMethod(
'placement.bind',
{
PLACEMENT: 'IM_CONTEXT_MENU',
HANDLER: 'https://your-domain.com/widgets/im-context-menu-handler.php',
TITLE: 'Мой пункт меню',
LANG_ALL: {
ru: {
TITLE: 'Мой пункт меню',
},
en: {
TITLE: 'My menu item',
}
},
OPTIONS: {
context: 'ALL',
role: 'USER',
extranet: 'N',
}
}
);
const result = response.getData().result;
if (result.error())
console.error(result.error());
else
console.info(result.data());
}
catch (error)
{
console.error('Error:', error);
}
try {
$response = $b24Service
->core
->call(
'placement.bind',
[
'PLACEMENT' => 'IM_CONTEXT_MENU',
'HANDLER' => 'https://your-domain.com/widgets/im-context-menu-handler.php',
'TITLE' => 'Мой пункт меню',
'LANG_ALL' => [
'ru' => [
'TITLE' => 'Мой пункт меню',
],
'en' => [
'TITLE' => 'My menu item',
],
],
'OPTIONS' => [
'context' => 'ALL',
'role' => 'USER',
'extranet' => 'N',
],
]
);
$result = $response->getResponseData()->getResult();
if ($result->error()) {
error_log($result->error());
} else {
echo 'Success: ' . print_r($result->data(), true);
}
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error binding placement: ' . $e->getMessage();
}
BX24.callMethod(
'placement.bind',
{
PLACEMENT: 'IM_CONTEXT_MENU',
HANDLER: 'https://your-domain.com/widgets/im-context-menu-handler.php',
TITLE: 'Мой пункт меню',
LANG_ALL: {
ru: { TITLE: 'Мой пункт меню' },
en: { TITLE: 'My menu item' }
},
OPTIONS: {
context: 'ALL',
role: 'USER',
extranet: 'N'
}
},
function(result) {
if (result.error()) {
console.error(result.error());
} else {
console.log(result.data());
}
}
);
require_once('crest.php');
$result = CRest::call(
'placement.bind',
[
'PLACEMENT' => 'IM_CONTEXT_MENU',
'HANDLER' => 'https://your-domain.com/widgets/im-context-menu-handler.php',
'TITLE' => 'Мой пункт меню',
'LANG_ALL' => [
'ru' => [
'TITLE' => 'Мой пункт меню',
],
'en' => [
'TITLE' => 'My menu item',
],
],
'OPTIONS' => [
'context' => 'ALL',
'role' => 'USER',
'extranet' => 'N',
],
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Продолжите изучение
- Установить обработчик виджета placement.bind
- Взаимодействие с UI из виджетов
- Интерактивные приложения
- Открыть слайдер со своим интерфейсом
- Открыть стандартные страницы Битрикс24 из виджетов приложений