Première expérimentations (et première galères…) de l'ordonnancement par drag and...
[Portfolio.git] / skins / photo_lightbox_viewer.js
index 8dfbaf4..cb8be26 100644 (file)
@@ -46,8 +46,40 @@ Lightbox = function(grid, toolbar, complete, container_type) {
                fm.onBeforeSubmit = function(fm_, evt) {return self.onBeforeSubmit(fm_, evt);};
                fm.onResponseLoad = function(req) {return self.onResponseLoad(req);};
        }
                fm.onBeforeSubmit = function(fm_, evt) {return self.onBeforeSubmit(fm_, evt);};
                fm.onResponseLoad = function(req) {return self.onResponseLoad(req);};
        }
+    this.disableDefaultDragging();
+    addListener(this.grid,
+                'dragstart',
+                function(evt) {
+                    var target = getTargetedObject(evt);
+                    console.info('dragstart',
+                                target);
+                    evt.dataTransfer.setData('text', '');
+                    target.style.opacity = 0;
+                    target.style.width = 0;
+                   // disableDefault(evt);
+                });
 };
 
 };
 
+if (browser.isGecko) {
+    Lightbox.prototype.disableDefaultDragging = function(element) {
+        if (!element) {
+            element = this.grid;
+        }
+        var i, j, name, elements;
+        var elementsNames = ['a', 'img'];
+        for (i=0 ; i < elementsNames.length ; i++) {
+            name = elementsNames[i];
+            elements = element.getElementsByTagName(name);
+            for (j=0 ; j < elements.length ; j++) {
+                elements[j].draggable=false;
+            }
+        }
+    };
+}
+else {
+    Lightbox.prototype.disableDefaultDragging = function() {};
+}
+
 Lightbox.prototype._buildSlidesIndex = function() {
        this.slides = [];
        var node, i;
 Lightbox.prototype._buildSlidesIndex = function() {
        this.slides = [];
        var node, i;
@@ -200,6 +232,9 @@ Lightbox.prototype.onResponseLoad = function(req) {
                        this.fm.submitButton = undefined;
                        this.refreshGrid();
                        break;
                        this.fm.submitButton = undefined;
                        this.refreshGrid();
                        break;
+               default :
+                       this.fm.loadResponse(req);
+                       break;
        }
 };
 
        }
 };
 
@@ -347,6 +382,7 @@ Lightbox.prototype._refreshGrid = function(req) {
                node = doc.childNodes[i];
                if (node.nodeType === 1) {
                        node = getCopyOfNode(node);
                node = doc.childNodes[i];
                if (node.nodeType === 1) {
                        node = getCopyOfNode(node);
+            this.disableDefaultDragging(node);
                        this.grid.replaceChild(node, this.slides[j]);
                        this.slides[j] = node;
                        j++;
                        this.grid.replaceChild(node, this.slides[j]);
                        this.slides[j] = node;
                        j++;
@@ -389,6 +425,7 @@ Lightbox.prototype._appendTail = function(req) {
                node = doc.childNodes[i];
                if (node.nodeType === 1) {
                        this.lastSlide = this.grid.appendChild(getCopyOfNode(node));
                node = doc.childNodes[i];
                if (node.nodeType === 1) {
                        this.lastSlide = this.grid.appendChild(getCopyOfNode(node));
+            this.disableDefaultDragging(this.lastSlide);
                        this.slides.push(this.lastSlide);
                        if (this.cbIndex) {
                                c = this.lastSlide.getElementsByTagName('input')[0];
                        this.slides.push(this.lastSlide);
                        if (this.cbIndex) {
                                c = this.lastSlide.getElementsByTagName('input')[0];