СПЕЦИФИКАЦИЯ. Клиентские скрипты (правила автоматизации). BETA версия. Планируем развивать!
В релизе r_3.7.0 появилась возможность настраивать кастомные правила автоматизации для карточки заявки в виде скриптов.
Такие скрипты позволяют реализовывать разные сценарии:
- Показать/скрыть какое-то поле в зависимости от значения другого поля
- Заполнить значение одного поля в зависимости от значения другого поля
- Заполнить значение доп. поля заявки значением поля пользователя, клиента или сотрудника
- Показать плашку об ошибке, если при сохранении заявки не соблюдено какое-то условие
- Настроить заполнение текста в комментарии или переключить вид комментария (публичный или внутренний)
- И другие..
Порядок настройки скрипта
Скрипты настраиваются в разделе "Настройки -> Заявки -> Скрипты заявок". На карточке создания скрипта нужно:
- Заполнить название
- Указать тип заявки, для которого должен применяться этот скрипт
- Нажать на кнопку "Открыть редактор" в поле "DSL"
- Написать там (или вставить туда) код скрипта
- Сохранить
- !Переавторизоваться (для того, чтобы скрипт заработал)
Структура скрипта
В общем виде скрипт выглядит так:
script v1.0 {
rule {
name: "Example Rule 1" //Название скрипта
on { //Блок с событиями применения
taskEvent: save //Событие применения
}
action { //Блок с действиями
if (bool.true(task.statusid.value)) { //Условие
setCommentMode: public //Само действие
}
}
}
}Ниже описаны спецификации и основные функции, доступные на данный момент при работе со скриптами. С примерами готовых скриптов можно ознакомиться в Статье №66549.
Основные блоки, функции и синтаксис скриптов:
1. События применения скрипта (блок "On")
//проверка по условию ИЛИ
on {
taskEvent: open-create-form //открытие формы создания заявки
taskEvent: open-edit-form //открытие формы созданной заявки
taskEvent: save //сохранение заявки
changeField: client //изменение поля "Клиент"
changeField: initiator //изменение поля "Заявитель"
changeField: executor //изменение поля "Исполнитель"
changeField: priority //изменение поля "Приоритет"
}
//также в changeField можно указать alias доп. поля заявки (поддерживаемые типы: Число, Число (дроб.), Строка, Текст, Вып. список)2. Условия (блок "If")
//операции для строк: "==", "!="
if(string.bool(task.addfield_vyp_spisokSingleSelect.value == '1')) {
task.addfield_dop_textText.setValue('value 1')
}
//операции для чисел : "==", "!=", ">", ">=", "<", "<="
if(number.bool(task.serviceid.value == 1055)) {
task.addfield_dop_textText.setValue('service is 1055')
}//доступна группировка по and и or
//как массив из bool условий
if(
bool.or
[
number.bool(task.statusid.value == 0)
bool.and
[
number.bool(task.statusid.value == 313)
string.bool(task.addfield_strokovoeString.value == '')
]
]
) {
user.load(task.initiatoruserid.value as initiatorUserData)
task.addfield_strokovoeString.setValue(user#initiatorUserData.defaultphone)
setAccess(edit){
addfield_strokovoeString
}
3. Получение значений полей заявки
task.serviceid.value //id сервиса
task.tasktypeid.value //id типа заявки
task.statusid.value //id статуса
task.priorityid.value //id приоритета
task.clientid.value //id клиента
task.initiatoruserid.value //id пользователя-заявителя
task.initiatorgroupid.value //id клиента-заявителя
task.executoruserid.value //id сотрудника-исполнителя
task.executorgroupid.value //id группы-исполнителя// доп поля заявки (поддерживаемые типы: Число, Число (дроб.), Строка, Текс, Вып. список)
//пример:
task.addfield_pole1Number.value4. Получение значений данных пользователей
//загрузить пользователя в переменную 'initiatorUser'
//загруженный пользователь кешируется на 10 минут
user.load(task.initiatoruserid.value as initiatorUser)
//пример использования загруженного пользователя в переменную 'initiatorUser'
task.addfield_pole_textText.setValue(user#initiatorUser.fullname)//Доступные функции для пользователя:
//полное ФИО
user#initiatorUser.fullname
//дефолтный телефон
user#initiatorUser.defaultphone
//все телефоны через запятую
user#initiatorUser.phones.toString()
//телефон по индексу в массиве, начиная с 0
user#initiatorUser.phones[2]
//основная почта
user#initiatorUser.email
//дополнительные почты через запятую
user#initiatorUser.additionalemails.toString()
//дополнительная почта по индексу в массиве, начиная с 0
user#initiatorUser.additionalemails[1]
//теги через запятую
user#initiatorUser.tags.toString()5. Получение значений данных групп пользователей
//загрузить группу в переменную 'initiatorGroup'
//кешируется на 10 минут
usergroup.load(task.initiatorgroupid.value as initiatorGroup)
//пример использования
task.addfield_pole_textText.setValue(usergroup#initiatorGroup.name)//Доступные функции для группы:
//название группы
usergroup#initiatorGroup.name
//дефолтный телефон
usergroup#initiatorGroup.defaultphone
//все телефоны через запятую
usergroup#initiatorGroup.phones.toString()
//телефон по индексу в массиве, начиная с 0
usergroup#initiatorGroup.phones[2]
//основная почта
usergroup#initiatorGroup.email
//дополнительные почты через запятую
usergroup#initiatorGroup.additionalemails.toString()
//дополнительная почта по индексу в массиве, начиная с 0
usergroup#initiatorGroup.additionalemails[1]
//теги через запятую
usergroup#initiatorGroup.tags.toString()
//id менеджера
usergroup#initiatorGroup.manager.id
//name менеджера
usergroup#initiatorGroup.manager.name
//email менеджера
usergroup#initiatorGroup.manager.email6. Получение значения текущей даты
//добавлена функция для получение текущей даты
date.now
//добавлена функция diff для вычисления разницы между двумя датами
date.diff(date1, date2, unit)
//при вызове происходит вычитание date2 из date1
//если date1 меньше чем date2, то результатом будет отрицательное число
//unit - разрядность вычитания, доступные значения:
// year | month | day | hour | minute | second | millisecond
//пример
//выдавать ошибку если в дату выполнения заявки установили значение меньше чем 5 дней от текущей даты
if(number.bool(date.diff(task.resolutiondateplan.value, date.now, day) < 5)) {
throw 'Дата выполнения должна быть больше 5 дней от текущей даты'
}7. Установка значений полей
//обнуление значения поля
task.initiatoruserid.setValue(#NULL)
//пример использования загруженного пользователя в переменную 'initiatorUser'
task.addfield_olga_textText.setValue(user#initiatorUser.fullname)
//задать текст
task.addfield_olga_textText.setValue('тест строка')
//установить значение из другого поля заявки
task.addfield_olga_textText.setValue(task.addfield_testpoleText.value)
//получить значение из поля "Заявитель"
task.initiatoruserid.value
task.initiatorgroupid.value
//установить значение в поле "Заявитель"
task.initiatoruserid.setValue(...)
task.initiatorgroupid.setValue(...)
//получить значение доп. полей с типами "Date" и "DateTime"
task.addfield_test1Date.value
task.addfield_test1DateTime.value
//установить значение доп. полей с типами "Date" и "DateTime"
task.addfield_test1Date.setValue('2026-01-01')
task.addfield_test1DateTime.setValue('2026-01-01T10:00:00')
//получить значение "Срок выполнения (план/факт)"
task.resolutiondateplan.value
task.resolutiondatefact.value
//установить значение "Срок выполнения (план/факт)"
task.resolutiondateplan.setValue(...)
task.resolutiondatefact.setValue(...)
//получить значение "Срок реакции (план/факт)"
task.reactiondateplan.value
task.reactiondatefact.value
//установить значение "Срок реакции (план/факт)"
task.reactiondateplan.setValue(...)
task.reactiondatefact.setValue(...)8. Настройка видимости полей (setVisibility)
setVisibility(hide) { //скрыть поле
priority
}
setVisibility(show) { //показать поле
addfield_strokovoeString
}
setVisibility(default) { //отобразить в зависимости от настроек прав доступа
addfield_strokovoeString
}*Перед применением видимости сначала проверяются права доступа. Это значит, что если поле недоступно по правам доступа, то оно не отобразится при использовании метода setVisibility(show).
9. Работа с полем комментария
//получить html текст комментария
task.comment.value
//установить html текст комментария
task.comment.setValue(...)
//преобразовать html text в plain text
html.toPlainText(...)
//пример скрипта
//в доп поле с типом "текст" установить plain text из комментария
task.addfield_testText.setValue(html.toPlainText(task.comment.value))
//по умолчанию включить добавление публичных комментариев
setCommentMode: public
//по умолчанию включить добавление внутренних комментариев
//(применяется только для пользователей-сотрудников)
setCommentMode: private10. Работа с доп. полями с типами "SingleSelect" и "MultiSelect"
//добавлена возможность менять значения выпадающих списков на форме заявки для доп полей с типом "SingleSelect" и "MultiSelect"
//возможно установить 2 значнения:
// [...], строковый массив значений
// default, для загрузки полного списка
//для правильной работы в стандартном списке должны быть указаны все значения, которые используются в скрипте,
//иначе значение из скрипта будет проигнорировано
script {
rule {
name: 'test rule'
action {
//секция по работе с внешним видом формы заявки
ui {
//alias доп поля
addfield_testSingleSelect {
//загрузить стандартный список
list = default
}
//alias доп поля
addfield_testMultiSelect {
//показать только заданные значения
list = ['1', '2']
}
}
}
}
}11. Создавать кастомных функций с возвращаемым значением
//пример с построчным комментарием возможностей
script {
helpers {
//создана функция test1
function test1(nFactor, mFactor){
//в v1 и v2 запомнили значения доп полей
var v1 = task.addfield_dopPoleNumber.value
var v2 = task.addfield_factorNumber.value
//в v3 вычислили произведение v1 на v2
var v3 = number.math(vars#v1 * vars#v2)
//в v4 вычислили деление v3 на динамичный аргумент nFactor
var v4 = number.math(vars#v3 / args#nFactor)
//результатом функции будет умножение v4 на mFactor
return number.math(vars#v4 * args#mFactor)
}
//можно создать функцию без аргументов
function getServiceId() {
return task.serviceid.value
}
}
rule {
name: 'rule test'
action {
//вызов функции с аргументами
task.comment.setValue(func#test1(10, 15))
//вызов функции без аргументов
task.comment.setValue(func#getServiceId())
}
}- Число (целое)
- Число (дробное)
- Строка
- Текст
- Выпадающий список
- Дата (без времени)
- Дата/время
- Вып. список
- Мн. выбор