first commit

This commit is contained in:
2025-05-26 16:15:30 +04:00
commit a6b05d6789
6059 changed files with 495628 additions and 0 deletions

View File

@ -0,0 +1,280 @@
<!DOCTYPE html>
<html lang="ru">
<head>
<title>Обработка событий в модулях</title>
<meta name="generator" content="Help+Manual" />
<meta name="keywords" content="" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="В рамках модуля вы можете настроить обработку различных событий системы." />
<meta name="picture" content="" />
<meta property="og:type" content="website" />
<meta property="og:title" content="Cправка по Low-code платформе ELMA365" />
<meta property="og:url" content="https://elma365.com/ru/help" />
<meta property="og:image" content="" />
<meta property="og:site_name" content="ELMA365" />
<link rel="icon" href="favicon.png" type="image/png" />
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet" />
<link rel="stylesheet" href="./jquery-ui.min.css" />
<link rel="stylesheet" href="default.css" />
<link rel="stylesheet" href="./search-yandex.css" />
<link rel="stylesheet" href="./article.css" />
<link rel="stylesheet" href="./glossary.css" />
<link rel="stylesheet" href="./theme.css" />
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="helpman_settings.js"></script>
<script type="text/javascript" src="helpman_topicinit.js"></script>
<script type="text/javascript" src="highlight.js"></script>
<script type="text/javascript">
$(document).ready(function(){highlight();});
</script>
</head>
<body>
<script async src="https://www.googletagmanager.com/gtag/js?id=G-M6ETBEC1R9"></script><script>window.dataLayer=window.dataLayer || []; function gtag(){dataLayer.push(arguments);}gtag('js', new Date()); gtag('config', 'G-M6ETBEC1R9');</script>
<script>!function(e,t,c,n,r,a,m){e.ym=e.ym||function(){(e.ym.a=e.ym.a||[]).push(arguments)},e.ym.l=1*new Date;for(var s=0;s<document.scripts.length;s++)if(document.scripts[s].src===n)return;a=t.createElement(c),m=t.getElementsByTagName(c)[0],a.async=1,a.src=n,m.parentNode.insertBefore(a,m)}(window,document,"script","https://mc.yandex.ru/metrika/tag.js"),ym(83179930,"init",{clickmap:!0,trackLinks:!0,accurateTrackBounce:!0,webvisor:!0})</script><noscript><div><img alt=""src=https://mc.yandex.ru/watch/83179930 style=position:absolute;left:-9999px></div></noscript>
<header class="header elma-365">
<div class="container">
<a class="header__logo" href="https://elma365.com/ru/help">
<img src="./logo.svg" alt="header logo">
</a>
<!-- <div class="hero__search-form" id="search-panel">
<form class="search-form" onsubmit="ym(83179930,'reachGoal','poisk')">
<label class="search-form__label">
<span id="reset-search" class="search__icon"></span>
<input class="search-form__input" type="text">
</label>
<input class="search-form__submit" type="submit" value="Submit">
</form>
</div> -->
<div class="hero__search-form" id="search-panel"> <form class="search-form"> <label class="search-form__label"> <span id="reset-search" class="search__icon"></span> <input class="search-form__input" type="text"> </label> <input class="search-form__submit" type="submit" value="Submit"> </form> </div>
<div class="hero__search">
<a href="#" id="search-icon" class="hero__search-icon">
<img src="search-icon-white.svg" alt="search string">
</a>
<a href="#" id="side-menu-icon" class="hero__side-icon">
<img src="side_menu.svg" alt="side menu">
</a>
</div>
<div class="header__navi">
<ul class="header__list"><li><span class="solution-select"><span class="solution-select__selected"></span><svg width="7" height="4" viewBox="0 0 7 4" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1L3.5 3.5L6 1" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg><ul class="solution-select__list"><li><a class="project-link" href="https://elma365.com/ru/help/platform/get-trial.html">Платформа</a></li><li><a class="project-link" href="https://elma365.com/ru/help/ecm/ecm-functions.html">ECM</a></li><li><a class="project-link" href="https://elma365.com/ru/help/crm/crm_overview.html">CRM</a></li><li><a class="project-link" href="https://elma365.com/ru/help/service/service-functions.html">Service</a></li><li><a class="project-link" href="https://elma365.com/ru/help/projects/projects-functions.html">Проекты</a></li><li><a class="project-link" href="https://elma365.com/ru/help/business_solutions/-elma365-store.html">Бизнес-решения</a></li></ul></span></li><li><a href="https://api.elma365.com/ru/"target="_blank">API</a></li><li><a href="https://tssdk.elma365.com/"target="_blank">SDK</a></li><li><a href="https://community.elma365.com/" target="_blank">Community</a></li><li><a href="https://elma-academy.com/ru/" target="_blank">Академия</a></li><li><a href="https://elma365.com/ru/" target="_blank">Сайт ELMA365</a></li></ul>
</div>
</div>
</header>
<main class="main container">
<aside class="sidebar" id="sidebar">
<div class="sidebar__header">
<a class="header__logo" href="https://elma365.com/ru/help">
<img src="./logo-light.svg">
</a>
<span class="sidebar__close elma-365-close" id="close"></span>
</div>
<div class="sidebar__wrapper" id="side-menu">
</div>
</aside>
<article class="article" id="article">
<div class="article-inner">
<div class="content">
<header class="article__header">
<div class="article__bread" style="display:flex; gap:10px;">
<span id="subcategory" class="search-res__item-category search-res__item-category_subcategory subcategory article__badge"></span>
<div class="topic__breadcrumbs">
<p><a href="360024498352.html">Модули расширения системы</a> &gt; <a href="extentions.html">Пользовательские модули</a> / Обработка событий в модулях</p>
</div>
</div>
<div class="topic__title"><h1 class="p_Heading1"><span class="f_Heading1">Обработка событий в модулях</span></h1>
</div>
</header>
<section class="article__content">
<div class="scroll-top-inner">
<a href="#h1-article" class="scroll-top"></a>
</div>
<!-- Placeholder for topic body. -->
<p style="line-height: 1.28; margin: 0 0 11px 0;">В рамках модуля вы можете настроить обработку различных событий системы.</p>
<p style="line-height: 1.28; margin: 0 0 11px 0;"><span style="font-weight: bold;">Обработчик события</span> запускает определённое действие в системе после того, как событие произошло. Это удобно при разработке комплексных модулей.</p>
<p class="p_Normal">При наступлении события в системе может:</p>
<ul style="list-style-type:disc">
<li class="p_Normal">выполняться <span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="type-script.html" class="topiclink">скрипт</a></span>, созданный в обработчике;</li><li class="p_Normal">запускаться <span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="extention-processes.html" class="topiclink">бизнес-процесс, настроенный на уровне модуля</a></span>;</li><li class="p_Normal">отправляться сообщение во <span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="custom_services.html" class="topiclink">внешний микросервис</a></span>. Доступно только в <a href="elma365-on-premises.html" class="topiclink">ELMA365 OnPremises</a>.</li></ul>
<p class="p_Normal">Например, в модуле можно создать обработчик, который запускает процесс после редактирования пользователем элемента приложения.</p>
<h2 class="p_Heading2"><a id="create-event-handler" class="hmanchor"></a><span class="f_Heading2">Создать обработчик событий</span></h2>
<ol style="list-style-type:upper-roman">
<li value="1" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Перейдите в <span style="font-weight: bold;">Администрирование</span> <span style="font-weight: bold;">&gt;</span> <span style="font-weight: bold;">Модули</span>.</li><li value="2" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Наведите курсор на модуль и нажмите на появившийся значок шестерёнки.</li><li value="3" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Перейдите на вкладку <span style="font-weight: bold;">Обработка событий</span>.</li><li value="4" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Нажмите кнопку <span style="font-weight: bold;">+ Обработчик </span>и задайте необходимые настройки в открывшемся окне. </li></ol>
<p style="line-height: 1.28; margin: 0 0 11px 36px;"><img alt="events_processing-1" width="596" height="328" style="margin:0;width:596px;height:328px;border:none" src="events_processing-1.png"/></p>
<ul style="list-style-type:disc">
<li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Название</span><span style="font-size: 15px; font-weight: bold; color: #ff0000;">* </span>— укажите название обработчика;</li><li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Тип обработчика</span><span style="font-size: 15px; font-weight: bold; color: #ff0000;">*</span> — выберите действие, которое будет совершаться при выполнении события:<ul style="list-style-type:circle">
<li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-size: 13px; font-weight: bold;">Запуск скрипта</span><span style="font-size: 13px;"></span><span style="color: #394149;">выполняет </span><span style="font-size: 15px; font-family: Inter;">скрипт, созданный в обработчике</span><span style="color: #394149;">;</span></li><li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-size: 13px; font-weight: bold;">Запуск процесса</span><span style="font-size: 13px;"></span><span style="color: #394149;">запускает бизнес-процесс, созданный в модуле на вкладке </span><span style="font-weight: bold; color: #394149;">Процессы</span><span style="color: #394149;">;</span></li><li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-size: 13px; font-weight: bold;">Передача сообщения в сервис</span><span style="font-size: 13px;"> — отправляет сообщение во внешний микросервис. Действие доступно только в </span><a href="elma365-on-premises.html" class="topiclink">ELMA365 OnPremises</a>.</li></ul>
<li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><a id="domain" class="hmanchor"></a><span style="font-size: 15px; font-weight: bold;">Домен события</span><span style="font-size: 15px; font-weight: bold; color: #ff0000;"> </span>— выберите область, события в которой будет отслеживать обработчик. Вы можете выбрать следующие домены:<ul style="list-style-type:circle">
<li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Все события</span><span style="color: #394149;">;</span></li><li class="p_Normal"><a id="object-type" class="hmanchor"></a><span style="font-weight: bold;">Элементы приложения</span> — в появившемся поле <span style="font-weight: bold;">Фильтр типа объекта</span> выберите приложение, события которого будут обрабатываться. Если приложение не указывать, обработчик в модуле будет отслеживать события всех существующих в системе приложений. Можно фиксировать создание, обновление, изменение статуса, удаление элемента, а также добавления комментариев в его ленте.</li></ul></li></ul>
<p class="p_Normal" style="margin: 0 0 0 58px;">Если вы установили отслеживание событий создания, обновления или удаления элемента и указали приложение, то в скрипт добавляется свойство <code><b>EventContext</b></code>. Оно содержит строго типизированные данные элемента приложения и соответствующего события.</p>
<p class="p_Normal" style="margin: 0 0 0 58px;">Обратите внимание, модуль с созданным обработчиком и указанным в нём приложением, нельзя <a href="export_extention.html" class="topiclink">экспортировать</a>. Вы можете <a href="create-solution.html" class="topiclink">создать решение</a> и выгрузить модуль и приложение в его составе;</p>
<ul style="list-style-type:disc"><ul style="list-style-type:circle">
<li class="p_Normal"><span style="font-weight: bold;">Задачи</span> — домен доступен при активированном <a href="licenses-crm.html" class="topiclink">платном решении CRM</a>, в котором включено использование <a href="/ru/help/crm/360012911980.html" target="_blank" class="weblink">задач CRM</a>. Обработчик фиксирует события, связанные с созданием, изменением, отменой или завершением задач CRM. В появившемся поле <span style="font-weight: bold;">Фильтр типа задачи</span> укажите тип задачи, изменения в которой будут отслеживаться модулем:<span style="font-weight: bold;"> Все задачи CRM</span>, <span style="font-weight: bold;">Звонок</span>, <span style="font-weight: bold;">Письмо</span>, <span style="font-weight: bold;">Вебинар</span>, <span style="font-weight: bold;">Встреча</span>. Подробнее о настройке обработчика этого типа читайте в статье <a href="/ru/help/crm/crm-events-processing.html" target="_blank" class="weblink">«Обработка событий в задачах CRM»</a>; </li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Приложения</span> — обработчик отслеживает события экспорта или импорта данных из приложений системы;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Файлы</span> — позволяет фиксировать создание, редактирование, удаление файла, добавление к нему комментариев и изменение настроек доступа;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Директории</span> — отслеживает создание, редактирование, удаление и изменение настроек доступа для папок в разделе <span style="font-weight: bold;">Файлы</span>;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><a id="duplicates" class="hmanchor"></a><span style="font-weight: bold;">Дубли</span> — настроить обработчик можно при активированном <a href="licenses-crm.html" class="topiclink">платном решении CRM</a>, в котором включён поиск дублей, т. е. элементов приложения с одинаковыми данными. Действие в обработчике запускается при объединении записей-дубликатов. Пример такого обработчика можно посмотреть в статье <a href="/ru/help/crm/duplicates-events-processing.html" target="_blank" class="weblink">«Обработка событий в дублях»</a>;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Модули</span> — позволяет отследить:<ul style="list-style-type:square">
<li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;">включение и выключение модулей;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;">установку и обновление модулей. Обратите внимание, эти события фиксируются, только если обработчик уже есть в системе, а не во время его добавления в составе модуля;</li></ul>
<li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Настройки</span> — фиксируется редактирование <a href="360009207779.html" class="topiclink">дополнительных параметров</a>, настроенных на уровне компании, раздела или приложения;</li><li style="background: #ffffff; margin-top: 0; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Пользователи</span> — отслеживаются события, связанные с <a href="360004833572.html" class="topiclink">управлением аккаунтом пользователя</a>, а также действия самого пользователя, например, изменение статуса, ошибка авторизации, выход из системы и т. д.</li></ul></li></ul>
<ul style="list-style-type:disc">
<li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Динамически вычислять тип события скриптом</span> — опция доступна, если выбран домен <span style="font-weight: bold;">Все события</span> или <span style="font-weight: bold;">Элементы приложений</span>. При её включении обработчик может отслеживать сразу несколько типов событий, которые задаются в <a href="events_processing.html#dynamic-filtering-script" class="topiclink">скрипте фильтрации</a>. Фильтрация событий выполняется до запуска самого обработчика. Например, вы можете настроить один обработчик для отслеживания событий по элементам разных приложений;</li></ul>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">начало&nbsp;внимание</span></p>
<p style="line-height: 1.28; margin: 0 0 11px 0;"><span style="font-size: 15px; font-family: Inter;">Фильтрация событий доступна по умолчанию в ELMA365 SaaS и OnPremises начиная с версии системы 2025.1. Вы можете использовать её в поставке OnPremises версии 2024.11, включив фича‑флаг </span><b><code>enableEventBusDynamicFiltration</code></b><span style="font-size: 15px; font-family: Inter;">. Подробнее читайте в статьях </span><span style="font-size: 15px; font-family: Inter; color: #0000ff;"><a href="change-settings-enterprise.html#enable-feature-flag-enterpeise" class="topiclink">«Изменение параметров ELMA365 Enterprise»</a></span><span style="font-size: 15px; font-family: Inter;"> и </span><span style="font-size: 15px; font-family: Inter; color: #0000ff;"><a href="change-elma365standard-parameters.html#enable-feature-flag-standard" class="topiclink">«Изменение параметров ELMA365 Standard»</a></span><span style="font-size: 15px; font-family: Inter;">.</span></p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">конец&nbsp;внимание</span></p>
<ul style="list-style-type:disc">
<li style="background: #ffffff; margin-top: 14px; margin-right: 0; margin-bottom: 0;"><span style="font-weight: bold;">Событие </span>— выберите событие, после которого будет запускаться обработчик. <span style="font-size: 15px; font-family: Inter;">При включении динамического вычисления типа событий поле не отображается, так как события для отслеживания задаются в скрипте.</span></li></ul>
<ol style="list-style-type:upper-roman" start="5">
<li value="5" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Нажмите кнопку <span style="font-weight: bold;">Создать</span>.</li><li value="6" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><a id="access-to-global-constants" class="hmanchor"></a>В открывшемся окне:</li></ol>
<ol style="list-style-type:upper-roman" start="5"><ul style="list-style-type:disc">
<li style="margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter;">для типа </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Запуск скрипта</span><span style="font-size: 15px; font-family: Inter;"> — напишите скрипт на вкладке </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Скрипты</span><span style="font-size: 15px; font-family: Inter;">. Вы можете получить доступ к переменным из других разделов и пользовательских модулей, настроив </span><span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="optional-dependencies.html" class="topiclink">опциональные зависимости</a></span><span style="font-size: 15px; font-family: Inter;">.</span></li></ul></li></ol>
<p style="line-height: 1.28; margin: 0 0 11px 29px;"><span style="font-size: 15px; font-family: Inter;">Для создания зависимости на верхней панели нажмите </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Настройки</span><span style="font-size: 15px; font-family: Inter;"> и добавьте разделы и модули в список. После этого к ним можно обращаться через глобальную константу </span><span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="optional-dependencies.html#use-imports" class="topiclink">Imports</a></span><span style="font-size: 15px; font-family: Inter;">. Модуль с опциональными зависимостями можно экспортировать без ограничений;</span></p>
<p style="margin: 0 0 11px 29px;"><img alt="events_processing-4" width="1048" height="298" style="margin:0;width:1048px;height:298px;border:none" src="events_processing-4.png"/></p>
<ol style="list-style-type:upper-roman" start="5"><ul style="list-style-type:disc">
<li style="margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter;">для типа </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Запуск процесса</span><span style="font-size: 15px; font-family: Inter;"> — выберите бизнес-процесс, созданный на уровне модуля. Затем на вкладке </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Входные переменные</span><span style="font-size: 15px; font-family: Inter;"> сопоставьте переменные из контекста процесса со свойствами события: объект, название, автор и т. д.</span></li></ul></li></ol>
<p style="margin: 0 0 11px 24px;">Для событий предусмотрен ограниченный набор системных полей: идентификатор, название, описание, время события, название объекта, автор и т. д. Также для каждого события есть индивидуальные свойства, отсылающие к выбранному домену и типу действия.</p>
<p style="margin: 0 0 11px 26px;">Настройка на вкладке <span style="font-weight: bold;">Входные переменные</span> позволяет определить<span style="color: #394149;"> источники данных для свойств из контекста процесса. Она</span> выполняется в зависимости от реализуемого обработчика и конечной потребности пользователя.</p>
<p style="line-height: 1.28; margin: 0 0 11px 27px;"><img alt="events_peocessing-2" width="758" height="366" style="margin:0;width:758px;height:366px;border:none" src="events_peocessing-2.png"/></p>
<p style="margin: 0 0 11px 23px;"><span style="font-weight: bold;">Важно</span>:<span style="font-weight: bold;"> </span>на вкладке <span style="font-weight: bold;">Входные переменные</span> отображаются свойства, присутствующие в контексте процесса в момент его привязки к обработчику. Если контекст процесса был изменён, новые переменные не появятся в настройках обработчика. Необходимо повторно создать и настроить обработчик событий, привязав к нему тот же самый бизнес‑процесс.</p>
<ol style="list-style-type:upper-roman" start="5"><ul style="list-style-type:disc">
<li style="margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter;">для типа </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Передача сообщения в сервис</span><span style="font-size: 15px; font-family: Inter;"> — укажите микросервис.</span></li></ul></li></ol>
<ol style="list-style-type:upper-roman" start="5">
<li value="7" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><a id="dynamic-filtering-script" class="hmanchor"></a>Если вы включили динамическое вычисление типа события, задайте фильтр для отбора событий, которые отслеживает обработчик. Для этого на вкладке <span style="font-weight: bold;">Настройки</span> нажмите ссылку <span style="font-weight: bold;">Вычисляется скриптом</span>.</li></ol>
<p style="line-height: 1.28; margin: 0 0 11px 34px;"><img alt="events_processing-5" width="693" height="278" style="margin:0;width:693px;height:278px;border:none" src="events_processing-5.png"/></p>
<p style="line-height: 1.28; margin: 0 0 11px 34px;"><span style="font-size: 15px; font-family: Inter;">Откроется вкладка </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Скрипты</span><span style="font-size: 15px; font-family: Inter;">. В методе </span><code><b>filter()</b></code><span style="font-size: 15px; font-family: 'Courier New',Courier,monospace; font-weight: bold;"> </span><span style="font-size: 15px; font-family: Inter;">укажите типы событий для отслеживания. Доступные варианты зависят от домена, выбранного при создании обработчика:</span></p>
<ul style="list-style-type:disc">
<li style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Все события</span><span style="font-size: 15px; font-family: Inter;"> — можно указать типы событий из различных доменов. Их список ограничен. При создании фильтра вы увидите подсказки с возможными значениями;</span></li><li style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Элементы приложений</span><span style="font-size: 15px; font-family: Inter;"> — доступны только события по элементам приложений.</span></li></ul>
<p style="line-height: 1.28; margin: 0 0 11px 34px;"><span style="font-size: 15px; font-family: Inter;">Подробнее о написании скрипта и особенностях динамической фильтрации читайте в </span><span style="font-size: 15px; font-family: Inter; color: #0563c1;"><a href="https://tssdk.elma365.com/ru/latest/pages/quick-start/intro_dynamic-filtration.html" target="_blank" class="weblink">справке ELMA365 TS SDK</a></span><span style="font-size: 15px; font-family: Inter;">.</span></p>
<p style="line-height: 1.28; margin: 0 0 11px 34px;"><span style="font-size: 15px; font-family: Inter;">Сформированный фильтр применится после публикации обработчика событий и включения модуля. Обработчик будет запускаться по событиям системы, которые подходят под заданные условия.</span></p>
<ol style="list-style-type:upper-roman" start="5">
<li value="8" style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;">Опубликуйте обработчик. </li></ol>
<p style="line-height: 1.28; margin: 0 0 11px 0;">Таким образом в пользовательском модуле можно добавить несколько обработчиков событий. Например, при смене статуса элементов приложения <span style="font-weight: bold;">Заказы</span> будет запускаться бизнес‑процесс обработки. При этом с помощью <a href="360027203731.html" class="topiclink">скрипта</a> или <a href="360012495911.html" class="topiclink">шлюза</a> можно настроить разные ветки хода процесса в зависимости от статуса элемента. </p>
<p style="margin: 0 0 11px 0;">В ELMA365 Community вы можете ознакомиться с настройкой обработчиков на примерах:</p>
<ul style="list-style-type:disc">
<li style="margin-top: 0; margin-right: 0; margin-bottom: 11px;"><a href="https://community.elma365.com/ru/threads/96/" target="_blank" class="weblink">отслеживание изменения значений в свойствах элементов приложения</a>;</li><li style="margin-top: 0; margin-right: 0; margin-bottom: 11px;"><a href="https://community.elma365.com/ru/threads/2793/" target="_blank" class="weblink">отправка письма на электронную почту при изменении статуса элемента приложения</a>.</li></ul>
<p style="margin: 0 0 11px 0;">Кроме того, с использованием обработчиков с доменами, доступными только при активированном решении <span style="font-weight: bold;">CRM</span>, можно ознакомиться в статьях <a href="/ru/help/crm/crm-events-processing.html" target="_blank" class="weblink">«Обработка событий в задачах CRM»</a>, <a href="/ru/help/crm/duplicates-events-processing.html" target="_blank" class="weblink">«Обработка событий в дублях»</a>.</p>
<h2 class="p_Heading2"><a id="tracing" class="hmanchor"></a><span class="f_Heading2">Трассировка скрипта обработчика </span></h2>
<p style="line-height: 1.28; margin: 0 0 11px 0;"><span style="font-size: 15px; font-family: Inter;">Если для обработчика типа </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Запуск скрипта</span><span style="font-size: 15px; font-family: Inter;"> включён сбор трейсов в разделе </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Администрирование &gt; Инструменты разработчика</span><span style="font-size: 15px; font-family: Inter;">, вы можете проанализировать выполнение его скрипта. Это позволяет оценить продолжительность отдельных запросов, оптимизировать код и выявить причины ошибок.</span></p>
<p style="line-height: 1.28; margin: 0 0 11px 0;"><span style="font-size: 15px; font-family: Inter;">Чтобы изучить трейсы, в настройках модуля откройте вкладку </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Обработка событий</span><span style="font-size: 15px; font-family: Inter;">. Для просмотра записей:</span></p>
<ul style="list-style-type:disc">
<li style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter;">по всем обработчикам в модуле — в правом верхнем углу страницы нажмите </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Посмотреть трассировку</span><span style="font-size: 15px; font-family: Inter;">;</span></li><li style="line-height: 1.28; margin-top: 0; margin-right: 0; margin-bottom: 11px;"><span style="font-size: 15px; font-family: Inter;">по определённому обработчику — нажмите на его название и на верхней панели выберите </span><span style="font-size: 15px; font-family: Inter; font-weight: bold;">Трассировка</span><span style="font-size: 15px; font-family: Inter;">. </span></li></ul>
<p style="line-height: 1.28; margin: 0 0 11px 0;"><span style="font-size: 15px; font-family: Inter;">Подробнее о включении трассировки и информации в карточке трейса читайте в статье </span><span style="font-size: 15px; font-family: Calibri,Vectora,'Droid Sans','Open Sans',Frutiger,sans-serif; color: #0563c1;"><a href="server-script-tracing.html" class="topiclink">«Трассировка серверных скриптов»</a></span><span style="font-size: 15px; font-family: Inter;">.</span></p>
<h2 class="p_Heading2"><span class="f_Heading2">Отменить действие обработчика</span></h2>
<p style="background: #ffffff; margin: 14px 0 0 0;">Чтобы отменить действие обработчика, на вкладке <span style="font-weight: bold;">Обработка событий</span> нажмите на три точки напротив названия созданного обработчика. Затем выберите кнопку <span style="font-weight: bold;">Отмена публикации</span>. При этом после выполнения события действие обработчика не будет совершаться. </p>
<p style="background: #ffffff; margin: 14px 0 0 0;">Кроме того, при необходимости вы можете удалить существующий обработчик событий. Для этого на вкладке <span style="font-weight: bold;">Обработка событий</span> отметьте один или несколько обработчиков в списке. Нажмите кнопку <span style="font-weight: bold;">Удалить</span>, появившуюся в правом верхнем углу страницы. </p>
<p style="background: #ffffff; margin: 14px 0 0 0;"><img alt="events_processing-3" width="798" height="305" style="margin:0;width:798px;height:305px;border:none" src="events_processing-3.png"/></p>
<div class="bottom-nav">
<a id="prev-link" class="topic__navi_prev" href="extention-processes.html">
<span class="bottom-nav__arrow bottom-nav__arrow--prev"></span> <span
class="bottom-nav__link">extention-processes.html</span>
</a>
<a id="next-link" class="topic__navi_next" href="portable-services.html">
<span class="bottom-nav__link">portable-services.html</span> <span
class="bottom-nav__arrow bottom-nav__arrow--next"></span>
</a>
</div>
<!-- добавляет на страницу строку блок Была ли статья полезной? -->
<div class="feedback-wrap"><div class="feedback" id="feedback"><span><b>Была ли статья полезной?</b></span><form action="" method="POST" class="feedback-form" id="feedback-form"><div class="feedback__popup feedback__popup-response" id="feedback__popup_thx">Спасибо за ваш отзыв!</div><div id="feedback-success-popup"><div class="wrap"><button type="button" class="feedback-popup-close">×</button><svg width="44" height="44" viewBox="0 0 44 44" fill="none" xmlns="http://www.w3.org/2000/svg"><g clip-path="url(#clip0_212_2187)"><path d="M22 0.6875C10.2294 0.6875 0.6875 10.2294 0.6875 22C0.6875 33.7706 10.2294 43.3125 22 43.3125C33.7706 43.3125 43.3125 33.7706 43.3125 22C43.3125 10.2294 33.7706 0.6875 22 0.6875ZM22 40.5625C11.8023 40.5625 3.4375 32.3078 3.4375 22C3.4375 11.8024 11.6922 3.4375 22 3.4375C32.1977 3.4375 40.5625 11.6922 40.5625 22C40.5625 32.1976 32.3078 40.5625 22 40.5625ZM34.1713 16.933L18.6613 32.3186C18.257 32.7197 17.604 32.7171 17.203 32.3128L9.82283 24.873C9.42176 24.4686 9.42434 23.8157 9.82867 23.4146L10.5609 22.6884C10.9652 22.2873 11.6181 22.2899 12.0192 22.6942L17.9468 28.6697L31.9926 14.7366C32.3969 14.3356 33.0498 14.3382 33.4509 14.7425L34.1772 15.4747C34.5783 15.879 34.5757 16.532 34.1713 16.933Z" fill="#27AE60"></path></g><defs><clipPath id="clip0_212_2187"><rect width="44" height="44" fill="white"></rect></clipPath></defs></svg><p>Ваш отзыв успешно отправлен!</p><span>Спасибо за обратную связь.</span></div></div><div class="feedback__popup" id="feedback__popup_why"><button type="button" class="feedback-popup-close">×</button><div class="feedback__popup-header">Уточните, почему:</div><input type="radio" name="category" id="bad_recommendation" value="bad_recommendation"><label for="bad_recommendation">Рекомендации не помогли</label><input type="radio" name="category" id="difficult_text" value="difficult_text"><label for="difficult_text">Текст трудно понять</label><input type="radio" name="category" id="no_answer" value="no_answer"><label for="no_answer">Нет ответа на мой вопрос</label><input type="radio" name="category" id="bad_header" value="bad_header"><label for="bad_header">Содержание статьи не соответствует заголовку</label><input type="radio" name="category" id="other_reason" value="other_reason"><label for="other_reason">Другая причина</label></div><div class="feedback__popup" id="feedback__popup-other"><button type="button" class="feedback-popup-close">×</button> <div class="feedback__popup-header">Расскажите, что вам не понравилось в статье:</div><textarea class="feedback__textarea" name="other" id=""></textarea><input type="submit" class="feedback__other-btn" value="Отправить"></div><div class="feedback-form__btn-group"><input type="radio" name="useful" id="feedback__useful_yes" value="true"><label for="feedback__useful_yes"><img src="like.svg"/><span class="feedback-form__btn-group_yes-btn">Да</span></label><input type="radio" name="useful" id="feedback__useful_no" value="false"><label for="feedback__useful_no"><img src="dislike.svg"/><span class="feedback-form__btn-group_no-btn">Нет</span></label></div><select name="category"><option disabled>Выберите вариант</option><option value="bad_recommendation" selected>Рекомендации не помогли</option><option value="difficult_text">Текст трудно понять</option><option value="no_answer">Нет ответа на мой вопрос</option><option value="bad_header">Содержание статьи не соответствует заголовку</option><option value="other_reason">Другая причина</option></select><input type="submit"></form></div></div>
</section>
</div>
<aside class="article__sidebar" style="display:none">
<input type="checkbox" />
<div class="article__arrow"></div>
<div class="table-of-contents elma365-right" id="toc2Content">
<h3 class="h3-toc">В этой статье</h3>
<nav id="toc2"></nav>
</div>
</aside>
</div>
</article>
</main>
<footer class="footer">
<div class="footer-container">
<div class="footer-mobile">
<ul class="footer-mobile__list"><li><a href="https://api.elma365.com/ru/" target="_blank">API</a></li><li><a href="https://tssdk.elma365.com/" target="_blank">TS SDK</a></li><li><a href="https://community.elma365.com/" target="_blank">Community</a></li><li><a href="https://elma-academy.com/ru/elma365" target="_blank">Академия</a></li></ul><ul class="footer-mobile__list"><li><a href="https://elma365.com/ru/help/platform/get-trial.html">Платформа</a></li><li><a href="https://elma365.com/ru/help/ecm/ecm-functions.html">ECM</a></li><li><a href="https://elma365.com/ru/help/service/service-functions.html">Service</a></li><li><a href="https://elma365.com/ru/help/projects/projects-functions.html">Проекты</a></li></ul>
</div>
<div class="container">
<div class="footer-wrap">
<div><span class="mobile-question-popup">Отправить фидбэк</span><form method="POST" action class="question__popup question-xs" id="question__popup"><div class="question-wrap"><span class="close"></span><span class="title">Задать вопрос</span><label for="help_question" style="display: none;"></label><textarea name="help_question" id="help_question"></textarea><input type="submit" value="Отправить"></div></form><div class="hidden fade-in question-success-xs">Ваш фидбэк отправлен.</div></div>
<div class="footer-flex-b">
<div class="footer-top">
<span class="footer-copy">&copy; 2025
ELMA365
</span>
<a href="https://navigator.sk.ru/orn/1122971" target="_blank">
<img src="sk-resident.svg" alt="sk icon" class="footer-img" width="117" height="34">
</a>
</div>
<div class="footer-line">
<div class="footer-line-copy">
<span class="footer-copy">&copy; 2025
ELMA365
</span>
</div>
<ul class="footer-list">
<li class="footer-item"><a href="https://elma365.com/ru/" target="_blank" class="footer-link" style="color: #0D4A75;"><img src="browse.svg" alt="browse icon" class="footer-img">elma365.com</a></li><li class="footer-item"><a href="https://www.youtube.com/user/ELMABPM" target="_blank" class="footer-link"><img src="yt.svg" alt="youtube icon" class="footer-img"></a></li><li class="footer-item"><a href="https://vk.com/elma_bpm" target="_blank" class="footer-link"><img src="vk.svg" alt="vk icon" class="footer-img"></a></li><li class="footer-item"><a href="https://t.me/elmaday" target="_blank" class="footer-link"><img src="tg.svg" alt="telegram icon" class="footer-img"></a></li><li class="footer-item"><a href="https://dzen.ru/elma" target="_blank" class="footer-link"><img src="dzen.svg" alt="dzen icon" class="footer-img"></a></li>
<li class="footer-item">
<a href="https://navigator.sk.ru/orn/1122971" target="_blank">
<img src="sk-resident.svg" alt="sk icon" class="footer-img" width="117" height="34">
</a>
</li>
</ul>
</div>
</div>
</div>
</div>
<a href="#" class="arrow-top"></a>
</div>
</footer>
<!-- <script type="text/javascript" src="jquery1.min.js"></script>-->
<iframe name="hmnavigation" style="display:none!important"></iframe>
<!--<script src="./jquery-ui.js"></script> -->
<script src="./jquery-ui.min.js"></script>
<!--script src="//cdn.jsdelivr.net/npm/featherlight@1.7.14/release/featherlight.min.js" type="text/javascript" charset="utf-8"></script-->
<script src="./jquery.tocify.min.js"></script>
<script src="./TypoReporter.min.js"></script>
<script src="./google-search.js"></script>
<script src="./main.js"></script>
</body>
</html>