From 637af47ad9f91d5b91f742a1eea4041ee1b019c4 Mon Sep 17 00:00:00 2001 From: Anaël Closson Date: Tue, 5 Sep 2017 13:33:34 +0200 Subject: Add holmes GUI without properties MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Change-Id: Ie961076abf2d57e3e917cab0012f6799bbe7762a Issue-Id: CLAMP-27 Signed-off-by: Anaël Closson --- .../META-INF/resources/designer/css/app.css | 1 + .../META-INF/resources/designer/css/diagram-js.css | 2 +- .../resources/designer/images/clds-holmes-icon.png | Bin 0 -> 522 bytes .../resources/META-INF/resources/designer/index.js | 77 +++++++++++++++++++-- .../partials/portfolios/holmes_properties.html | 39 +++++++++++ .../resources/designer/scripts/CldsModelService.js | 1 + .../META-INF/resources/designer/scripts/app.js | 33 +++++++++ 7 files changed, 148 insertions(+), 5 deletions(-) create mode 100644 src/main/resources/META-INF/resources/designer/images/clds-holmes-icon.png create mode 100644 src/main/resources/META-INF/resources/designer/partials/portfolios/holmes_properties.html diff --git a/src/main/resources/META-INF/resources/designer/css/app.css b/src/main/resources/META-INF/resources/designer/css/app.css index 44733b6f2..333c96669 100644 --- a/src/main/resources/META-INF/resources/designer/css/app.css +++ b/src/main/resources/META-INF/resources/designer/css/app.css @@ -181,6 +181,7 @@ svg:not(:root) { } /* '' */ .icon-initial-node:before{ content: url('../images/InitialProcess.png'); } /* '' */ .icon-collector-node:before{ content: url('../images/clds-collector-icon.png'); } /* '' */ +.icon-holmes-node:before{ content: url('../images/clds-holmes-icon.png'); } /* '' */ .icon-ves-collector-node:before{ content: url('../images/clds-ves-collector-icon.png'); } /* '' */ .icon-stringmatch-node:before{ content: url('../images/clds-string-match-icon.png'); } /* '' */ .icon-tca-node:before{ content: url('../images/clds-tca-icon.png'); } /* '' */ diff --git a/src/main/resources/META-INF/resources/designer/css/diagram-js.css b/src/main/resources/META-INF/resources/designer/css/diagram-js.css index 8796603ae..77fcd5126 100644 --- a/src/main/resources/META-INF/resources/designer/css/diagram-js.css +++ b/src/main/resources/META-INF/resources/designer/css/diagram-js.css @@ -231,7 +231,7 @@ svg.drop-not-ok { x: 400px; y: 10px; height: 50px; - width: 326px; + width: 400px; } .djs-palette:not(.open) { diff --git a/src/main/resources/META-INF/resources/designer/images/clds-holmes-icon.png b/src/main/resources/META-INF/resources/designer/images/clds-holmes-icon.png new file mode 100644 index 000000000..f928ddf9d Binary files /dev/null and b/src/main/resources/META-INF/resources/designer/images/clds-holmes-icon.png differ diff --git a/src/main/resources/META-INF/resources/designer/index.js b/src/main/resources/META-INF/resources/designer/index.js index a0e918734..75c175a8a 100644 --- a/src/main/resources/META-INF/resources/designer/index.js +++ b/src/main/resources/META-INF/resources/designer/index.js @@ -1560,6 +1560,45 @@ function visibility_model() return lane; }, + 'bpmn:Holmes': function(p, element) { + var lane = renderer('bpmn:Lane')(p, element, { + fill: 'White' + }); + + var expandedPool = DiUtil.isExpanded(element); + + var instanceName = getSemantic(element).name; + if (expandedPool) { + + if (instanceName == undefined) { + instanceName = 'Holmes'; + } + + // add holmes 'icon' + var attrs = computeStyle({}, { + stroke: 'black', + strokeWidth: 1, + fill: 'white' + }); + p.circle(15, 15, 10).attr(attrs) + textUtil.createText(p, "H", { align: 'left-top', 'padding': { top:6, left:11 } }); + } + + renderLabel(p, instanceName, { + box: element, + align: 'center-middle' + }); + + var participantMultiplicity = !!(getSemantic(element).participantMultiplicity); + + if (participantMultiplicity) { + renderer('ParticipantMultiplicityMarker')(p, element); + } + + return lane; + }, + + 'bpmn:StringMatch': function(p, element) { var lane = renderer('bpmn:Lane')(p, element, { fill: 'White' @@ -3821,7 +3860,22 @@ function visibility_model() } }); } - + if (bpmnElement.$instanceOf('bpmn:Holmes')) { + assign(actions, { + 'Properties': { + group: 'clds', + label: 'Edit Properties', + className: 'clds-edit-properties', + title: 'Properties', + action: { + click: function(event) { + lastElementSelected=bpmnElement.id + HolmesWindow(bpmnElement); + } + } + } + }); + } if (bpmnElement.$instanceOf('bpmn:TCA')) { assign(actions, { 'Properties': { @@ -4961,8 +5015,12 @@ function visibility_model() height: 80 }; } - - + if (semantic.$instanceOf('bpmn:Holmes')) { + return { + width: 120, + height: 80 + }; + } if (semantic.$instanceOf('bpmn:TCA')) { return { width: 120, @@ -6480,7 +6538,11 @@ function visibility_model() ), 'create.ves-collector': createAction( 'bpmn:VesCollector', 'event', 'icon-ves-collector-node', 'Ves Collector' - ), + ), + 'create.holmes': createAction( + 'bpmn:Holmes', 'event', 'icon-holmes-node', 'Holmes' + ), + 'create.TCA': createAction( 'bpmn:TCA', 'event', 'icon-tca-node', 'TCA' @@ -14328,6 +14390,13 @@ function visibility_model() "Activity", "InteractionNode" ] + }, + { + "name": "Holmes", + "superClass": [ + "Activity", + "InteractionNode" + ] }, { diff --git a/src/main/resources/META-INF/resources/designer/partials/portfolios/holmes_properties.html b/src/main/resources/META-INF/resources/designer/partials/portfolios/holmes_properties.html new file mode 100644 index 000000000..f4c3d6762 --- /dev/null +++ b/src/main/resources/META-INF/resources/designer/partials/portfolios/holmes_properties.html @@ -0,0 +1,39 @@ + + + +
+ + + + + +
diff --git a/src/main/resources/META-INF/resources/designer/scripts/CldsModelService.js b/src/main/resources/META-INF/resources/designer/scripts/CldsModelService.js index 86fedc9a2..12d2d05d0 100644 --- a/src/main/resources/META-INF/resources/designer/scripts/CldsModelService.js +++ b/src/main/resources/META-INF/resources/designer/scripts/CldsModelService.js @@ -31,6 +31,7 @@ app.service('cldsModelService', ['alertService','$http', '$q', function (alertSe 'policy': PolicyWindow, 'collector': CollectorsWindow, 'vescollector': VesCollectorWindow, + 'holmes': HolmesWindow, }; key = name.split('_')[0].toLowerCase() diff --git a/src/main/resources/META-INF/resources/designer/scripts/app.js b/src/main/resources/META-INF/resources/designer/scripts/app.js index 3b1ffe941..8c2d3c333 100644 --- a/src/main/resources/META-INF/resources/designer/scripts/app.js +++ b/src/main/resources/META-INF/resources/designer/scripts/app.js @@ -1462,6 +1462,34 @@ var app = angular.module('clds-app', ['ngRoute', } }; + $scope.HolmesWindow = function(holmes) { + + if (isTemplate) { + var partial = 'partials/portfolios/Template_model.html' + } else { + var partial = 'partials/portfolios/holmes_properties.html' + } + + var dlg = dialogs + .create( + partial, + 'ImportSchemaCtrl', + holmes, + { + closable : true, + draggable : true + }, + { + size : 'lg', + keyboard : true, + backdrop : 'static', + windowClass : 'my-class' + }); + + dlg.result() + }; + + $scope.TCAWindow = function(tca) { if (isTemplate) { var dlg = dialogs @@ -1688,6 +1716,11 @@ function VesCollectorWindow(vesCollectorWin) { .VesCollectorWindow(vesCollectorWin); } +function HolmesWindow(holmesWin) { + angular.element(document.getElementById('navbar')).scope() + .HolmesWindow(holmesWin); +} + function F5Window() { angular.element(document.getElementById('navbar')).scope().F5Window(); -- cgit 1.2.3-korg