From: Charles du Jeu Date: Thu, 15 Jan 2009 08:50:52 +0000 (+0000) Subject: Use JmsClient instead of AmqClient X-Git-Tag: argeo-slc-2.1.7~2191 X-Git-Url: http://git.argeo.org/?a=commitdiff_plain;ds=inline;h=52892a27cdd31de7378992b1124fe58c71f2f6a5;p=gpl%2Fargeo-slc.git Use JmsClient instead of AmqClient git-svn-id: https://svn.argeo.org/slc/trunk@2100 4cfe0d0a-d680-48aa-b62c-e0a02a3f76cc --- diff --git a/org.argeo.slc.webapp/src/main/webapp/argeo-ria-lib/slc/class/org/argeo/slc/ria/LauncherApplet.js b/org.argeo.slc.webapp/src/main/webapp/argeo-ria-lib/slc/class/org/argeo/slc/ria/LauncherApplet.js index a8886acc8..b008aba06 100644 --- a/org.argeo.slc.webapp/src/main/webapp/argeo-ria-lib/slc/class/org/argeo/slc/ria/LauncherApplet.js +++ b/org.argeo.slc.webapp/src/main/webapp/argeo-ria-lib/slc/class/org/argeo/slc/ria/LauncherApplet.js @@ -51,6 +51,11 @@ qx.Class.define("org.argeo.slc.ria.LauncherApplet", command : null } } + }, + registeredTopics : { + init : {}, + check : "Map", + event : "changeRegisteredTopics" } }, @@ -64,23 +69,40 @@ qx.Class.define("org.argeo.slc.ria.LauncherApplet", this.setView(viewPane); this._createLayout(); this._createForm(); - this._amqClient = new org.argeo.ria.remote.AmqClient(); - this._amqClient.startPolling(); - qx.io.remote.RequestQueue.getInstance().setDefaultTimeout(30000); + this._amqClient = org.argeo.ria.remote.JmsClient.getInstance(); + this._amqClient.startPolling(); }, /** - * Load a given row : the data passed must be a simple data array. - * @param data {Element} The text xml description. + * */ load : function(){ - this.getView().setViewTitle("Slc Execution Launcher"); - org.argeo.ria.event.CommandsManager.getInstance().getCommandById("reloadagents").execute(); + this.getView().setViewTitle("Execution Launcher"); + this.addListener("changeRegisteredTopics", function(event){ + this._refreshTopicsSubscriptions(event); + this._feedSelector(event); + }, this); + var reloadHandler = function(message){ + org.argeo.ria.event.CommandsManager.getInstance().getCommandById("reloadagents").execute(); + } + this._amqClient.addListener("agentregister", "topic://agent.register", reloadHandler, this); + //qx.event.Timer.once(function(){ + this._amqClient.addListener("agentunregister", "topic://agent.unregister", reloadHandler, this); + //}, this, 500); + reloadHandler(); }, addScroll : function(){ return false; }, + + close : function(){ + this._amqClient.removeListener("agentregister", "topic://agent.register"); + this._amqClient.removeListener("agentunregister", "topic://agent.unregister"); + + this.setRegisteredTopics({}); + this._amqClient.stopPolling(); + }, _createLayout : function(){ this.formPane = new qx.ui.container.Composite(new qx.ui.layout.VBox(5)); @@ -130,14 +152,22 @@ qx.Class.define("org.argeo.slc.ria.LauncherApplet", var serviceManager = org.argeo.ria.remote.RequestManager.getInstance(); serviceManager.addListener("reload", function(reloadEvent){ if(reloadEvent.getDataType()!= "agents") return ; - this._xmlListToSelector(reloadEvent.getContent(), this.agentSelector); + var xmlDoc = reloadEvent.getContent(); + var NSMap = {slc:"http://argeo.org/projects/slc/schemas"}; + var nodes = org.argeo.ria.util.Element.selectNodes(xmlDoc, "//slc:slc-agent-descriptor", NSMap); + var newTopics = {}; + for(var i=0;i