Разработка решений на платформе ELMA365 / Опциональные зависимости

Опциональные зависимости

Опциональная зависимость — это механизм, позволяющий настраивать связь между компонентом (виджетом, модулем, бизнес‑процессом) и разделом или пользовательским модулем без жёсткой привязки. Это означает, что компонент может обращаться к объектам выбранного раздела или модуля через глобальную константу Imports, но его работоспособность не зависит от наличия этого раздела или модуля. Таким образом, опциональные зависимости обеспечивают гибкость и расширяемость при разработке и дистрибуции компонентов системы.

Ключевые особенности опциональной зависимости:

  • опциональная зависимость работает в рамках сценария, который получает доступ к другому разделу или модулю через уникальное имя, задаваемое для этого раздела или модуля;
  • в сценарии компонента доступна глобальная константа Imports. Эта константа позволяет в коде сценария обращаться к объектам и функциям раздела или модуля, с которым установлена опциональная зависимость;
  • компоненты, использующие опциональные зависимости, можно экспортировать и импортировать между различными средами или компаниями без наличия связанных разделов или модулей в целевой среде. Это обеспечивает удобство переноса решений и их независимость от конкретных конфигураций системы;
  • при отсутствии зависимого раздела или модуля в целевой системе связанные функции либо не активируются, либо можно настроить вывод сообщения об ошибке.

Примеры применения опциональной зависимости включают создание гибких бизнес-процессов, виджетов и других компонентов системы, которые могут взаимодействовать с разнообразными модулями и разделами, не требуя их обязательного наличия для функционирования основной логики. Это особенно важно для разработки расширяемых решений, где новые функции и модули могут добавляться по мере необходимости без переработки уже существующих компонентов.

Добавление опциональной зависимости

начало внимание

Опциональные зависимости и константа Imports по умолчанию доступны в поставке Saas, а также On‑Premises, начиная с версии системы 2024.2. В более ранних версиях администратору системы нужно включить фича-флаг allowScriptImportsDependencies. Подробнее об этом читайте в статьях «Изменение параметров On-Premises Enterprise» и «Изменение параметров On-Premises Standard».

конец внимание

Когда вы настраиваете опциональную зависимость в сценарии, вы выбираете, к какому именно разделу или модулю хотите получить доступ, и присваиваете ему уникальное имя. Это имя затем используется в коде сценария для обращения к функциям или данным выбранного раздела или модуля.

Подробнее о том, как создать опциональные зависимости в разных компонентах системы, читайте в статьях:

После добавления опциональной зависимости в сценарии доступна глобальная константа Imports. С её помощью можно обращаться к объектам выбранного раздела или пользовательского модуля.

Применение глобальной константы Imports

Когда вы добавляете опциональную зависимость, вы получаете доступ к глобальной константе Imports. Эта константа позволяет вам работать с объектами внутри раздела, например, с помощью сценария добавить пользователя на портал или создать элемент приложения. Взаимодействовать с модулем можно при помощи настроенных в нём методов API и действий в бизнес‑процессах.

Пример использования включает вызов метода API, который находится в другом разделе системы:

if (Imports?.documents) {
    let result = await Imports.documents.api.validate.call();
    // ...
}

При написании сценария учитывайте, что компонент с использованием константы Imports можно импортировать, даже если зависимость в компании не найдена. Рекомендуется добавить блок кода, который выполняется, если не удаётся обратиться к выбранному разделу или модулю. Например, чтобы выводить понятную для пользователя ошибку.

Кроме того, компонент со сценарием и раздел или модуль, с которым создана опциональная зависимость, можно экспортировать совместно в составе решения.

Подробнее об экспорте компонентов с глобальными константами читайте в статье «Глобальные константы в сценариях».

Важно: в версиях системы ниже 2023.11 объект Imports недоступен. Если вы разрабатываете решение, которое должно быть совместимо с более ранними версиями платформы, используйте в начале сценария функцию следующего вида:

 

function getImports() {
  // Присвоение начального значения локальной переменной
  return typeof Imports !== 'undefined' ? <typeof Imports>Imports : undefined;
}
 
const __Imports = getImports();
 
// Далее в коде можно использовать переменную `__Imports`
if (__Imports?.payment_docs) {
    let item = __Imports.payment_docs.app.invoices.create();
}

 

Пример использования опциональной зависимости

Допустим, в компании есть раздел Платёжные документы с приложением Счета и раздел Документы с приложением Договоры. С карточки договора необходимо добавлять новые счета по нажатию кнопки.

Разделы входят в состав разных решений, их необходимо экспортировать по отдельности.

В этом случае можно привязать к кнопке запуск сценария, создать для него опциональную зависимость и обращаться к приложению из другого раздела с помощью константы Imports. Для этого:

  1. Откройте карточку приложения Договоры в дизайнере интерфейсов и перейдите на вкладку Настройки > Доступные элементы.
  2. Напротив поля Опциональные зависимости (доступны в объекте Imports) нажмите + Добавить раздел и выберите раздел Платёжные документы.
  3. В колонке Псевдоним задайте для раздела уникальное имя, которое будет использоваться в сценарии, например, payment_docs.
  4. Перейдите на вкладку Шаблон и добавьте на форму кнопку с типом действия Сценарий. В поле Выполняемый сценарий создайте функцию, которая будет вызываться при нажатии кнопки.

optional-dependencies-1

  1. Откройте добавленную функцию на вкладке Сценарии и укажите:

async function create_invoice(): Promise<void> {
    if (Imports?.payment_docs) {
        const item = Imports.payment_docs.app.invoices.create();
        // ...
        await item.save();
    }
}

  1. На верхней панели дизайнера интерфейсов нажмите Сохранить и Опубликовать, чтобы сделать изменения доступными для пользователей.

Теперь с карточки договора можно быстро создать новый счёт.

Вы можете экспортировать приложение Договоры, раздел Документы и решение, в состав которого они входят. Затем можно импортировать эти компоненты в другую компанию. Если в компании нет раздела, с которым создана опциональная зависимость, привязанный к кнопке сценарий не будет выполняться.