From 9614a6e8ee19924e528f770b5b1310a2f7169052 Mon Sep 17 00:00:00 2001 From: ZitRo Date: Tue, 28 Apr 2015 12:36:10 +0300 Subject: [PATCH 1/4] clickable class header refers to documentation --- cache/projectTemplate.xml | 1 + web/css/classView.css | 8 ++++++++ web/js/ClassView.js | 22 ++++++++++++++++++++-- web/jsLib/joint.js | 6 +++++- web/jsLib/joint.shapes.uml.js | 10 ++++++++-- 5 files changed, 42 insertions(+), 5 deletions(-) diff --git a/cache/projectTemplate.xml b/cache/projectTemplate.xml index 70eef77..50cb861 100644 --- a/cache/projectTemplate.xml +++ b/cache/projectTemplate.xml @@ -58,6 +58,7 @@ return structured data about class set oClass = ##class(%ZEN.proxyObject).%New() set oProperties = ##class(%ZEN.proxyObject).%New() + set oClass.NAMESPACE = $NAMESPACE set oClass.super = classDefinition.Super set oClass.properties = oProperties set count = classDefinition.Properties.Count() diff --git a/web/css/classView.css b/web/css/classView.css index b76de0d..323c708 100644 --- a/web/css/classView.css +++ b/web/css/classView.css @@ -28,4 +28,12 @@ text { .centralText > div { display: table-cell; vertical-align: middle; +} + +.uml-class-name-text { + cursor: help; +} + +.uml-class-name-text:hover { + fill: red; } \ No newline at end of file diff --git a/web/js/ClassView.js b/web/js/ClassView.js index 4847881..01eed74 100644 --- a/web/js/ClassView.js +++ b/web/js/ClassView.js @@ -18,6 +18,8 @@ var ClassView = function (parent, container) { this.MIN_PAPER_SCALE = 0.2; this.MAX_PAPER_SCALE = 4; + this.CLASS_DOC_PATH = "/csp/documatic/%25CSP.Documatic.cls"; + this.init(); }; @@ -60,6 +62,16 @@ ClassView.prototype.resetView = function () { }; +ClassView.prototype.openClassDoc = function (className, nameSpace) { + + window.open( + this.CLASS_DOC_PATH + "?LIBRARY=" + encodeURIComponent(nameSpace) + + "&CLASSNAME=" + encodeURIComponent(className), + "_blank" + ); + +}; + /** * @param {string} name * @param classMetaData @@ -70,7 +82,8 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { var attrArr, methArr, classParams = classMetaData["parameters"], classProps = classMetaData["properties"], - classMethods = classMetaData["methods"]; + classMethods = classMetaData["methods"], + self = this; var insertString = function (array, string, extraString) { string.match(/.{1,44}/g).forEach(function (p) { @@ -79,7 +92,7 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { }; return new joint.shapes.uml.Class({ - name: name, + name: name + "\x1b" + JSON.stringify({ url: function () {alert(name)} }), attributes: attrArr = (function (params, ps) { var arr = [], n; for (n in params) { @@ -108,6 +121,11 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { } return arr; })(classMethods), + directProps: { + nameClickHandler: function () { + self.openClassDoc(name, classMetaData["NAMESPACE"]); + } + }, size: { width: 300, height: Math.max(attrArr.length*12.1, 15) + Math.max(methArr.length*12.1, 15) + 40 diff --git a/web/jsLib/joint.js b/web/jsLib/joint.js index 5321c7b..a9f2615 100644 --- a/web/jsLib/joint.js +++ b/web/jsLib/joint.js @@ -17222,6 +17222,10 @@ if ( typeof window === "object" && typeof window.document === "object" ) { tspan.node.style[j] = setup["STYLES"][j]; } } + if (opt.clickHandler) { + console.log(1); + tspan.node.onclick = opt.clickHandler; + } } // Make sure the textContent is never empty. If it is, add an additional // space (an invisible character) so that following lines are correctly @@ -20943,7 +20947,7 @@ joint.dia.ElementView = joint.dia.CellView.extend({ $selected.each(function() { - V(this).text(attrs.text + '', { lineHeight: attrs.lineHeight, textPath: attrs.textPath }); + V(this).text(attrs.text + '', attrs); }); specialAttributes.push('lineHeight','textPath'); } diff --git a/web/jsLib/joint.shapes.uml.js b/web/jsLib/joint.shapes.uml.js index 4427e7e..603f9f7 100644 --- a/web/jsLib/joint.shapes.uml.js +++ b/web/jsLib/joint.shapes.uml.js @@ -82,7 +82,8 @@ joint.shapes.uml.Class = joint.shapes.basic.Generic.extend({ updateRectangles: function() { - var attrs = this.get('attrs'); + var attrs = this.get('attrs'), + self = this; var rects = [ { type: 'name', text: this.getClassName() }, @@ -92,15 +93,20 @@ joint.shapes.uml.Class = joint.shapes.basic.Generic.extend({ var offsetY = 0; + var dp = self.get("directProps") || {}, + nameClickHandler = dp.nameClickHandler; + _.each(rects, function(rect) { var lines = _.isArray(rect.text) ? rect.text : [rect.text]; var rectHeight = lines.length * 20 + 20; attrs['.uml-class-' + rect.type + '-text'].text = lines.join('\n'); + if (nameClickHandler) { + if (rect.type === "name") attrs['.uml-class-' + rect.type + '-text'].clickHandler = nameClickHandler; + } attrs['.uml-class-' + rect.type + '-rect'].height = rectHeight; attrs['.uml-class-' + rect.type + '-rect'].transform = 'translate(0,'+ offsetY + ')'; - offsetY += rectHeight; }); From 37f7521440d23bb92f8fa628635febef44a3f6a0 Mon Sep 17 00:00:00 2001 From: ZitRo Date: Tue, 28 Apr 2015 12:39:21 +0300 Subject: [PATCH 2/4] private and public methods visualization --- web/js/ClassView.js | 3 ++- web/jsLib/joint.js | 1 - 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/web/js/ClassView.js b/web/js/ClassView.js index 01eed74..c342d68 100644 --- a/web/js/ClassView.js +++ b/web/js/ClassView.js @@ -112,7 +112,8 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { for (n in met) { insertString( arr, - "+ " + n + (met[n]["returns"] ? ": " + met[n]["returns"] : ""), + (met[n]["private"] ? "- " : "+ ") + n + + (met[n]["returns"] ? ": " + met[n]["returns"] : ""), (met[n]["classMethod"] ? "\x1b" + JSON.stringify({STYLES:{ textDecoration: "underline" diff --git a/web/jsLib/joint.js b/web/jsLib/joint.js index a9f2615..9e8085c 100644 --- a/web/jsLib/joint.js +++ b/web/jsLib/joint.js @@ -17223,7 +17223,6 @@ if ( typeof window === "object" && typeof window.document === "object" ) { } } if (opt.clickHandler) { - console.log(1); tspan.node.onclick = opt.clickHandler; } } From 84069657b9b6dd0376c455a0fe4180fff8d00b51 Mon Sep 17 00:00:00 2001 From: ZitRo Date: Tue, 28 Apr 2015 13:03:35 +0300 Subject: [PATCH 3/4] abstract classes visual differences --- web/js/ClassView.js | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/web/js/ClassView.js b/web/js/ClassView.js index c342d68..cf3f8fc 100644 --- a/web/js/ClassView.js +++ b/web/js/ClassView.js @@ -79,7 +79,7 @@ ClassView.prototype.openClassDoc = function (className, nameSpace) { */ ClassView.prototype.createClassInstance = function (name, classMetaData) { - var attrArr, methArr, + var attrArr, methArr, nameArr, classParams = classMetaData["parameters"], classProps = classMetaData["properties"], classMethods = classMetaData["methods"], @@ -92,7 +92,7 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { }; return new joint.shapes.uml.Class({ - name: name + "\x1b" + JSON.stringify({ url: function () {alert(name)} }), + name: nameArr = (classMetaData["ABSTRACT"] ? ["<>", name] : [name]), attributes: attrArr = (function (params, ps) { var arr = [], n; for (n in params) { @@ -129,7 +129,8 @@ ClassView.prototype.createClassInstance = function (name, classMetaData) { }, size: { width: 300, - height: Math.max(attrArr.length*12.1, 15) + Math.max(methArr.length*12.1, 15) + 40 + height: Math.max(nameArr.length*12.1, 0) + Math.max(attrArr.length*12.1, 0) + + Math.max(methArr.length*12.1, 0) + 30 } }); From 4c5b4b72cd8a3397bc5dc0aadabab3554e70cec3 Mon Sep 17 00:00:00 2001 From: ZitRo Date: Tue, 28 Apr 2015 14:06:41 +0300 Subject: [PATCH 4/4] opening class tree and focusing on displayed class item when page opens --- web/css/treeView.css | 2 +- web/js/ClassTree.js | 31 +++++++++++++++++++++---------- web/js/ClassView.js | 2 ++ 3 files changed, 24 insertions(+), 11 deletions(-) diff --git a/web/css/treeView.css b/web/css/treeView.css index eb231b2..57b928b 100644 --- a/web/css/treeView.css +++ b/web/css/treeView.css @@ -11,7 +11,7 @@ display: none; } -.tv-class-name.selected { +.tv-class-name.selected, .tv-package-name.selected { box-shadow: inset 0 0 2px 2px #ffcc1b; } diff --git a/web/js/ClassTree.js b/web/js/ClassTree.js index b3b8b6a..9f55e26 100644 --- a/web/js/ClassTree.js +++ b/web/js/ClassTree.js @@ -65,7 +65,9 @@ ClassTree.prototype.packageSelected = function (element, packageName) { ClassTree.prototype.updateTree = function (treeObject) { var self = this, - div = function () { return document.createElement("div"); }; + div = function () { return document.createElement("div");}, + selectedClassElement = this.SELECTED_CLASS_NAME ? this.SELECTED_CLASS_NAME.split(".") : [], + sce = 0; // selectedClassElement level index var packageClick = function (e) { @@ -87,24 +89,32 @@ ClassTree.prototype.updateTree = function (treeObject) { }; - var append = function (rootElement, elementName, isPackage, path) { + var append = function (rootElement, elementName, isPackage, path, level) { - var el1 = div(), + var sel = selectedClassElement.length + && sce === level && selectedClassElement[sce] === elementName ? ++sce : null, + el1 = div(), el2, el3, el4; if (isPackage) { el1.className = "tv-package"; - (el2 = div()).className = "tv-package-name minimized"; el2.textContent = elementName; + (el2 = div()).className = "tv-package-name" + (sel ? "" : " minimized"); + el2.textContent = elementName; + if (sel && sce === selectedClassElement.length) { + el2.className += " selected"; + self.SELECTED_ELEMENT = el2; + } (el3 = div()).className = "tv-package-content"; el1.appendChild(el2); el1.appendChild(el3); el2.addEventListener("click", packageClick); el2.appendChild(el4 = div()); el4.className = "tv-rightListIcon icon list"; el4.addEventListener("click", function () { - self.packageSelected(el1, (path ? path + "." : path) + elementName); + self.packageSelected(el2, (path ? path + "." : path) + elementName); }); } else { - el1.className = "tv-class-name"; + if (sel) self.SELECTED_ELEMENT = el1; + el1.className = "tv-class-name" + (sel ? " selected" : ""); el1.textContent = elementName; el1.addEventListener("click", classClick); el1.CLASS_NAME = path + (path ? "." : "") + elementName; @@ -116,7 +126,7 @@ ClassTree.prototype.updateTree = function (treeObject) { }; - var build = function (rootElement, object, path) { + var build = function (rootElement, object, path, level) { var i, element, rec, arr = []; @@ -136,15 +146,16 @@ ClassTree.prototype.updateTree = function (treeObject) { rootElement, element.name, typeof element.val === "object", - path.join(".") + path.join("."), + level )) { - build(rec, element.val, path.concat([element.name])); + build(rec, element.val, path.concat([element.name]), level + 1); } } }; - build(this.container, treeObject, []); + build(this.container, treeObject, [], 0); this.removeLoader(); diff --git a/web/js/ClassView.js b/web/js/ClassView.js index cf3f8fc..224188d 100644 --- a/web/js/ClassView.js +++ b/web/js/ClassView.js @@ -214,6 +214,7 @@ ClassView.prototype.loadClass = function (className) { var self = this; + this.cacheUMLExplorer.classTree.SELECTED_CLASS_NAME = className; this.showLoader(); this.cacheUMLExplorer.source.getClassView(className, function (err, data) { //console.log(data); @@ -235,6 +236,7 @@ ClassView.prototype.loadPackage = function (packageName) { var self = this; + this.cacheUMLExplorer.classTree.SELECTED_CLASS_NAME = packageName; this.showLoader(); this.cacheUMLExplorer.source.getPackageView(packageName, function (err, data) { //console.log(data);