
 
flykit.namespace("flykit.flyted");
 
 

/*
 * ----------------------------------------------------------------
 *                             WIDGET
 * ----------------------------------------------------------------
 */







flykit.flyted.BatchWidget = function( service, renderer ) {
    var _context = "flykit.flyted.BatchWidget";
    try {
        
        flykit.debug("call private constructor", _context);
        this.__init__(service, renderer);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
    
}



 
 



/** @private */
flykit.flyted.BatchWidget.prototype._controller = null;

/**
 * @private
 * @type flykit.mvcutils.GenericModel2
 */ 
flykit.flyted.BatchWidget.prototype._model = null;

/**
 * @private
 */
flykit.flyted.BatchWidget.prototype._renderer = null;

/**
 * @private
 */
flykit.flyted.BatchWidget.prototype._service = null;










/**
 * @private
 */
flykit.flyted.BatchWidget.prototype.__init__ = function( service, renderer ) {
    var _context = "flykit.flyted.BatchWidget.prototype.__init__";
    try {
        
        this._service = service;
        this._renderer = renderer;
        
        flykit.debug("create a model", _context);
        this._model = new flykit.mvcutils.GenericModel2();
        this._model.setDefinition(flykit.flyted.BatchWidget.modelDefinition);
        
        flykit.debug("create a controller", _context);
        this._controller = new flykit.flyted.BatchWidget.Controller(this._model, service, this);
        
        flykit.debug("connect the renderer to the model", _context);
        this._renderer.connect(this._model);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};







/**
 * @public
 * @param {Array<String>} querynames
 * @param {Array<flykit.flybase.Gene>} genes
 */
flykit.flyted.BatchWidget.prototype.findImagesByGeneBatch = function( querynames, genes ) {
    var _context = "flykit.flyted.BatchWidget.prototype.findGenesByAnyNameBatch";
    try {
        
        flykit.debug("pass ["+querynames+"], ["+genes+"] through to controller", _context);
        this._controller.findImagesByGeneBatch(querynames, genes);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};








flykit.flyted.BatchWidget.prototype.clear = function() {
    var _context = "flykit.flyted.BatchWidget.prototype.clear";
    try {
        
        flykit.debug("clear", _context);
        this._controller.clear();
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
}









/*
 * ----------------------------------------------------------------
 *                             CONTROLLER
 * ----------------------------------------------------------------
 */






/**
 * @class
 */
flykit.flyted.BatchWidget.Controller = function( model, service, controllee ) {
    var _context = "flykit.flyted.BatchWidget.Controller";
    try {
        
        this._model = null;
        this._service = null;
        this._controllee = null;
        
        flykit.debug("call private constructor", _context);
        this.__init__(model, service, controllee);        
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};








/**
 * @private
 */
flykit.flyted.BatchWidget.Controller.prototype.__init__ = function( model, service, controllee ) {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype.__init__";
    try {
        
        this._model = model;
        this._service = service;
        this._controllee = controllee;
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};








/**
 * @public
 */
flykit.flyted.BatchWidget.Controller.prototype.findImagesByGeneBatch = function( querynames, genes ) {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype.findGenesByAnyNameBatch";
    try {
        
        flykit.info("findImagesByGeneBatch: "+querynames+" || "+genes, _context);
        flykit.debug("pass through to private implementation", _context);
        this._findImagesByGeneBatch(querynames, genes, this._findImagesByGeneBatchSuccess(), this._findImagesByGeneBatchFailure());
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};












/**
 * @private
 */
flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatch = function( querynames, genes, success, failure ) {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatch";
    try {
        
        flykit.debug("querynames: "+querynames, _context);
        flykit.debug("genes: "+genes, _context);
        
        flykit.debug("set state pending", _context);
        this._model.set("STATE", "PENDING");
        
        flykit.debug("set model property query", _context);
        this._model.set("QUERY", [querynames, genes]);
        
        flykit.debug("set mode full", _context);
        this._model.set("MODE", "FULL");

        flykit.debug("set result null", _context);
        this._model.set("RESULTS", null);
                
        flykit.debug("set message null", _context);
        this._model.set("MESSAGE", null);
                
        var flybaseids = [];
        for (var i=0;i<genes.length;i++) {
            flybaseids[i] = genes[i].flybaseID;
        }
        
        flykit.debug("kick off request: "+flybaseids, _context);
        this._service.findImagesByFlybaseGeneIDBatch(flybaseids, success, failure);        
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};








/**
 * @private
 */
flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatchSuccess = function() {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatchSuccess";
    var self = this;
    /**
     */
    return function( results ) {
        try {
            
            flykit.info("request success", _context);
            
            flykit.debug("set model results", _context);
            self._model.set("RESULTS", results);
            
            flykit.debug("set model state", _context);
            self._model.set("STATE", "READY");
            
            var explanation = "Images depict expression patterns of genes involved in spermatogenesis in the testes of Drosophila melanogaster. Empty table cells indicate that no images are available from FlyTED for that gene. See also Carine Barreau, Elizabeth Benson, Elin Gudmannsdottir and Helen White-Cooper, <a href='http://dev.biologists.org/cgi/content/full/135/11/1897'>Post-meiotic transcription in Drosophila testes</a>, Development. 2008 Jun;135(11):1897-902.";
            self._model.set("MESSAGE", explanation);
            
        } catch (unexpected) {
            flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
            throw unexpected;    
        }
    };
};







/**
 * @private
 */
flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatchFailure = function() {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype._findImagesByGeneBatchFailure";
    var self = this;
    /**
     * @param {ResponseObject} response
     */
    return function( response ) {
        try {
            
            flykit.err("request failed: "+response.status+" "+response.statusText, _context);
            self._model.set("MESSAGE", "there was an error retrieving data from the server, see the logs for more info");
            self._model.set("STATE", "SERVERERROR");
            
        } catch (unexpected) {
            flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
            throw unexpected;    
        }
    };
};






flykit.flyted.BatchWidget.Controller.prototype.clear = function() {
    var _context = "flykit.flyted.BatchWidget.Controller.prototype.clear";
    try {
        
        flykit.debug("clear", _context);

        flykit.debug("set state ready", _context);
        this._model.set("STATE", "READY");
        
        flykit.debug("set model property query", _context);
        this._model.set("QUERY", null);

        flykit.debug("set result null", _context);
        this._model.set("RESULTS", null);
                
        flykit.debug("set message null", _context);
        this._model.set("MESSAGE", null);
        
        flykit.debug("set mode null", _context);
        this._model.set("MODE", null);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
}








/*
 * ----------------------------------------------------------------
 *                             MODEL DEFINITION
 * ----------------------------------------------------------------
 */





/** 
 * @type Object
 */
flykit.flyted.BatchWidget.modelDefinition = {

    properties : [ "STATE", "RESULTS", "MESSAGE", "QUERY", "MODE" ],
    
    values : {
        "STATE" : [ "READY", "PENDING", "SERVERERROR", "UNEXPECTEDERROR" ]
    },
    
    initialize : function( data ) {
        data["STATE"] = "READY";
        data["RESULTS"] = null;
        data["MESSAGE"] = null;
        data["QUERY"] = null;
        data["MODE"] = null;
    }

};







/*
 * ----------------------------------------------------------------
 *                             DEFAULT RENDERER
 * ----------------------------------------------------------------
 */







flykit.flyted.BatchWidget.DefaultRenderer = function() {};


/** 
 * @private 
 * @type Element
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._canvas = null;

/**
 * @private 
 * @type Element
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._pendingPane = null;

/**
 * @private 
 * @type Element
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._resultsSummaryPane = null;

/**
 * @private 
 * @type Element
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._resultsPane = null;

/**
 * @private 
 * @type Element
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._messagePane = null;





/**
 * Set the DOM element to which this renderer applies and initialise it.
 * @param {Element} canvas
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype.setCanvas = function( canvas ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype.setCanvas";
    try {
        
        flykit.debug("set canvas", _context);
        this._canvas = $(canvas);
        this._initCanvas();
        
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};






/**
 * @private
 * @param {Element} canvas
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._initCanvas = function() {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._initCanvas";
    try {
        
        flykit.debug("begin init canvas", _context);
        
        var canvas = this._canvas;
        canvas.addClass("batchFlytedImageWidget");

        var pp = $("<p class='pendingPane'>pending (please wait, this can take up to 10 seconds) ...</p>").hide();
        canvas.append(pp);
        this._pendingPane = pp;

        var rsp = $("<p class='resultsSummaryPane'>this text should never be displayed</p>").hide();
        canvas.append(rsp);
        this._resultsSummaryPane = rsp;
        
        var rp = $("<div class='resultsPane'></div>").hide();
        canvas.append(rp);
        this._resultsPane = rp;
        
        var mp = $("<p class='messagePane'>this text should never be displayed</p>").hide();
        canvas.append(mp);
        this._messagePane = mp;            

        flykit.debug("init canvas done", _context);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};





/**
 * @public
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype.connect = function( model ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype.connect";
    try {
        
        flykit.debug("connect to model", _context);
        model.subscribeAll(this._onModelChanged, this);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};





/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onModelChanged = function( type, args, self ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onModelChanged";
    try {
        
        var handlers = {
            "STATE":"_onStateChanged",
            "QUERY":"_onQueryChanged",
            "RESULTS":"_onResultsChanged",
            "MESSAGE":"_onMessageChanged",
            "MODE": "_onModeChanged"
        };
        var handler = handlers[type];
        flykit.debug("call model changed handler: "+handler, _context);
        self[handler](args[0], args[1], args[2]);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};






/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onQueryChanged = function( from, to, get ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onQueryChanged";
    try {
        
        // do nothing, we will access the value later
        flykit.debug("query changed from "+from+" to "+to, _context);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};


/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onModeChanged = function( from, to, get ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onModeChanged";
    try {
        
        // do nothing, we will access the value later
        flykit.debug("query changed from "+from+" to "+to, _context);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};



/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onStateChanged = function( from, to, get ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onStateChanged";
    try {
        
        flykit.debug("state changed from "+from+" to "+to, _context);

        if ( to == "PENDING" ) {
            this._pendingPane.show();
            this._messagePane.hide();
            this._resultsSummaryPane.hide();
            this._resultsPane.hide();
        }
        else if ( to == "READY" ) {
            this._pendingPane.hide();
            this._messagePane.show();
            this._resultsSummaryPane.show();
            this._resultsPane.show();         
        } 
        else if ( to == "SERVERERROR" || to == "UNEXPECTEDERROR" ) {
            this._pendingPane.hide();
            this._messagePane.show();
            this._resultsSummaryPane.hide();
            this._resultsPane.hide();         
        } 
        else {
            // this should never happen
            throw {message:"invalid state: "+to};
        }
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};






/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onResultsChanged = function( from, to, get ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onResultsChanged";
    try {
        
        flykit.debug("results changed to: "+to, _context);
        
        if (to == null) {
            flykit.debug("empty results summary pane", _context);
            this._resultsSummaryPane.empty();
            flykit.debug("empty results pane", _context);
            this._resultsPane.empty();
        } 
        
        else {

            var query = get("QUERY");
            
            var mode = get("MODE");
            
            flykit.debug("render results summary", _context);
            this._renderResultsSummary(query, to);
            
            if (mode=="FULL") {
                flykit.debug("render results", _context);
                this._renderResults(query, to);
            }else{
                
                flykit.debug("render results", _context);
                this._simpleRenderResults(query, to);
            }
                
        }
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};







/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._onMessageChanged = function( from, to, get ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._onMessageChanged";
    try {
        
        flykit.debug("message changed to: "+to, _context);
        
        if (to == null) {
            flykit.debug("empty messsage pane", _context);
            this._messagePane.empty();
        } 
        
        else {

            this._messagePane.html(to);
            
        }
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};









/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._renderResultsSummary = function( query, results ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._renderResultsSummary";
    try {
        
        flykit.debug("render results summary", _context);

        var querynames = query[0];
        var genes = query[1];
        
        var count = 0;
        
        for (genename in results) {
            flykit.debug("counting images for "+genename, _context);
            count += results[genename].images.length;               
        }
        
        var content = "found "+count+" images from <a href='http://www.fly-ted.org'>www.fly-ted.org</a> ("+flykit.flyted.provenance+") ...";

        this._resultsSummaryPane.html(content);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};








/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._renderResults = function( query, results ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._renderResults";
    try {
        flykit.debug("render results", _context);

        // query has both anyNames + geneObjects
        
        // querynames: anyNames
        var querynames = query[0];
        // genes; gene objects
        var genes = query[1];
        
        var content = "<table>";

        content += "<thead><tr><th>gene</th><th>Full Name</th><th>probe</th><th>images</th></tr></thead><tbody>";
        
        for (var i=0; i<querynames.length; i++) {
            var n = querynames[i];
            var c = genes[i].symbols[0];
            var id = genes[i].flybaseID;
            var fullname = genes[i].fullNames;
            content += "<tr><td>" + c + "</td>"; // use query name because that's what the user asked for
            content += "<td>" + fullname + "</td>"; // use query name because that's what the user asked for
            content += "<td>" + n + "</td><td>"; // use query name because that's what the user asked for

            // TODO add links to flyted gene report pages? or not?
                        
            flykit.debug("looking for results for gene "+id, _context);
            
            var fbgn = "http://purl.org/net/open-biomed/id/flybase/feature/Drosophila_melanogaster/SO_0000704/" + id ;
            
            if (typeof results[fbgn] != "undefined" || results[fbgn]) {
                var imgs = results[fbgn].images;
                
                flykit.debug("found images "+imgs.length+" in result for gene "+id, _context);
                
    //            content += imgs.length ;
                
                for (var image in imgs) {
            	    var alttext = "thumbnail image depicting expression of "+imgs[image].caption;
                    flykit.debug("found image "+image+" in result for gene "+id, _context);
                    flykit.debug("found image "+imgs[image].flytedURL+" in result for gene "+id, _context);
                    content +=   "<div class=\"result\">";
                    content +=          "<a href=\"" + imgs[image].flytedURL + "\">";
                    content +=              "<img src=\"" + imgs[image].thumbnailURL + "\" alt=\""+alttext+"\">";
                    content +=          "</img></a>"; 
                    content +=          "<p class=\"caption\">"+imgs[image].caption+"</p>"
                    content +=      "</div>";
                }
            }
            
            content += "</td></tr>";
        }

        content += "</tbody></table>";
        
        flykit.debug("results pane content: "+content, _context);
        this._resultsPane.html(content);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};











/**
 * @private
 */
flykit.flyted.BatchWidget.DefaultRenderer.prototype._simpleRenderResults = function( query, results ) {
    var _context = "flykit.flyted.BatchWidget.DefaultRenderer.prototype._simpleRenderResults";
    try {
        flykit.debug("render results", _context);
        
        // genes; 
        var genes = query[0];
        
        var content = "<table>";

        content += "<thead><tr><th>gene</th><th>images</th></tr></thead><tbody>";
        
        for (var i=0; i<genes.length; i++) {
            var n = genes[i];
            content += "<tr><td>" + n + "</td>"; // use query name because that's what the user asked for
            
            // TODO add links to flyted gene report pages? or not?
                        
            flykit.debug("looking for results for gene "+n, _context);
            
            var fbgn = "http://purl.org/net/open-biomed/id/flybase/feature/Drosophila_melanogaster/SO_0000704/" + n ;
            
            if (typeof results[fbgn] != "undefined" || results[fbgn]) {
                var imgs = results[fbgn].images;
                
                flykit.debug("found images "+imgs.length+" in result for gene "+n, _context);
                
    //            content += imgs.length ;
                
                for (var image in imgs) {
            	    var alttext = "thumbnail image depicting expression of "+imgs[image].caption;
                    flykit.debug("found image "+image+" in result for gene "+n, _context);
                    flykit.debug("found image "+imgs[image].flytedURL+" in result for gene "+n, _context);
                    content +=   "<div class=\"result\">";
                    content +=          "<a href=\"" + imgs[image].flytedURL + "\">";
                    content +=              "<img src=\"" + imgs[image].thumbnailURL + "\" alt=\""+alttext+"\">";
                    content +=          "</img></a>"; 
                    content +=          "<p class=\"caption\">"+imgs[image].caption+"</p>"
                    content +=      "</div>";
                }
            }
            
            content += "</td></tr>";
        }

        content += "</tbody></table>";
        
        flykit.debug("results pane content: "+content, _context);
        this._resultsPane.html(content);
        
    } catch (unexpected) {
        flykit.debug("rethrowing "+unexpected.name+", "+unexpected.message, _context);
        throw unexpected;    
    }
};




















