init : {\r
"reloadlogs" : {\r
label : "Reload Logs", \r
- icon : "resource/slc/view-refresh.png",\r
+ icon : "org.argeo.slc.ria/view-refresh.png",\r
shortcut : "Control+r",\r
enabled : true,\r
menu : null,\r
this._reloadLogger();\r
},\r
command : null\r
- } \r
+ },\r
+ "openrealized" : {\r
+ label : "Re-open",\r
+ icon : "org.argeo.slc.ria/document-open.png",\r
+ shortcut : "Control+o",\r
+ enabled : false,\r
+ menu : null,\r
+ toolbar : "realized",\r
+ callback : function(e){\r
+ var selection = this.getViewSelection();\r
+ var rowData = selection.getNodes()[0];\r
+ this.openRealized(rowData);\r
+ },\r
+ selectionChange : function(viewId, selection){\r
+ if(viewId != "logger") return;\r
+ this.setEnabled((selection!=null && selection.length==1));\r
+ },\r
+ command : null\r
+ }\r
}\r
}\r
},\r
this.setView(viewPane);\r
this.setViewSelection(new org.argeo.ria.components.ViewSelection(viewPane.getViewId())); \r
this._createLayout();\r
+ this.UIBus = org.argeo.ria.event.UIBus.getInstance();\r
},\r
\r
/**\r
* \r
*/\r
load : function(){\r
- this._reloadLogger(); \r
- this.timer = new qx.event.Timer(15000);\r
- this.timer.addListener("interval", this._reloadLogger, this);\r
- this.timer.start(); \r
+ this._reloadLogger();\r
+ this.UIBus.addListener("newSlcExecution", this._reloadLogger, this);\r
+ this.UIBus.addListener("updateSlcExecutionStatus", this._reloadLogger, this);\r
},\r
\r
addScroll : function(){\r
},\r
\r
close : function(){\r
- this.timer.stop();\r
+ this.UIBus.removeListener("newSlcExecution", this._reloadLogger, this);\r
+ this.UIBus.removeListener("updateSlcExecutionStatus", this._reloadLogger, this);\r
},\r
\r
+ openRealized : function(logData){\r
+ \r
+ // DEBUG PURPOSE\r
+ var CHECK_HOST = false;\r
+ \r
+ var uuid = logData[2];\r
+ var host = "charlie";// logData[1];\r
+ \r
+ \r
+ // 1. Check that both associated views are here\r
+ var batchView;\r
+ var flowsView;\r
+ try{\r
+ batchView = org.argeo.ria.components.ViewsManager.getInstance().getViewPaneById("batch").getContent();\r
+ flowsView = org.argeo.ria.components.ViewsManager.getInstance().getViewPaneById("selector").getContent();\r
+ }catch(e){\r
+ this.debug("Cannot find either bath or flows IView!");\r
+ }\r
+ if(!batchView || !flowsView) return; \r
+ \r
+ // 2. Check that at least a host with the same name exists.\r
+ var agentsMap = flowsView.getAgentsMap(); \r
+ var currentBatchId = batchView.getBatchAgentId();\r
+ if(currentBatchId != null){\r
+ var currentHost = agentsMap[currentBatchId];\r
+ if(currentHost != host){\r
+ this.error("Cannot re-open these flows on a different host. Please clear the batch first.");\r
+ return;\r
+ }\r
+ } \r
+ if(!qx.lang.Object.contains(agentsMap, host)){\r
+ this.error("Cannot find any agent running on '"+host+"'! Please start an agent on this host.");\r
+ return;\r
+ }\r
+ //console.log(currentBatchId);\r
+ if(currentBatchId == null){\r
+ var defaultId = qx.lang.Object.getKeyFromValue(agentsMap, host);\r
+ batchView.setBatchAgentId(defaultId);\r
+ }\r
+ \r
+ // 3. Call service to load execution message\r
+ var req = org.argeo.slc.ria.SlcApi.getRealizedFlowsService(uuid);\r
+ var handler = function(xmlDoc){ \r
+ var realizedFlows = org.argeo.ria.util.Element.selectNodes(xmlDoc, "slc:slc-execution/realized-flows/slc:realized-flow");\r
+ for(var i=0;i<realizedFlows.length;i++){\r
+ var newEntrySpec = new org.argeo.slc.ria.execution.BatchEntrySpec(null, null, realizedFlows[i]); \r
+ batchView.appendBatchEntrySpec(newEntrySpec);\r
+ } \r
+ };\r
+ req.addListener("completed", function(response){\r
+ handler(response.getContent());\r
+ });\r
+ // STUB CASE\r
+ req.addListener("failed", function(){\r
+ if(!window.xmlExecStub || !window.xmlExecStub[uuid]){ \r
+ return;\r
+ }\r
+ var xmlDoc = window.xmlExecStub[uuid];\r
+ handler(xmlDoc);\r
+ }); \r
+ req.send();\r
+ },\r
+ \r
/**\r
* Creates the applet layout\r
*/\r
return new qx.ui.table.columnmodel.Resize(obj)\r
}\r
});\r
- this.logPane.setDecorator(null);\r
- this._initLogger();\r
- this.add(this.logPane, {edge:'center'});\r
- },\r
- \r
- /**\r
- * Initialize the log table.\r
- */\r
- _initLogger : function(){\r
- this.logPane.set({ \r
+ var selectionModel = this.logPane.getSelectionModel();\r
+ selectionModel.addListener("changeSelection", function(e){\r
+ var viewSelection = this.getViewSelection();\r
+ viewSelection.setViewId("logger");\r
+ viewSelection.clear();\r
+ selectionModel.iterateSelection(function(index){\r
+ viewSelection.addNode(this.logModel.getRowData(index));\r
+ }, this);\r
+ }, this);\r
+ \r
+ this.logPane.set({ \r
+ decorator : null,\r
statusBarVisible: false,\r
showCellFocusIndicator:false\r
});\r
columnModel.getBehavior().setWidth(0, "30%");\r
columnModel.getBehavior().setWidth(1, "15%");\r
columnModel.getBehavior().setWidth(3, "12%"); \r
+ \r
+ this.add(this.logPane, {edge:'center'});\r
},\r
\r
/**\r