mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
mujma: Added exclusive lock on image operation. Starting each operation block others i.e you cannot rotate image when you are cropping area from it.
(merged from branches/gsoc) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@41901 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
00f262e445
commit
71cb143070
@ -20,6 +20,8 @@ var Crop = {
|
|||||||
this.onCropCancel = Crop.onCropCancel.bind(this);
|
this.onCropCancel = Crop.onCropCancel.bind(this);
|
||||||
this.doCrop = Crop.doCrop.bind(this);
|
this.doCrop = Crop.doCrop.bind(this);
|
||||||
this.setVisible = Crop.setVisible.bind(this);
|
this.setVisible = Crop.setVisible.bind(this);
|
||||||
|
this.enable = Crop.enable.bind(this);
|
||||||
|
this.disable = Crop.disable.bind(this);
|
||||||
Event.observe('image','load',this.centerCropBox);
|
Event.observe('image','load',this.centerCropBox);
|
||||||
options = {
|
options = {
|
||||||
resizeStop: Crop.resizeStop.bind(this),
|
resizeStop: Crop.resizeStop.bind(this),
|
||||||
@ -31,6 +33,7 @@ var Crop = {
|
|||||||
Event.observe(this.cropBox,'dblclick',this.onCropStop.bind(this));
|
Event.observe(this.cropBox,'dblclick',this.onCropStop.bind(this));
|
||||||
this.setListeners();
|
this.setListeners();
|
||||||
this.setVisible(false);
|
this.setVisible(false);
|
||||||
|
this.isEnabled = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
resizeStop: function(event) {
|
resizeStop: function(event) {
|
||||||
@ -88,22 +91,32 @@ var Crop = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
onCropStop: function(event) {
|
onCropStop: function(event) {
|
||||||
|
Element.hide($('cropOk'),$('cropCancel'));
|
||||||
this.doCrop();
|
this.doCrop();
|
||||||
},
|
},
|
||||||
|
|
||||||
doCrop: function() {
|
doCrop: function() {
|
||||||
newWidth = this.cropBox.getWidth()
|
if(this.isEnabled) {
|
||||||
newHeight = this.cropBox.getHeight() ;
|
newWidth = this.cropBox.getWidth()
|
||||||
startTop = this.cropBox.getTop() ;
|
newHeight = this.cropBox.getHeight() ;
|
||||||
startLeft = this.cropBox.getLeft() ;
|
startTop = this.cropBox.getTop() ;
|
||||||
if(newWidth > 35 && newHeight > 35) {
|
startLeft = this.cropBox.getLeft() ;
|
||||||
imageTransformation.crop(startTop,startLeft,newWidth,newHeight);
|
if(newWidth > 35 && newHeight > 35) {
|
||||||
imageHistory.enable();
|
imageTransformation.crop(startTop,startLeft,newWidth,newHeight,Crop.cropCallback.bind(this));
|
||||||
} else {
|
imageHistory.enable();
|
||||||
alert('Crop area too small');
|
} else {
|
||||||
|
alert('Crop area too small');
|
||||||
|
}
|
||||||
|
this.disable();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
cropCallback: function() {
|
||||||
|
effects.enableRotate();
|
||||||
|
this.enable();
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
setListeners: function() {
|
setListeners: function() {
|
||||||
Event.observe('cropStart','click',this.onCropStart);
|
Event.observe('cropStart','click',this.onCropStart);
|
||||||
Event.observe('cropOk','click',this.onCropOk);
|
Event.observe('cropOk','click',this.onCropOk);
|
||||||
@ -111,20 +124,29 @@ var Crop = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
onCropStart: function() {
|
onCropStart: function() {
|
||||||
this.setVisible(true);
|
if(this.isEnabled) {
|
||||||
Element.show($('cropOk'),$('cropCancel'));
|
this.setVisible(true);
|
||||||
imageHistory.disable();
|
Element.show($('cropOk'),$('cropCancel'));
|
||||||
|
imageHistory.disable();
|
||||||
|
effects.disableRotate();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onCropOk: function() {
|
onCropOk: function() {
|
||||||
Element.hide($('cropOk'),$('cropCancel'));
|
if(this.isEnabled) {
|
||||||
this.doCrop();
|
Element.hide($('cropOk'),$('cropCancel'));
|
||||||
|
this.doCrop();
|
||||||
|
effects.disableRotate();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onCropCancel: function() {
|
onCropCancel: function() {
|
||||||
Element.hide($('cropOk'),$('cropCancel'));
|
if(this.isEnabled) {
|
||||||
this.setVisible(false);
|
Element.hide($('cropOk'),$('cropCancel'));
|
||||||
imageHistory.enable();
|
this.setVisible(false);
|
||||||
|
imageHistory.enable();
|
||||||
|
effects.enableRotate();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
setVisible: function(setVisible) {
|
setVisible: function(setVisible) {
|
||||||
@ -137,5 +159,14 @@ var Crop = {
|
|||||||
}
|
}
|
||||||
resize.imageContainerResize.setVisible(!setVisible);
|
resize.imageContainerResize.setVisible(!setVisible);
|
||||||
this.resizeCropBox.setVisible(setVisible);
|
this.resizeCropBox.setVisible(setVisible);
|
||||||
|
},
|
||||||
|
|
||||||
|
enable: function() {
|
||||||
|
this.isEnabled = true;
|
||||||
|
},
|
||||||
|
|
||||||
|
disable: function() {
|
||||||
|
this.isEnabled = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -6,13 +6,36 @@ var Effects = {
|
|||||||
this.setListeners = Effects.setListeners.bind(this);
|
this.setListeners = Effects.setListeners.bind(this);
|
||||||
this.rotate = Effects.rotate.bind(this);
|
this.rotate = Effects.rotate.bind(this);
|
||||||
this.setListeners();
|
this.setListeners();
|
||||||
|
this.isRotateEnabled = true;
|
||||||
|
this.enableRotate = Effects.enableRotate.bind(this);
|
||||||
|
this.disableRotate = Effects.disableRotate.bind(this);
|
||||||
},
|
},
|
||||||
|
|
||||||
rotate: function() {
|
rotate: function() {
|
||||||
imageTransformation.rotate(90);
|
if(this.isRotateEnabled) {
|
||||||
|
resize.imageContainerResize.disable();
|
||||||
|
crop.disable();
|
||||||
|
imageTransformation.rotate(90,Effects.rotateCallback.bind(this));
|
||||||
|
this.isRotateEnabled = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
rotateCallback: function() {
|
||||||
|
resize.imageContainerResize.enable();
|
||||||
|
crop.enable();
|
||||||
|
this.isRotateEnabled = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
setListeners: function() {
|
setListeners: function() {
|
||||||
Event.observe('rotateButton','click',this.rotate);
|
Event.observe('rotateButton','click',this.rotate);
|
||||||
|
},
|
||||||
|
|
||||||
|
disableRotate: function() {
|
||||||
|
this.isRotateEnabled = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
enableRotate: function() {
|
||||||
|
this.isRotateEnabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -37,7 +37,7 @@ var ImageTransformation = {
|
|||||||
new Ajax.Request('admin/ImageEditor/manipulate', options);
|
new Ajax.Request('admin/ImageEditor/manipulate', options);
|
||||||
},
|
},
|
||||||
|
|
||||||
rotate: function(angle) {
|
rotate: function(angle,callback) {
|
||||||
var options = {
|
var options = {
|
||||||
method: 'post',
|
method: 'post',
|
||||||
postBody: 'command=rotate&file=' + $('image').src + '&angle=' + angle ,
|
postBody: 'command=rotate&file=' + $('image').src + '&angle=' + angle ,
|
||||||
@ -52,6 +52,7 @@ var ImageTransformation = {
|
|||||||
$('imageContainer').style.height = response.height + 'px';
|
$('imageContainer').style.height = response.height + 'px';
|
||||||
imageHistory.add('rotate',$('image').src);
|
imageHistory.add('rotate',$('image').src);
|
||||||
resize.imageContainerResize.placeClickBox();
|
resize.imageContainerResize.placeClickBox();
|
||||||
|
if(callback != null) callback();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
imageBox.showIndicator();
|
imageBox.showIndicator();
|
||||||
@ -59,7 +60,7 @@ var ImageTransformation = {
|
|||||||
new Ajax.Request('admin/ImageEditor/manipulate', options);
|
new Ajax.Request('admin/ImageEditor/manipulate', options);
|
||||||
},
|
},
|
||||||
|
|
||||||
crop: function(top,left,width,height) {
|
crop: function(top,left,width,height,callback) {
|
||||||
var options = {
|
var options = {
|
||||||
method: 'post',
|
method: 'post',
|
||||||
postBody: 'command=crop&file=' + $('image').src + '&top=' + top + '&left=' + left + '&width=' + width + '&height=' + height,
|
postBody: 'command=crop&file=' + $('image').src + '&top=' + top + '&left=' + left + '&width=' + width + '&height=' + height,
|
||||||
@ -73,6 +74,7 @@ var ImageTransformation = {
|
|||||||
$('imageContainer').style.height = response.height + 'px';
|
$('imageContainer').style.height = response.height + 'px';
|
||||||
imageHistory.add('crop',$('image').src);
|
imageHistory.add('crop',$('image').src);
|
||||||
crop.setVisible(false);
|
crop.setVisible(false);
|
||||||
|
if(callback != null) callback();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
imageBox.showIndicator();
|
imageBox.showIndicator();
|
||||||
|
@ -20,13 +20,24 @@ var Resize = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
resizeStop: function(event) {
|
resizeStop: function(event) {
|
||||||
imageElement = $('image');
|
if(EventStack.getLastEventElement() != null) {
|
||||||
EventStack.clearStack();
|
imageElement = $('image');
|
||||||
if(this.imageContainerResize.originalWidth != imageElement.width || this.imageContainerResize.originalHeight != imageElement.height) {
|
EventStack.clearStack();
|
||||||
imageTransformation.resize(imageElement.width,imageElement.height);
|
if(this.imageContainerResize.originalWidth != imageElement.width || this.imageContainerResize.originalHeight != imageElement.height) {
|
||||||
|
imageTransformation.resize(imageElement.width,imageElement.height,Resize.resizeCallback.bind(this));
|
||||||
|
}
|
||||||
|
effects.disableRotate();
|
||||||
|
crop.disable();
|
||||||
|
this.imageContainerResize.disable();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
resizeCallback: function() {
|
||||||
|
effects.enableRotate();
|
||||||
|
crop.enable();
|
||||||
|
this.imageContainerResize.enable();
|
||||||
|
},
|
||||||
|
|
||||||
onDrag: function()
|
onDrag: function()
|
||||||
{
|
{
|
||||||
if(this.element.getTop() < this.topBoxConstraint) this.element.style.top = this.topBoxConstraint + "px";
|
if(this.element.getTop() < this.topBoxConstraint) this.element.style.top = this.topBoxConstraint + "px";
|
||||||
|
@ -16,6 +16,7 @@ Resizeable = {
|
|||||||
this.placeClickBoxOnImageLoad();
|
this.placeClickBoxOnImageLoad();
|
||||||
this.originalHeight = 0;
|
this.originalHeight = 0;
|
||||||
this.originalWidth = 0;
|
this.originalWidth = 0;
|
||||||
|
this.isEnabled = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
resizeStart: function(event) {
|
resizeStart: function(event) {
|
||||||
@ -75,7 +76,7 @@ Resizeable = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
onResize: function(event) {
|
onResize: function(event) {
|
||||||
if(EventStack.getLastEventElement() != null && this.isVisible) {
|
if(EventStack.getLastEventElement() != null && this.isVisible && this.isEnabled) {
|
||||||
lastEventElement = EventStack.getLastEventElement();
|
lastEventElement = EventStack.getLastEventElement();
|
||||||
var relativeMouseX = this.getMousePos(event).x - this.element.getParentLeft();
|
var relativeMouseX = this.getMousePos(event).x - this.element.getParentLeft();
|
||||||
var relativeMouseY = this.getMousePos(event).y - this.element.getParentTop();
|
var relativeMouseY = this.getMousePos(event).y - this.element.getParentTop();
|
||||||
@ -217,6 +218,8 @@ Resizeable = {
|
|||||||
this.addDraging = Resizeable.addDraging.bind(this);
|
this.addDraging = Resizeable.addDraging.bind(this);
|
||||||
this.setVisible = Resizeable.setVisible.bind(this);
|
this.setVisible = Resizeable.setVisible.bind(this);
|
||||||
this.removeDraging = Resizeable.removeDraging.bind(this);
|
this.removeDraging = Resizeable.removeDraging.bind(this);
|
||||||
|
this.disable = Resizeable.disable.bind(this);
|
||||||
|
this.enable = Resizeable.enable.bind(this);
|
||||||
|
|
||||||
this.leftUpperDrag = Resizeable.leftUpperDrag.bind(this);
|
this.leftUpperDrag = Resizeable.leftUpperDrag.bind(this);
|
||||||
this.leftMiddleDrag = Resizeable.leftMiddleDrag.bind(this);
|
this.leftMiddleDrag = Resizeable.leftMiddleDrag.bind(this);
|
||||||
@ -284,5 +287,13 @@ Resizeable = {
|
|||||||
this.lowerMiddleClickBox);
|
this.lowerMiddleClickBox);
|
||||||
this.removeDraging();
|
this.removeDraging();
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
disable: function() {
|
||||||
|
this.isEnabled = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
enable: function() {
|
||||||
|
this.isEnabled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user