X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=server%2Forg.argeo.slc.ria%2Fsrc%2Fargeo-ria-lib%2Fjcr%2Fclass%2Forg%2Fargeo%2Fjcr%2Fria%2Fviews%2FPlainXmlViewer.js;h=ce938badacd410d61b56157f24fd0a1ccbcf7d2d;hb=3fa6f9082cb27ae94109d1de5013e88dc9cb895f;hp=28a2bc5441ad0a607a78d1b5cda0d284631e61c2;hpb=d452373ca35dbbb2d4b25362968a0f8e9ad71e90;p=gpl%2Fargeo-slc.git diff --git a/server/org.argeo.slc.ria/src/argeo-ria-lib/jcr/class/org/argeo/jcr/ria/views/PlainXmlViewer.js b/server/org.argeo.slc.ria/src/argeo-ria-lib/jcr/class/org/argeo/jcr/ria/views/PlainXmlViewer.js index 28a2bc544..ce938bada 100644 --- a/server/org.argeo.slc.ria/src/argeo-ria-lib/jcr/class/org/argeo/jcr/ria/views/PlainXmlViewer.js +++ b/server/org.argeo.slc.ria/src/argeo-ria-lib/jcr/class/org/argeo/jcr/ria/views/PlainXmlViewer.js @@ -1,4 +1,4 @@ -qx.Class.define("org.argeo.jcr.ria.views.XmlNodeEditor", { +qx.Class.define("org.argeo.jcr.ria.views.PlainXmlViewer", { extend : qx.ui.container.Composite, implement : [org.argeo.ria.components.IView], @@ -8,7 +8,21 @@ qx.Class.define("org.argeo.jcr.ria.views.XmlNodeEditor", { * See {@link org.argeo.ria.event.CommandsManager#definitions} for the keys to use for defining commands. */ commands : { - init : {} + init : { + "close" : { + label : "Close", + shared : true, + icon : "org.argeo.slc.ria/window-close.png", + shortcut : "Control+w", + enabled : true, + menu : null, + toolbar : null, + callback : function(e){ + org.argeo.ria.components.ViewsManager.getInstance().getViewPaneById("editor").closeCurrent(); + }, + command : null + } + } }, viewSelection : { nullable:false, @@ -21,9 +35,6 @@ qx.Class.define("org.argeo.jcr.ria.views.XmlNodeEditor", { instanceLabel : { init:"Xml Editor", event : "changeInstanceLabel" - }, - dataModel : { - } }, @@ -40,18 +51,17 @@ qx.Class.define("org.argeo.jcr.ria.views.XmlNodeEditor", { * @param data {Mixed} Any object or data passed by the initiator of the view * @return {Boolean} */ - init : function(viewPane, dataModel){ + init : function(viewPane, jcrNode){ + this._viewPane = viewPane; this.setViewSelection(new org.argeo.ria.components.ViewSelection(viewPane.getViewId())); this.setLayout(new qx.ui.layout.VBox()); - this.setDataModel(dataModel); - - this.input = new qx.ui.form.TextField(); - this.add(this.input); - this._attachInputToDM(); + this.setInstanceId("edit:" + jcrNode.getPath()); + this.setInstanceLabel("Node '" + jcrNode.getName()+"'"); this.htmlPane = new qx.ui.embed.Html(); this.htmlPane.setOverflow("auto", "auto"); + this.htmlPane.setDecorator("input"); this.add(this.htmlPane, {flex:1}); }, @@ -59,73 +69,69 @@ qx.Class.define("org.argeo.jcr.ria.views.XmlNodeEditor", { * The implementation should contain the real data loading (i.o. query...) * @return {Boolean} */ - load : function(){ - var dataModel = this.getDataModel(); - dataModel.addListener("changeContextNode", function(event){ - var xmlString = event.getData().toXmlString(true); - var TAG_START_PATTERN = new RegExp("<([0-9a-zA-Z\.]+)([^>]*)>", "gi"); - var TAG_END_PATTERN = new RegExp("", "gi"); - var TAG_CLOSE_PATTERN = new RegExp("(/?>)", "gi"); - var TAG_ATTRIBUTE = new RegExp("\\s([0-9a-zA-Z:]+)\\=\"([^\"]*)\"", "gi"); - // Not implemented yet - var TAG_COMMENT = new RegExp("()", "gi"); - var TAG_CDATA_START = new RegExp("(\\)", "gi"); - - xmlString = xmlString.replace(TAG_START_PATTERN, 'xml_div_begin<xml_tagname_begin$1xml_tagname_end$2>'); - xmlString = xmlString.replace(TAG_END_PATTERN, '</xml_tagname_begin$1xml_tagname_end>xml_div_end'); - xmlString = xmlString.replace(TAG_CLOSE_PATTERN, '>'); - - xmlString = xmlString.replace(TAG_ATTRIBUTE, ' xml_attname_begin$1xml_attname_end="xml_attvalue_begin$2xml_attvalue_end"'); - - //xmlString = qx.xml.String.escape(xmlString); - xmlString = xmlString.replace(new RegExp("(xml_div_begin)", "g"), '
'); - xmlString = xmlString.replace(new RegExp("(xml_div_end)", "g"), '
'); - xmlString = xmlString.replace(new RegExp("(xml_tagname_begin)", "g"), ''); - xmlString = xmlString.replace(new RegExp("(xml_tagname_end)", "g"), ''); - xmlString = xmlString.replace(new RegExp("(xml_attname_begin)", "g"), ''); - xmlString = xmlString.replace(new RegExp("(xml_attname_end)", "g"), ''); - xmlString = xmlString.replace(new RegExp("(xml_attvalue_begin)", "g"), ''); - xmlString = xmlString.replace(new RegExp("(xml_attvalue_end)", "g"), ''); - xmlString = '
' + xmlString + '
'; - this.htmlPane.setHtml(xmlString); - /* - var call = new qx.util.DeferredCall(function(){ - var htmlDom = this.htmlPane.getContentElement().getDomElement(); - var spans = qx.bom.Selector.query("span", htmlDom); - for(var i=0;i]*)>", "gi"); + var TAG_END_PATTERN = new RegExp("", "gi"); + var TAG_CLOSE_PATTERN = new RegExp("(/?>)", "gi"); + var TAG_ATTRIBUTE = new RegExp("\\s([0-9a-zA-Z:_]+)\\=\"([^\"]*)\"", "gi"); + // Not implemented yet + var TAG_COMMENT = new RegExp("()", "gi"); + var TAG_CDATA_START = new RegExp("(\\)", "gi"); + + xmlString = xmlString.replace(TAG_START_PATTERN, 'xml_div_begin<xml_tagname_begin$1xml_tagname_end$2>'); + xmlString = xmlString.replace(TAG_END_PATTERN, '</xml_tagname_begin$1xml_tagname_end>xml_div_end'); + xmlString = xmlString.replace(TAG_CLOSE_PATTERN, '>'); + + xmlString = xmlString.replace(TAG_ATTRIBUTE, ' xml_attname_begin$1xml_attname_end="xml_attvalue_begin$2xml_attvalue_end"'); + + //xmlString = qx.xml.String.escape(xmlString); + xmlString = xmlString.replace(new RegExp("(xml_div_begin)", "g"), '
'); + xmlString = xmlString.replace(new RegExp("(xml_div_end)", "g"), '
'); + xmlString = xmlString.replace(new RegExp("(xml_tagname_begin)", "g"), ''); + xmlString = xmlString.replace(new RegExp("(xml_tagname_end)", "g"), ''); + xmlString = xmlString.replace(new RegExp("(xml_attname_begin)", "g"), ''); + xmlString = xmlString.replace(new RegExp("(xml_attname_end)", "g"), ''); + xmlString = xmlString.replace(new RegExp("(xml_attvalue_begin)", "g"), ''); + xmlString = xmlString.replace(new RegExp("(xml_attvalue_end)", "g"), ''); + xmlString = '
' + xmlString + '
'; + this.htmlPane.setHtml(xmlString); + var call = new qx.util.DeferredCall(function(){ + var htmlDom = this.htmlPane.getContentElement().getDomElement(); + var spans = qx.bom.Selector.query("span", htmlDom); + for(var i=0;i