123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444 |
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
- };
- var Unibase;
- (function (Unibase) {
- let Platform;
- (function (Platform) {
- let Automation;
- (function (Automation) {
- let Components;
- (function (Components) {
- class ExecuteQuery extends Platform.Core.BaseComponent {
- constructor() {
- super(...arguments);
- this.RowIndex = 0;
- this.RuleProviderId = 0;
- this.AutomationMode = 0;
- }
- jsFiles() {
- var jsfiles = ["platform/automation/managers/rulemanager.js",
- "platform/automation/enums/automationmode.js",
- "platform/automation/components/conditions.js",
- "platform/automation/components/contactselection.js",
- "platform/automation/requests/ruleaction.js",
- "platform/automation/requests/rulecondition.js",
- "platform/forms/components/formviewer/formviewer.js",
- "libs/parsley/parsley.min.js",
- "libs/querybuilder/query-builder.min.js",
- "libs/querybuilder/query-builder.standalone.min.js",
- "libs/querybuilder/query-builder.standalone.js",
- "libs/querybuilder/sql-parser.min.js", "libs/notificationbuilder/notificationbuilder.js", "platform/automation/components/rulebuilder/notificationgroup.js", "platform/automation/managers/notificationgroupmanager.js"
- ];
- return jsfiles;
- }
- cssFiles() {
- return [];
- }
- html(id, containerid) {
- let html = `<form id="frmUnibase_ExecuteQuery" data-validate="parsley" data-isdynamic="false">
- <div class="card bg-light">
- <div class="b-b bg-white card-header header">
- <strong class="text-dark title" id="Spn_ExecuteQuery">Create Execute Query</strong>
- </div>
- <div class="card-body scrollable" style="overflow-y: scroll;">
- <div class="bg-white card" id="divExecuteQuery">
- <div id="Validate_ExecuteQueryAction" class="clear"></div>
- <div class="card-body">
- <div class="row">
- <div class="col-sm-12">
- <div class="floating-label-form-group">
- <label for="lbl" id="lbl_RuleActionName">Action<span class="text-danger required" id="spnIsRequired_RuleActionName"> *</span></label>
- <input type="text" id="txtExecuteQuery_RuleActionName" class="form-control value-control required floating-label-control" placeholder="Action *" data-placeholder="Enter Action" data-label="Action *">
- <input type="hidden" id="hf_RuleActionName" />
- </div>
- </div>
- </div>
- <div class="row">
- <div class="col-sm-6">
- <div id="div_QueryType" class=" floating-label-form-group floating-label-form-group-with-value">
- <label for="lbl" id="lbl_QueryType">Query Type</label>
- <select id="ddl_QueryType" class="form-control">
- <option value="1">Query</option>
- <option value="2">Procedure</option>
- </select>
- <label for="Validation" id="lblValidation_QueryType"></label><input type="hidden" id="hfFormPropertyId" value="0" />
- </div>
- </div>
- <div class="col-sm-6">
- <div class="custom-control custom-checkbox checkbox-primary mt-40">
- <input type="checkbox" class="custom-control-input" id="chkIsAsync">
- <label class="custom-control-label" for="chkIsAsync">IsAsync</label> 
- </div>
- </div>
- </div>
- <div class="row">
- <div id="div_Query" class="TextEditor col-sm-12">
- <inpu type="hidden" id="txthdn__Query" class="value-control" value="">
- <span class="text-danger" id="spnIsRequired__Query"></span>
- <div class="type-control summernote__Query" style="display: block;" id="summernote__Query" data-propdoctypename="Query" data-required="" placeholder="Query" data-placeholder="Query" data-label="Query"></div>
- <label for="Validation" id="lblValidation"></label>
- </inpu>
- </div>
- </div>
- <div class="row">
- <div id="div_NotificationGrp" class="floating-label-form-group col-sm-6 floating-label-form-group-with-value">
- <label for="lbl_NotificationGrp" id="lbl_NotificationGroup">Notification Group<span class="text-danger"> *</span></label>
- <select id="ddl_NotificationGrp" class="form-control"><option value="0">Select Group</option></select>
- </div><div class="col-sm-6 createbtn_grp"><button class="badge badge-primary mt-30 ml-15" id="creategrp_btn">Create Group</button></div></div>
-
- <div class="row">
- <div class="ResultActions col-sm-6 hidden">
- <div id="div_ResultAction" class=" floating-label-form-group floating-label-form-group-with-value">
- <label for="lbl" id="lbl_ResultAction">Result Action</label>
- <select id="ddl_ResultAction" class="form-control">
- <option value="0">Select</option>
- </select>
- <label for="Validation" id="lblValidation_ResultAction"></label><input type="hidden" id="hfFormPropertyId" value="0" />
- </div>
- </div>
- <!---- <div class="col-sm-6">
- <div class="custom-control custom-checkbox divEnablePieces checkbox-primary mt-25">
- <input type="checkbox" class="custom-control-input" id="chkAutoApprovedExecuteQuery" checked>
- <label class="custom-control-label" for="chkAutoApprovedExecuteQuery">Perform this Action</label> 
- </div>
- </div>---->
- </div>
- </div>
- </div>
- <div class="bg-white card Advanced_optionsdata">
- <div class="card-header"><i class="fa fa-angle-down arrowicon mr-1" onclick="Unibase.Platform.Automation.Components.ExecuteQuery.Instance().Toggleadvancedoptions()"></i>Advanced Options</div>
- <div class="card-body Advanced_options hidden">
- <div class="row">
- <div class="col-sm-6 floating-label-form-group floating-label-form-group-with-value">
- <label class="Message_type">Message Type</label>
- <select class="form-control" id="message_result">
- <option value="0">Success</option>
- <option value="1">Warning</option>
- <option value="2">Error</option>
- </select>
- </div>
- <div class="col-sm-6">
- <input type="checkbox" class="test_data mt-50" id="chkAutoApprovedExecuteQuery" checked>Perform this Action
- <!---<label class="check_action">Perform this Action</label>---->
- </div>
- </div>
- </div>
- </div>
- <div class="bg-white card" id="ActionConditionsDivdata">
- <div class="card-header"><i class="fa fa-angle-down conditionicon mr-1" style="font-size:20px" onclick="Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ToggleExecuteQueryConditions();"></i>Condition Details</div>
- <div class="card-body hidden" id="ActionConditionsDiv">
- <div class="ActionConditions">
- <!--For Action Conditions-->
- </div>
- </div>
- </div>
- </div>
- <div class="bg-white card-footer footer" id="CreateExecuteQueryFooter">
- <a href="javascript:;" id="btnCloseExecuteQuery" class="btn btn-light btn-sm mr-auto "> Close</a>
- <a href="javascript:;" id="btnSaveExecuteQuery" class="btn btn-primary btn-sm"> Save</a>
- </div>
- </div>
- </form>`;
- return html;
- }
- load(id, containerid, callback) {
- return __awaiter(this, void 0, void 0, function* () {
- var instance = this;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ActionId = instance.ActionId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleActionData = instance.RuleActionData;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RowIndex = instance.RowIndex;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().AutomationMode = instance.AutomationMode;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleProviderId = instance.RuleProviderId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ParentActionId = instance.ParentActionId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().IsAutomationMode = instance.IsAutomationMode;
- yield Unibase.Platform.Automation.Components.NotificationGroup.Instance().LoadNotificationGroups();
- if (instance.AutomationMode == Unibase.Platform.Automation.Enums.AutomationMode.AdvancedMode) {
- eval('bizgaze_automation_flow_main.getcontainerid("' + containerid + '")');
- }
- $("#btnCloseExecuteQuery").click(function () {
- $('#' + containerid).modal('hide');
- $('#' + containerid).remove();
- if (Unibase.Platform.Automation.Components.ExecuteQuery.Instance().AutomationMode == Unibase.Platform.Automation.Enums.AutomationMode.NormalMode) {
- if (Unibase.Platform.Automation.Components.ExecuteQuery.Instance().AutomationMode) {
- if (Unibase.Platform.Automation.Components.ExecuteQuery.Instance().IsAutomationMode) {
- Unibase.Platform.Automation.Components.Rule.Instance().ChangeAction(instance.RowIndex, id);
- }
- }
- }
- else {
- eval("bizgaze_automation_flow_main.getpopupclosed()");
- }
- Unibase.Platform.Automation.Components.Conditions.conditionArray = [];
- });
- $("#btnSaveExecuteQuery").click(function () {
- let appcontrolid = "frmUnibase_ExecuteQuery";
- let result = Unibase.Platform.Forms.Components.FormViewer.Instance().requiredFieldValidation(appcontrolid);
- if (result == false) {
- MessageHelper.Instance().showError("Mandatory fields are missing", "Validate_ExecuteQueryAction");
- return false;
- }
- else {
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().SaveExecuteQuery(id, containerid);
- }
- });
- $("#ddl_QueryType").val(1);
- if (instance.ParentActionId != 0) {
- Unibase.Platform.Automation.Components.ContactSelection.Instance().getResultActions(instance.ParentActionId);
- yield Unibase.Platform.Automation.Components.ExecuteQuery.Instance().GetRuleActionInfo(Number(instance.ParentActionId));
- $('#ddl_NotificationGrp').prop("disabled", true);
- $('#creategrp_btn').addClass('d-none');
- }
- $('#creategrp_btn').click(function () {
- Unibase.Platform.Automation.Components.NotificationGroup.Instance().init(0, null, true);
- });
- if (id != "") {
- setTimeout(function () { Unibase.Platform.Automation.Components.ExecuteQuery.Instance().EditExecuteQuery(id); }, 10);
- }
- let rpid = instance.RuleProviderId;
- if (rpid != 0) {
- Unibase.Platform.Automation.Components.ContactSelection.Instance().loadQueryBuilder(rpid, null);
- Unibase.Platform.Automation.Managers.RuleManager.Instance().getTokens(instance.RuleProviderId).then(function (response) {
- var Data = new Array();
- for (let i = 0; i <= response.length - 1; i++) {
- var result = response[i];
- Data.push(result);
- }
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().loadSummernote(Data);
- });
- }
- if (instance.RuleActionData.length != 0) {
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().LoadExecuteQueryData(instance.RuleActionData);
- }
- });
- }
- GetRuleActionInfo(parentactionid) {
- return __awaiter(this, void 0, void 0, function* () {
- yield Unibase.Platform.Automation.Managers.RuleManager.Instance().getRuleAction(parentactionid).then(function (response) {
- if (response != null) {
- var html = '<option value=' + response.NotificationGroupId + ' selected>' + response.NotificationGroupName + '</option>';
- $('#ddl_NotificationGrp').html('').html(html);
- }
- });
- });
- }
- ToggleExecuteQueryConditions() {
- $('#ActionConditionsDiv').toggleClass("hidden");
- if ($('.conditionicon').hasClass('fa-angle-down')) {
- $('.conditionicon').removeClass('fa-angle-down').addClass('fa-angle-up');
- Unibase.Platform.Automation.Components.ContactSelection.Instance().loadQueryBuilder(Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleProviderId, null);
- }
- else {
- $('.conditionicon').removeClass('fa-angle-up').addClass('fa-angle-down');
- }
- }
- Toggleadvancedoptions() {
- if ($('.arrowicon').hasClass('fa-angle-down')) {
- $('.arrowicon').removeClass('fa-angle-down').addClass('fa-angle-up');
- }
- else {
- $('.arrowicon').removeClass('fa-angle-up').addClass('fa-angle-down');
- }
- $('.Advanced_options').toggleClass("hidden");
- }
- EditExecuteQuery(id) {
- let actionid = Number(id);
- $("#Spn_ExecuteQuery").text("Edit Execute Query");
- Unibase.Platform.Automation.Managers.RuleManager.Instance().getRuleAction(actionid).then(function (response) {
- $("#txtExecuteQuery_RuleActionName").val(response.RuleActionName);
- $('#ddl_NotificationGrp option[value=' + response.NotificationGroupId + ']').prop('selected', true);
- if (!Unibase.Platform.Automation.Components.ExecuteQuery.Instance().IsAutomationMode) {
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleId = response.RuleId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleEventId = response.RuleEventId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().EventGroupId = response.EventGroupId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ActionId = response.ActionId;
- Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ParentActionId = response.ParentActionId;
- }
- $("#ddl_QueryType").val(response.String4);
- $("#ddl_QueryType").attr("disabled", "disabled");
- $('#message_result').val(Number(response.BString5));
- if (response.ResultActionId != null) {
- $('#ddl_ResultAction').val(response.ResultActionId);
- }
- if (response.ExecuteStatusId != Number(Unibase.Platform.Automation.Enums.ExecuteActionStatus.Approved))
- $("#chkAutoApprovedExecuteQuery").prop("checked", false);
- else
- $("#chkAutoApprovedExecuteQuery").prop("checked", true);
- if (response.BString2 == "1") {
- $("#chkIsAsync").prop("checked", true);
- }
- else {
- $("#chkIsAsync").prop("checked", false);
- }
- $('.summernote__Query').summernote("code", response.BString1);
- Unibase.Platform.Automation.Components.ContactSelection.Instance().loadQueryBuilder(response.RuleProviderId, response.SqlWhere);
- $("#btn_ActionConditions").addClass("hidden");
- if (response.SqlWhere != null && response.SqlWhere != "") {
- $('.conditionicon').removeClass('fa-angle-down').addClass('fa-angle-up');
- $("#ActionConditionsDiv").removeClass("hidden");
- }
- eval('_floatingLabelHelper.init();');
- });
- }
- LoadExecuteQueryData(Data) {
- for (var i = 0; i < Data.length; i++) {
- $("#txtExecuteQuery_RuleActionName").val(Data[i].RuleActionName);
- $("#txtExecuteQuery_ApiParameter").val(Data[i].BString1);
- if (!Data[i].AutoApproved)
- $("#chkAutoApprovedExecuteQuery").prop("checked", false);
- else
- $("#chkAutoApprovedExecuteQuery").prop("checked", true);
- if (Data[i].BString2 == "1") {
- $("#chkIsAsync").prop("checked", true);
- }
- else {
- $("#chkIsAsync").prop("checked", false);
- }
- $('.summernote__Query').summernote("code", Data[i].BString1);
- if (Data[i].SqlWhere != "" && Data[i].SqlWhere != null) {
- Unibase.Platform.Automation.Components.ContactSelection.Instance().loadQueryBuilder(Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleProviderId, Data[i].SqlWhere);
- $("#btn_ActionConditions").addClass("hidden");
- $('.conditionicon').removeClass('fa-angle-down').addClass('fa-angle-up');
- $("#ActionConditionsDiv").removeClass("hidden");
- }
- eval('_floatingLabelHelper.init();');
- }
- }
- SaveExecuteQuery(ExecuteQueryid, containerid) {
- let ruleactionid = Number(ExecuteQueryid);
- var contents = $('.summernote__Query').summernote('code');
- var plainText = $("<p>" + contents + "</p>").text();
- let queryelmnt = $("#builder");
- let model = new Unibase.Platform.Automation.Requests.RuleAction();
- model.RuleActionId = ruleactionid;
- model.RuleActionName = $("#txtExecuteQuery_RuleActionName").val().toString();
- model.BString1 = plainText;
- model.String4 = Number($("#ddl_QueryType option:selected").val());
- model.BString5 = $('#message_result option:selected').val().toString();
- model.ActionId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ActionId;
- model.RuleId = 0;
- model.Users = "";
- model.NotificationGroupId = $('#ddl_NotificationGrp').val() == undefined ? 0 : Number($('#ddl_NotificationGrp').val());
- if (model.NotificationGroupId == 0) {
- MessageHelper.Instance().showError("Please Select Notification Group", "Validate_ExecuteQueryAction");
- return;
- }
- let query = queryelmnt.queryBuilder('getSQL', false, true);
- if (query != null) {
- model.SqlWhere = queryelmnt.queryBuilder('getSQL', false, true).sql.replace(/\n/g, " ").replace(/LIKE/g, "ILIKE");
- ;
- model.SqlWhereJson = JSON.stringify(queryelmnt.queryBuilder('getSQL', false, true));
- }
- else {
- model.SqlWhere = "";
- model.SqlWhereJson = "";
- }
- model.ResultActionId = Number($("#ddl_ResultAction option:selected").val());
- if (model.ResultActionId != 0) {
- model.ResultActionName = $("#ddl_ResultAction option:selected").text();
- }
- else {
- model.ResultActionName = "";
- }
- if ($('#chkIsAsync').is(':checked')) {
- model.BString2 = "1";
- }
- else {
- model.BString2 = "0";
- }
- model.DelayTime = 0;
- model.ParentActionId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ParentActionId;
- model.AutoApproved = $('#chkAutoApprovedExecuteQuery').is(':checked');
- model.RowIndex = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RowIndex;
- if (Unibase.Platform.Automation.Components.ExecuteQuery.Instance().IsAutomationMode) {
- if (Unibase.Platform.Automation.Components.ExecuteQuery.Instance().AutomationMode == Unibase.Platform.Automation.Enums.AutomationMode.NormalMode) {
- Unibase.Platform.Automation.Components.Rule.Instance().RuleActionsArray(model);
- $('#' + containerid).modal('hide');
- $('#' + containerid).remove();
- Unibase.Platform.Automation.Components.Conditions.conditionArray = [];
- }
- else {
- model.RuleId = eval("bizgaze_automation_flow_main.getruleid()");
- Automation.Managers.RuleManager.Instance().saveRuleAction(model).then(function (response) {
- if (response.status == Unibase.Data.Status.Error) {
- MessageHelper.Instance().showError(response.message, "Validate_ExecuteQueryAction");
- }
- else {
- MessageHelper.Instance().showSuccess(response.message, "Validate_ExecuteQueryAction");
- $('#' + containerid).modal('hide');
- $('#' + containerid).remove();
- Unibase.Platform.Automation.Components.Conditions.conditionArray = [];
- var actionname = response.result.RuleActionName;
- eval("bizgaze_automation_flow_main.saveExecuteQueryblock('" + response.result.RuleActionId + "','" + actionname + "')");
- }
- });
- }
- }
- else {
- model.RuleId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleId;
- model.EventGroupId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().EventGroupId;
- model.RuleEventId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().RuleEventId;
- model.ActionId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ActionId;
- model.ParentActionId = Unibase.Platform.Automation.Components.ExecuteQuery.Instance().ParentActionId;
- Automation.Managers.RuleManager.Instance().saveRuleAction(model).then(function (response) {
- if (response.status == Unibase.Data.Status.Error) {
- MessageHelper.Instance().showError(response.message, "Validate_ExecuteQueryAction");
- }
- else {
- MessageHelper.Instance().showSuccess(response.message, "Validate_ExecuteQueryAction");
- $('#' + containerid).modal('hide');
- $('#' + containerid).remove();
- Unibase.Platform.Automation.Components.Conditions.conditionArray = [];
- }
- });
- }
- }
- loadSummernote(Data) {
- $(".summernote__Query").summernote({
- height: 100,
- minHeight: null,
- maxHeight: null,
- placeholder: "Query",
- disableDragAndDrop: true,
- codemirror: {
- mode: 'text/html',
- lineNumbers: true
- },
- toolbar: [
- ['font', ['bold', 'italic', 'underline']],
- ['color', ['color']],
- ['view', ['fullscreen', 'codeview', 'help']],
- ],
- hint: {
- match: /\B[@!](\w*)$/,
- search: function (keyword, callback) {
- callback($.grep(Data, function (i) {
- var user = i;
- return user.indexOf(keyword) === 0;
- }));
- },
- content: function (i) {
- var user = i;
- return $('<span>@' + user + '</span>')[0];
- }
- }
- });
- }
- static Instance() {
- if (this.instance === undefined) {
- this.instance = new ExecuteQuery();
- }
- return this.instance;
- }
- }
- Components.ExecuteQuery = ExecuteQuery;
- })(Components = Automation.Components || (Automation.Components = {}));
- })(Automation = Platform.Automation || (Platform.Automation = {}));
- })(Platform = Unibase.Platform || (Unibase.Platform = {}));
- })(Unibase || (Unibase = {}));
|