Yandex Cloud
Поиск
Связаться с экспертомПопробовать бесплатно
  • Кейсы
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
  • Marketplace
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Искусственный интеллект
    • Безопасность
    • Инструменты DevOps
    • Бессерверные вычисления
    • Управление ресурсами
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Калькулятор цен
    • Тарифы
    • Акции и free tier
  • Кейсы
  • Документация
  • Блог
Создавайте контент и получайте гранты!Готовы написать своё руководство? Участвуйте в контент-программе и получайте гранты на работу с облачными сервисами!
Подробнее о программе
Проект Яндекса
© 2026 ООО «Яндекс.Облако»
Yandex DataLens
  • Нейроаналитик DataLens
    • Обзор
      • Обзор
      • Нейроаналитик в Editor
      • Вкладки
      • Источники
      • Доступные методы
      • Уведомления
      • Связи чарта в дашбордах и отчетах
      • Кросс-фильтрация
      • Отладка чартов
    • Добавление информации о чарте
    • Открытие чарта как таблицы
    • Сохранение чарта как изображения
    • Версионирование
    • Экспорт данных из чартов
    • Инспектор чартов
    • Управление доступом
  • Галерея в DataLens
  • Аудитные логи Audit Trails

В этой статье:

  • Meta
  • Params
  • Специальные параметры
  • Ограничения
  • Sources
  • Подключение к источнику данных через датасет
  • Подключение к источнику данных через SQL-запрос
  • Подключение к источнику данных через API Connector
  • Config
  • Prepare
  • Controls
  • Activities
  • Доступные методы
  • Доступные действия
  • Выполнение действий
  • Ограничения
  1. Чарты
  2. Чарты в Editor
  3. Вкладки

Вкладки

Статья создана
Yandex Cloud
Обновлена 6 апреля 2026 г.
  • Meta
  • Params
    • Специальные параметры
    • Ограничения
  • Sources
    • Подключение к источнику данных через датасет
    • Подключение к источнику данных через SQL-запрос
    • Подключение к источнику данных через API Connector
  • Config
  • Prepare
  • Controls
  • Activities
    • Доступные методы
    • Доступные действия
    • Выполнение действий
    • Ограничения

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

Код формирования конфигурации чарта, описанный на вкладках, выполняется на сервере. На этой странице представлены форматы заполнения каждой из вкладок.

Код функций, расположенный внутри Editor.wrapFn, выполняется на клиенте в браузере пользователя. Это накладывает ряд ограничений, подробнее можно почитать в разделе Доступные методы.

Вкладки выполняются в определенном порядке.

MetaMeta

Служит для описания служебной информации о списке связанных сущностей.

На вкладке Meta добавляются id объектов использующихся источников для чарта/селектора. Описание id объектов является обязательным. Эта информация используется для определения, с какими подключениями и датасетами связан чарт, а также для диалога связанных объектов, при копировании воркбука и при публикации в Public.

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

В качестве ключа необходимо указать произвольное имя-алиас, которое будет присвоено данному источнику данных в чарте. Далее на вкладке Source можно получить это имя-алиас с помощью Editor.getId(arg) и указать его в качестве источника.

Формат
Пример
{
    "links": {
        "<string>": "<string>",
        ...
    }
}
{
    "links": {
        "myDatasetKeyName": "qvnkqzm0wstyf",
        "connectionKey": "ch96co0501xy1",
        "apiConnectionKey": "uzrou8sqm5zaj"     
    } 
}

ParamsParams

Вкладка предназначена для установки дефолтных параметров чарта/селектора. Все параметры, которые используются в чарте/селекторе, должны быть описаны на вкладке Params. Значения параметров являются массивами строк. Если требуется передать только одно значение, его нужно оформить в виде массива из одного элемента.

Формат
Пример
{
    "<string>": "<string>",
    ...
}
module.exports = {
    count: ['10'],
    setting: ['value'],
};

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

Значения всех актуальных параметров на последующих вкладках можно получить с помощью метода Editor.getParams(), а получить актуальное значение параметра по его названию можно с помощью Editor.getParam(name).

Переопределить параметры можно через URL графика. Например:

&period=40&metric=2012&metric=2014

Такой URL, наложенный на параметры по умолчанию, описанные выше, образует следующий объект:

{
  period: 40,
  metric: ['2012', '2014'],
  id: ['1215', '1217', '979', '483']
}

При изначальной отрисовке дашборда или отчета параметры, которые связывают JS-селектор с чартами на дашборде или в отчете, остаются статичными. Если параметр динамически вычисляется в коде селектора, то перерисовка чартов с обновленными значениями параметра произойдет только при последующем изменении селектора.

Специальные параметрыСпециальные параметры

Относительная датаОтносительная дата

Форматы:

  • __relative_<знак><количество><единица_измерения>
  • __relative_<знак><количество><единица_измерения>_<тип_приведения><единица_измерения>
  • <знак>: + или -
  • <единица_измерения>:
    • y - год
    • Q - квартал
    • M - месяц
    • w - неделя
    • d - день
    • h - час
    • m - минута
    • s - секунда
    • ms - миллисекунда
  • <тип_приведения>:
    • s - к началу
    • e - к концу

Пример:

Если время на данный момент 2020-03-24T23:30:39.874Z, то

  • __relative_-7d - семь дней назад - 2020-03-17T00:00:00.000Z
  • __relative_+30m - через 30 минут - 2020-03-25T00:00:39.874Z
  • __relative_-0d - сегодня - 2020-03-24T00:00:00.000Z
  • __relative_-0h - сейчас - 2020-03-24T23:30:39.874Z
  • __relative_-3M_sQ
    • минус 3 месяца - 2019-12-24T00:00:00.000Z
      • приведенные к началу квартала - 2019-10-01T00:00:00.000Z
  • __relative_+15s_em
    • плюс 15 секунд - 2020-03-24T23:30:54.874Z
      • приведенные к концу минуты - 2020-03-24T23:30:59.999Z

Примечание: если не указаны приведения, то для единиц измерения от дня и выше время приводится к началу дня,
т.е. 00:00:00.000, а для единиц измерения меньше дня используется текущее время.

Вспомогательный метод: Editor.resolveRelative

ИнтервалИнтервал

Формат: __interval_<начало>_<конец>

начало/конец - относительная дата или ISO дата.

Пример:

Если время на данный момент 2020-03-24T23:30:39.874Z, то

  • __interval_2019-03-11T09:35:48_2019-12-28T09:35:48
    • с 2019-03-11T09:35:48 по 2019-12-28T09:35:48
  • __interval_2019-01-17T09:35:48___relative_+0d
    • с 2019-01-17T09:35:48 по сегодня (2020-03-24T23:59:59.999Z)
  • __interval___relative_-2w_sM___relative_+1d
    • от двух недель назад - 2020-03-10T00:00:00.000Z
      • приведенных к началу месяца - 2020-03-01T00:00:00.000Z
    • до завтра - 2020-03-25T23:59:59.999Z

Вспомогательный метод: Editor.resolveInterval

ОграниченияОграничения

При использовании параметров существуют следующие ограничения:

  • Зарезервированные ключи, которые нельзя использовать:

    • tab
    • state
    • mode
    • focus
    • grid
    • scale
    • tz
    • timezone
    • date
    • datetime
    • _action_params
    • _autoupdate
    • _opened_info
    • report_page
    • preview_mode

    Параметры с такими ключами будут проигнорированы и не будут сохранены.

  • В ссылках могут быть использованы только те параметры, которые заданы в настройках дашборда. В противном случае они будут проигнорированы. Например, если в ссылке будет указано ?product=Furniture, но в настройках дашборда не будет задан параметр product (даже с пустым значением), то такой параметр будет проигнорирован.

  • Параметры дашборда в любом случае будут применены к виджетам, что может привести к ошибкам в запросах данных.

SourcesSources

На этой вкладке определяется структура для запроса данных, которые нужно визуализировать.

Данные можно запросить, используя:

  • датасет;
  • подключение к базам данных через SQL-запрос;
  • подключение через API Connector.

Подключение к источнику данных через датасетПодключение к источнику данных через датасет

Для использования данных из датасета:

Формат
Пример 1
Пример 2

Возвращаемый на вкладке JSON-объект вида:

{
    datasetId: "<string>",
    data: {
        fields: [
            {
                ref: {
                    title: "<string>",
                    type: "title"| "id",
                },
            },
            ...
        ],
    }
}

Где:

  • datasetId — id датасета, описанного на вкладке Meta и полученного с помощью метода Editor.getId(arg).

  • fields — массив имен колонок датасета:

    • title — название или id колонки;
    • type — тип колонки, указанной в title (выбирать колонку по названию или по id).
module.exports = {
    'myDatasetSource': {
        datasetId: Editor.getId('myDatasetKeyName'),
        data: {
            fields: [
                {
                    ref: {
                        type: "title",
                        title: "PaymentType",
                    },
                },
		{
                    ref: {
                        type: "title",
                        title: "OrderYear",
                    },
                },
		{
                    ref: {
                        type: "title",
                        title: "OrderMonth",
                    },
                },
            ],
        },
    },
};

Для удобства можно использовать вспомогательный служебный модуль для работы с датасетами, тогда Пример 1 будет выглядеть так:

const {buildSource} = require('libs/dataset/v2');
module.exports = {
    'myDatasetSource': buildSource({
        datasetId: Editor.getId('myDatasetKeyName'),
        columns: ['PaymentType', 'OrderYear', 'OrderMonth'],
    }),
};

Где:

  • datasetId — id датасета, описанного на вкладке Meta и полученного с помощью метода Editor.getId(arg).
  • columns — массив имен колонок датасета.

В дальнейшем появится дополнительный параметр, в котором можно будет передать массив идентификаторов колонок датасета.

Пример с получением только списка полей из датасета:

Вкладка Sources
module.exports = {
  fields: {
      datasetId: Editor.getId('mySource'),
      path: 'fields'
  }
};

См. такжеСм. также

  • Быстрый старт по созданию таблицы с подключением через датасет

Подключение к источнику данных через SQL-запросПодключение к источнику данных через SQL-запрос

Для получения данных из подключения (через SQL запрос):

Формат
Пример
{
    qlConnectionId: "<string>",
    data: {
        sql_query: "<string>",
    },
}

Где:

  • qlConnectionId — id подключения, описанного на вкладке Meta и полученного с помощью метода Editor.getId(arg).
  • sql_query — запрос данных.
module.exports = {
    'myDataSource': {
        qlConnectionId: Editor.getId('connectionKey'),
        data: {
            sql_query: 'SELECT 1 + 1',
        },
    }
}

См. такжеСм. также

  • Быстрый старт по созданию таблицы с подключением через SQl-запрос

Подключение к источнику данных через API ConnectorПодключение к источнику данных через API Connector

Для получения данных с помощью API Connector:

Формат
Пример
{
    apiConnectionId: "<string>",
    path: "<string>",
    method: "GET"|"POST",
    body: <object>,
}

Где:

  • apiConnectionId — id подключения с типом API Connector, описанного на вкладке Meta и полученного с помощью метода Editor.getId(arg).
  • path — путь к API после хоста.
  • method — метод: поддерживаются GET и POST.
  • body — тело запроса.
module.exports = {
    'myApiDataSource': {
        apiConnectionId: Editor.getId('apiConnectionKey'),
        path: '/html',
        method: 'GET',
    }
}

См. такжеСм. также

  • Быстрый старт по созданию таблицы с подключением через API Connector

ConfigConfig

В этой вкладке задаются настройки визуализации, например настройки кросс-чарт фильтрации.

Доступно для типов визуализаций График и Таблица. Возможное содержимое зависит от конкретного типа визуализации.

PreparePrepare

Вкладка отвечает за препроцессинг данных перед их передачей на отрисовку и предполагает следующие действия:

  • Получение загруженных данных из источников с помощью метода Editor.getLoadedData().

  • Обработка и приведение к нужному формату (зависит от типа визуализации).

  • Запись результатов в module.exports, откуда они попадают на отрисовку.

Доступно для типов визуализаций График, Advanced-чарт, Таблица, Markdown.

ControlsControls

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

Доступно для всех типов визуализаций. Подробный формат вкладки зависит от типа контролов.

ActivitiesActivities

Вкладка позволяет конфигурировать интерактивные действия для элементов дашборда, например, отправлять HTTP-запрос по клику на строку таблицы.

Доступно для типов визуализаций Селектор, Таблица и График (Gravity UI Charts).

Формат
Пример
module.exports = {
    sources: ({params}) => { /* конфигурация источников */ },
    handleResponse: ({data}) => { /* обработка ответа */ }
}
module.exports = {
  sources: ({params}) => {
      const ticketId = params.cells[0].value;
      return {
          todoList: {
              apiConnectionId: Editor.getId('todoListConnection'),
              path: `?ticketId=${ticketId}`,
              method: "GET",
          },
      }; 
  },
  handleResponse: ({data}) => {
      const ticket = data.todoList.data.body;
      return {
          action: 'popup',
          title: ticket.title,
          content: ticket.description,
      };
  }
};

Доступные методыДоступные методы

  • Метод sources() — функция, возвращающая объект для подключения к источнику данных. Используется для отправки запросов. Формат идентичен формату вкладки Sources.

    sources: ({params}) => ({     
        sourceKey: {         
            apiConnectionId: Editor.getId("mySourceKeyName"),         
            path: '/api/endpoint',         
            method: 'POST',         
            body: { /* данные запроса */ }     
        } 
    })
    

    Где:

    • params — объект с параметрами из элементов управления дашборда.
    • apiConnectionId — ID подключения с типом API Connector, описанного на вкладке Meta и полученного с помощью метода Editor.getId(arg).
    • mySourceKeyName — имя-алиас источника данных, описанного на вкладке Meta.
    • path — путь к API после хоста.
    • method — метод запроса.
    • body — данные запроса.
  • Метод handleResponse() — функция, возвращающая объект в формате, зависящем от типа действия. Обрабатывает ответ от сервера и определяет действие в интерфейсе.

        handleResponse: ({data}) => { /* обработка ответа */ }
    

    Где data — объект с ответами от источников данных.

Доступные действияДоступные действия

  • toast — всплывающее уведомление:

    Формат
    Пример
    {
        action: "toast",
        title: "<string>",
        content: "<string>",
        type: "warning"|"success"|"normal"|"info"|"danger"|"utility",
    }
    

    Где:

    • action — тип действия, которое нужно вызывать после отправки запроса. Значение toast показывает компоненту всплывающего кратковременного уведомления в правом нижнем углу.
    • title — заголовок уведомления.
    • content — содержимое уведомления.
    {
        action: 'toast',
        title: 'Заголовок',
        content: 'Текст уведомления' 
    }
    
  • popup — всплывающее окно:

    Формат
    Пример
    {
        action: "popup",
        title: "<string>",
        /** текст или разметка в формате markdown */
        content: "<string>",
    }
    

    Где:

    • action — тип действия, которое нужно вызывать после отправки запроса. Значение popup показывает компоненту всплывающего окна по центру экрана.
    • title — заголовок окна.
    • content — содержимое окна.
    {
        action: 'popup',
        title: 'Заголовок',
        content: 'Содержимое окна' 
    }
    
  • setParams — установка параметров:

    Формат
    Пример
    {
        action: "setParams",
        params: object,
    }
    

    Где:

    • action — тип действия, которое нужно вызывать после отправки запроса. Значение setParams обновляет значения параметров из переданного поля params.
    • params — объект со списком ключей и значений параметров для установки.
    {
        action: "setParams",
        params: {p: ["1"]}
    }
    

Выполнение действийВыполнение действий

Чтобы выполнить действия вкладки Activities, обработайте события элементов интерфейса:

  • Для селекторов: на вкладке Controls для кнопки укажите действие runActivity по событию onClick.
  • Для чартов График (Gravity UI Charts) и Таблица: настройте действие runActivity на вкладке Config.

ОграниченияОграничения

  • На вкладке Activities доступен ограниченный набор источников данных для отправки запросов: запросы к датасетам, стандартным подключениям и подключениям API Connector.
  • Функциональность на текущий момент доступна для следующих типов чартов: Селектор, Таблица и График (Gravity UI Charts).

См. такжеСм. также

  • Пример использования вкладки Activities в Editor

Была ли статья полезна?

Предыдущая
Нейроаналитик в Editor
Следующая
Источники
Создавайте контент и получайте гранты!Готовы написать своё руководство? Участвуйте в контент-программе и получайте гранты на работу с облачными сервисами!
Подробнее о программе
Проект Яндекса
© 2026 ООО «Яндекс.Облако»