Добрый день! Подскажите пожалуйста, как можно реализовать запуск бизнес-процесса на основании фильтрации в разделе?
К примеру:
Есть заказы которые вручную отфильтровали по Состоянию и Дате создания, к этому результату необходимо применить БП который изменит значение текущего поля на другое (которое будет разово прописано в БП).
Артём, если вопрос не в конкретном решении, покрываемом дополнением, а в общем случае, то это можно сделать базовыми средствами системы:
После выполнения фильтрации выбрать действие «Выбрать несколько записей», затем действие «Выбрать все» (это выберет не все в разделе, а именно отфильтрованные), а затем запустить ранее подключенный в мастере раздела БП для этих записей:
С версии 7.16 появилась возможность множественного запуска бизнес-процессов через элемент подпроцесс.
К примеру необходимо создать бизнес-процесс который будет отправлять письмо-поздравление всем контактам у которых сегодня день рождения.
Для этого необходимо создать процесс с двумя элементами:
1. Элемент [Читать коллекцию] контактов у которых сегодня день рождения
2. Элемент [Подпроцесс] в который передать коллекцию контактов которых нужно поздравить.
В самом же подпроцессе необходимо создать параметр процесса который соответствует отдельному элементу коллекции, в нашем случае это контакт:
В результате запуска такого процесса получим последовательное выполнение подпроцесса для каждого элемента коллекции. Также процесс можно модифицировать добавив исходящие параметры.
При добавлении пользователя через интерфейс идёт обращение к веб-сервису AdministrationService и его методу UpdateOrCreateUser. В схеме AdministrationServiceUsers виден его код:
То есть видно, что вставка идёт через механизмы ESQ (значит, события отработают), но в объект VwSysAdminUnit, а не SysAdminUnit. Если посмотреть в коде встроенного БП на VwSysAdminUnit в пакетах Base, Translation и WebitelCollaborations, там как раз успешно добавляют свои обработчики на вставку, сохранение и другие события:
То есть нужно будет либо в Custom сделать своё переопределение схемы со встроенным БП, либо сделать отдельный БП, запускающийся по сигналу вставки туда:
В любом случае нужно учитывать, что в этой view видны и пользователи, и роли.
Часто сталкиваемся с проблемой того, что при активном окне процесса, нельзя запускать БП поверх них, они будут выполнятся в фоне. Приходить писать код, который будет выполнять определенные действия, например, создавать запись в разделе из кнопки.
Реальный, частый кейс:
Пользователю открывается задача по БП с текстом: "Оформите счет и договор по заказу", в системе есть 2 стандартных бп, которые это делают, но, когда пользователь прямо из задачи по ссылке переходит к заказу и через действия пытается это сделать, ничего не происходит (он так думает), но на самом деле процессы то запускаются, просто в фоне...
Очень хотелось бы иметь возможность в конструкторе бп установить признак для процесса "Запускать поверх других процессов". В данном случае у пользователя запускался процесс создание счета и договора.
А если и у второго процесса галка стоит, что делать? Ещё одну настройку добавлять, «Запускать поверх вообще всех процессов»?
В таких случаях будет лучше переработать логику процессов: либо отключить стандартные и интегрировать их логику в свой процесс, либо разбить свой на несколько отдельных частей, которые завершаются поочерёдно.
Нет, достаточно одной галки, она будет означать, что этот процесс начинается поверх любого другого. Вопрос не в ходе процесса, а в его начале-старте.
Вы не поняли сути проблемы. Проблема заключается в том, что человеку ставится задача, создать заказ из продажи или создать счет из заказа и ему удобнее прямо из задачи перейти в продажу или заказ и нажать кнопку, которая запустит другой процесс, процесс создания заказа или счета. Ему неудобно нажимать сохранить (в задаче), ждать когда его вернет система на последнюю карточку, открывать расписание, находить задачу, переходить по ссылке и нажимать на кнопку создать заказа или счет. Прочувствуйте разницу во времени, предложите альтернативу. Какие тут изменения в процессе, нам нужно запустить бп, чтобы он не в фоне начался.
П.С. Я не говорю про вариант подвязывания скрипта для кнопки создания продажи или счета.
Д., можно вместо открытия полной карточки заказа и прочего показать автогенерируемую или преднастроенную страницу, а затем создать запись с этими значениями полей. Либо опять же бить один большой всеохватывающий процесс на много мелких по отдельным действиям.
Вы, наверно, меня не понимаете. Даже если это мелкий подпроцесс с 1 задачей, он все равно не позволит запустить процесс сверху.Думаю, Вы с таким не сталкивались, а у нас это не каждый второй процесс, каждый первый. Нам приходит каждый раз делать кодом действия из кнопки. Просто нужно возможность в бп поставить галочку, запустить поверх текущего :))) Просто чтобы запустился сверху если его запускают при открытом другом бп
Видимо, Вы неверно подходите к архитектуре процессов, раз с таким никто больше не сталкивался, а Вы постоянно. В БП есть элементы автогенерируемых и преднастроенных страниц, открытие карточек новых и существующих записей разных разделов и др. Интегрируйте нужную логику стандартных процессов в свой, а стандартный отключите.
Вы написали очень много и все не по теме. Прочитайте, пожалуйста, суть вопроса и потом, если вы его, наконец, поймете, дайте реальный совет, а не история про космические корабли, которые бороздят...
Простейший кейс: У вас в бп 2 задачи, всего 2 задачи. Выполнятся бп начал при изменении статуса продажи, соответственно перед Вами открылась карточка задачи. В задаче написано: "Александр, дорогой, пожалуйста, создай счет к заказу, который связан с продажей". В задаче, естественно, есть связь с заказом.
Внимание, Александр, вопрос: как так переделать и оптимизировать наш с вами бп из двух задач, чтобы мы могли перейти сразу из этой задачи в заказ и нажать кнопку "Создать счет", чтобы у нас открылась картчочка счета и перенеслись туда продукты ? Вы там про автогенерируемые и преднастроенные страницы говорили, как там они перед нами появятся, если можно скриншотик.
Сейчас нам придется сохранить задачу, найти нужный заказ и потом создать счет, только в этом случае всплывет карточка счета.
А то, что вы говорите вообще никак не решает ситуацию, ведь эти страницы и есть часть бп, которые никогда не всплывет, пока активен другой бп.
Добрый день, Д. В таком случае попробуйте прямо в этом БП сделать не 2 блока, а 6, при этом вторые 2 будут связаны с заказом, а третьи 2 — со счётом. Если пользователь будет идти по процессу, ему не нужно будет ни вручную создавать счёт, ни нажимать дополнительные кнопки в карточках, а карточка нового счёта с уже заполненными полями связи с продажей и заказом автоматически появится при сохранении заказа в соответствии с логикой процесса. Дополнительную информацию пользователю, что от него хочет в этот момент система, можно показывать как раз в автогенерируемых страницах.
Такой возможности нет, поскольку Вы сами этот признак только что придумали. Дизайнер процессов реализован на уровне ядра, пользовательскими средствами в него добавить новую логику не получится. Попробуйте написать в поддержку, пусть зарегистрируют пожелание. Если его разработка будет целесообразной, в новых версиях добавят.
Андрей, речь о том, что раньше процессы были компилируемые, а сейчас — интерпретируемые. Сейчас можно создать только интерпретируемый. Но старые, созданные давно (как стандартные, так и самодельные) остались.
Основная разница для разработчика — в обращении из скрипта в БП к параметрам (напрямую в старых или через Get и Set в новых). Ну и в запуске, как написал Григорий. Ещё до последнего времени из интерпретируемых нельзя было возвращать результат в параметре, теперь уже можно.
Добрый вечер! Для объекта Лид создал замещающий модуль, в котором добавил новое действие в карточке объекта.
Подскажите, пожалуйста, как можно запустить бизнес-процесс при нажатии на созданное действие?
В теле метода, который выполняется по клику на действие можно вызвать процесс как-то так:
var url ='https://'+ document.domain+'/0/ServiceModel/ProcessEngineService.svc/MyProcessName/Execute?Param1Name=Param1Value&Param2Name=Param2Value';
var request = null;
request =new XMLHttpRequest();
request.open("GET", url, true);
request.send(null);
Где MyProcessName - название БП.
Param1Name/Param2Name - названия параметров, которые необходимо передать в БП.
Param1Value/Param2Value - значения параметров, соответственно.
Николай,
Добавить действие и обработчик нужно в схему, в который необходимо реализовать данный функционал. Если это страница редактирования то ..PageV2, если реестр раздела то ..SectionV2 (вместо точек подставить название объекта, например – OrderSectionV2, OrderPageV2).
Оба фрагмента кода необходимо добавить в блок methods: { ... }
Примеры можно найти в системе. Вот один из них (OrderPageV2):
methods: {
//Добавить действие
getActions: function() {
var actionMenuItems = this.callParent(arguments);
actionMenuItems.add("CreateContract", this.getButtonMenuItem({
"Caption": {"bindTo": "Resources.Strings.CreateContract"},
"Tag": "createContract",
"Enabled": {"bindTo": "canEntityBeOperated"}
}));
return actionMenuItems;
},
...
//Обработчик
createContract: function() {
...
},
...
}
В случае необходимости иметь возможность запустить БП путем перехода по гиперссылке, например в формате: terrasoft://WFStart/Workflow/%7b8C91E8A4-942C-4F39-BCB3-0C7D5D9C5779}/AccountID|%7b04B25C6A-9336-42DD-838F-E686D83B882C%7d (ссылка),
где 8C91E8A4-942C-4F39-BCB3-0C7D5D9C5779 – идентификатор диаграммы БП, AccountID|%7b04B25C6A-9336-42DD-838F-E686D83B882C%7d – параметр/значение, передаваемое в БП (Все параметры в ссылке разделяются символом «/»), проделайте следующие изменения в конфигурации:
1. Внесите следующие изменения в функцию RunHyperlink() скрипта scr_HyperlinkUtils:
2. Добавьте функцию запуска БП HyperlinkStartWorkflow() в скрипт scr_HyperlinkUtils.
function HyperlinkStartWorkflow(Params){ if(Params.length2){ return; } var Module = Params[0]; var IDValue = Params[1].replace(/%7b/g,'{').replace(/%7d/,'}');//Diagram ID var ParameterHash = Params.slice(2, Params.length); var ParamNames =new Array(); var ParamValues =new Array(); for(var i =0, iLength = ParameterHash.length; i iLength; i++){ var tmp =new String(ParameterHash[i]).split('|'); if(('length'in tmp)&&(tmp.length>1)){
ParamNames.push(tmp[0]);
ParamValues.push(tmp[1]); } }
WFStartByID(IDValue, ParamNames, ParamValues); }
Пытаюсь решить задачу, нужна подсказка.
Есть определенный БП, который запустил руководитель. В теле БП руководитель выбирает нескольких сотрудников. БП руководителя инициирует каждому из выбранных сотрудников свой отдельный БП.
Возникает трудность: как сделать так, чтоб эти под процессы принадлежащий именно выбранным сотрудникам (и что бы каждый из них мог довести уже свой отдельный процесс), а не инициатору выбора?
Можно попробовать так:
В подпроцессах создать параметр диаграммы OwnerID, и в первой задаче подпроцесса привязать параметр диаграммы OwnerID к параметру процесса OwnerID.
Потом возможны такие варианты:
1) если не нужно связывать процесс руководителя с подпроцессами сотрудников, то можно в скрипте к процессу запустить подпроцессы примерно так:
var ParamNames =new Array('OwnerID');
var ParamValues =new Array(null);for(var i =0; i < OwnerIDs.length; i++){
ParamValues[0]= OwnerIDs[i];
WFStartByID('{ИД сервиса-диаграммы}', ParamNames, ParamValues);}
2) если нужно привязаться к процессу руководителя, то (предполагаем, что количество сотрудников заранее неизвестно, а вычисляется по БП на каком то этапе):
- в родительской диаграмме ставим блок-подпроцесс, параметр которого OwnerID связываем с параметром основного процесса;
- перед этим блоком ставим блок-ромбик (условие), из которого будет два выхода - один на подпроцесс, второй на себя (это чтобы зациклить создание определенного количества подпроцессов). В обработчике условия собственно указываем очередное значение параметра OwnerID, и если еще не для всех запустили подпроцесс - зацикливаемся, иначе идем дальше.
Это так, схематично, отвечу на вопросы если надо :)
Валерий, я пробовал Ваш способ, делал немного по другому - без разницы!
Новый БП получает OwnerID, но инициатором и дальше остается тот кто запустил. Соответственно следующий уже шаг обратно возвращается к инициатору БП, а не тому, чей OwnerID мы передали.
Нам, фактически, нужно изменить ответственного по БП.
Немного поэкспериментировал, прикладываю сервисы для 3.3.2.
Чтобы обойтись без правки базовых сервисов (wa_TaskAction и т.п), можно сделать так (это как раз в примере):
1) в дочернем БП создаем параметр диаграммы ChildOwnerID, и в каждом блоке-задаче процесса параметр OwnerID ставим в соответствие параметру ChildOwnerID диаграммы;
2) в родительском БП
- также делаем параметр ChildOwnerID
- перед запуском подпроцесса устанавливаем параметр в нужный ИД контакта
- ставим параметр ChildOwnerID блока-подпроцесса в соответствие параметру диаграммы ChildOwnerID
В бизнес процессах если используется задержка процесса по времени, то следующая задача после процесса не создается автоматически. т.е. чтобы запустить задачу надо выполнить следующий шаг запущенного процесса.
Это не всегда удобно, т.к. таких процессов может быть запущенно огромное количество и пользователь не помнит, а может и не знает, что надо продолжить процесс.
Предлагается при окончании задержки выполнения процесса, чтобы автоматически запускалось окно создания задачи
Валерий, ваше решение достаточно интересное хотелось бы узнать о нем подробнее - стоимость, условие внедрения.
Что касается затрагиваемой мною темы, то здесь я считаю что была недоработка системы, т.е. если пользователь отменил действие или что то допустил не то, это другое дело, но запланированная задержка, должна быть задержкой на указанный промежуток времени, а не на все время :smile: