X-Git-Url: https://svn.cri.ensmp.fr/git/Portfolio.git/blobdiff_plain/8c870898f8c5b34896619b4f33be97f0eeb228b6..7d1d5b450a86762cd8dceb6a2e15eafa6231a755:/skins/photo_lightbox_viewer.js?ds=sidebyside diff --git a/skins/photo_lightbox_viewer.js b/skins/photo_lightbox_viewer.js index f7afe84..dbea64c 100644 --- a/skins/photo_lightbox_viewer.js +++ b/skins/photo_lightbox_viewer.js @@ -14,11 +14,24 @@ var reSelected = /.*selected.*/; Lightbox = function(grid) { this.grid = grid; this.lastCBChecked = undefined; + this.form = undefined; + var parent = this.grid.parentNode; + while(parent) { + parent = parent.parentNode; + if (parent.tagName === 'FORM') { + this.form = parent; + break; + } + else if (parent.tagName === 'BODY') { + break; + } + } thisLightbox = this; addListener(this.grid, 'click', function(evt){thisLightbox.mouseClickHandler(evt);}); - if (!browser.isGecko){ - addListener(this.grid, 'mouseover', function(evt){thisLightbox.mouseOverHandler(evt);}); - addListener(this.grid, 'mouseout', function(evt){thisLightbox.mouseOutHandler(evt);}); + if (this.form) { + var fm = new FormManager(this.form); + fm.onBeforeSubmit = function(fm_, evt) {return thisLightbox.onBeforeSubmit(fm_, evt);}; + fm.onResponseLoad = function(req) {return thisLightbox.onResponseLoad(req);}; } }; @@ -112,26 +125,76 @@ Lightbox.prototype.mouseClickHandler = function(evt) { } }; -Lightbox.prototype.mouseOverHandler = function(evt) { - var target = getTargetedObject(evt); - if (target.tagName==='AREA') { - var slide = target.parentNode.parentNode; - if(reSelected.test(slide.className)) { - slide.className = 'slide_over_selected';} - else { - slide.className = 'slide_over';} +Lightbox.prototype.onBeforeSubmit = function(fm, evt) { + switch(fm.submitButton.name) { + case 'delete' : + this.hideSelection(); + break; } }; -Lightbox.prototype.mouseOutHandler = function(evt) { - var target = getTargetedObject(evt); - if (target.tagName==='AREA') { - var slide = target.parentNode.parentNode; - if(reSelected.test(slide.className)) { - slide.className = 'selected';} - else { - slide.className = undefined;} +Lightbox.prototype.onResponseLoad = function(req) { + switch(req.responseXML.documentElement.nodeName) { + case 'deleted' : + this.deleteSelection(); + break; + case 'error' : + this.showSelection(); + break; + } +}; + +Lightbox.prototype.hideSelection = function() { + var i, e, slide; + for (i=0 ; i