Your IP : 18.224.62.198


Current Path : /var/www/www-root/data/www/info.monolith-realty.ru/bitrix/js/main/core/
Upload File :
Current File : /var/www/www-root/data/www/info.monolith-realty.ru/bitrix/js/main/core/core_canvas.js

;(function(window){
	if (window.BX["CanvasEditor"])
		return false;
	var BX = window.BX, E = {},
	FormToArray = function(form, data) {
		data = (data || {});
		var i, ii,
			_data = [],
			n = form.elements.length,
			files = 0, length = 0;
		if(!!form)
		{
			for(i=0; i<n; i++)
			{
				var el = form.elements[i];
				if (el.disabled)
					continue;
				switch(el.type.toLowerCase())
				{
					case 'text':
					case 'textarea':
					case 'password':
					case 'hidden':
					case 'select-one':
						_data.push({name: el.name, value: el.value});
						length += (el.name.length + el.value.length);
						break;
					case 'file':
						if (!!el.files)
						{
							for(ii=0;ii<el.files.length;ii++)
							{
								files++;
								_data.push({name: el.name, value: el.files[ii]});
								length += el.files[ii].size;
							}
						}
						break;
					case 'radio':
					case 'checkbox':
						if(el.checked)
						{
							_data.push({name: el.name, value: el.value});
							length += (el.name.length + el.value.length);
						}
						break;
					case 'select-multiple':
						for (var j = 0; j < el.options.length; j++) {
							if (el.options[j].selected)
							{
								_data.push({name : el.name, value : el.options[j].value});
								length += (el.name.length + el.options[j].length);
							}
						}
						break;
					default:
						break;
				}
			}

			i = 0; length = 0;
			var current = data;

			while(i < _data.length)
			{
				var p = _data[i].name.indexOf('[');
				if (p == -1) {
					current[_data[i].name] = _data[i].value;
					current = data;
					i++;
				}
				else
				{
					var name = _data[i].name.substring(0, p);
					var rest = _data[i].name.substring(p+1);
					if(!current[name])
						current[name] = [];

					var pp = rest.indexOf(']');
					if(pp == -1)
					{
						current = data;
						i++;
					}
					else if(pp == 0)
					{
						//No index specified - so take the next integer
						current = current[name];
						_data[i].name = '' + current.length;
					}
					else
					{
						//Now index name becomes and name and we go deeper into the array
						current = current[name];
						_data[i].name = rest.substring(0, pp) + rest.substring(pp+1);
					}
				}
			}
		}
		return {data : data, filesCount : files, roughSize : length};
	};

	BX.CanvasEditor = function (id)
	{
		this.previewSize = {width : 1024, height : 860, minWidth : 500, minHeight : 335};
		this.dialogName = "BX.CanvasEditor";
		this.id = id + 'Editor';
		this.canvas = new BX.Canvas();
		BX.addCustomEvent(this.canvas, "onChangeSize", BX.delegate(function(params, changeCoeff) {
			var props = params.props,
				style = { width : parseInt(params.style.width.replace('px', '')), height : parseInt(params.style.height.replace('px', '')) },
				cover = BX.pos(this.canvas.getCanvas().parentNode.parentNode),
				cover1 = { style : params.style }, ratio, coeff = 0, cnv = this.canvas.getCanvas();

			if (changeCoeff == true)
			{
				if (style.height > cover.height || style.width > cover.width)
				{
					ratio = BX.UploaderUtils.scaleImage(props, cover, "inscribed");
					coeff = ratio.coeff;
					if (!cnv.hasAttribute("bx-bxu-html-compression-ratio-real"))
						cnv.setAttribute("bx-bxu-html-compression-ratio-real", cnv.getAttribute("bx-bxu-html-compression-ratio"));
					cnv.setAttribute("bx-bxu-html-compression-ratio", coeff);
				}
				else if (cnv.hasAttribute("bx-bxu-html-compression-ratio-real"))
				{
					coeff = cnv.getAttribute("bx-bxu-html-compression-ratio-real");
					cnv.setAttribute("bx-bxu-html-compression-ratio", coeff);
					cnv.removeAttribute("bx-bxu-html-compression-ratio-real");
				}
				if (coeff > 0)
					return this.canvas.setProps(props, false);
			}
			var top = Math.ceil((cover.height - style.height) / 2),
				left = Math.ceil((cover.width - style.width) / 2),
				right = (cover.width - left - style.width),
				cover2 = { style : {
					paddingTop : top + 'px',
					paddingBottom : (cover.height - top - style.height) + 'px',
					paddingLeft : left + 'px',
					paddingRight : right + 'px'
				} };
			BX.adjust(this.canvas.getCanvas().parentNode, cover1);
			BX.adjust(this.canvas.getCanvas().parentNode.parentNode, cover2);
		}, this));

		BX.addCustomEvent(this.canvas, "onChangeCanvas", BX.delegate(function(ratio) {
			this.canvas.getCanvas().removeAttribute("bx-bxu-html-compression-ratio-real");
			var props = ratio.destin, padding = {},
				width = Math.max(props.width, this.previewSize.minWidth),
				height = Math.max(props.height, this.previewSize.minHeight);
			padding.left = Math.ceil((width - props.width) / 2);
			padding.right = width - padding.left - props.width;
			padding.top = Math.ceil((height - props.height) / 2);
			padding.bottom = height - padding.top - props.height;
			BX.adjust(this.canvas.getCanvas().parentNode.parentNode, { style : {
					padding : '' + padding.top + 'px ' + padding.right + 'px ' + padding.bottom + 'px ' + padding.left + 'px'
				}
			} );
		}, this));

		this.popup = null;
		return this;
	};
	BX.CanvasEditor.prototype = {
		onApply : function()
		{
			this.canvas.apply();
			BX.onCustomEvent(this, "onApplyCanvas", [this.canvas.orig, FormToArray(BX(this.id + 'params'))]);
		},
		onCancel : function()
		{
			BX.onCustomEvent(this, "onCancelCanvas", [this.canvas.orig]);
		},
		onDelete : function()
		{
			BX.onCustomEvent(this, "onDeleteCanvas", [this.canvas.orig]);
		},
		showEditor : function(canvas, params) {
			params = (!!params && typeof params == "object" ? params : {template : params});
			BX.onCustomEvent(this, "onBeforeShow");
			var res = BX.GetWindowInnerSize();
			if (res.innerWidth < this.previewSize.width)
				this.previewSize.width = res.innerWidth;
			if (res.innerHeight * 0.8 < (this.previewSize.height))
				this.previewSize.height = res.innerHeight * 0.8;
			if (this.popup === null)
			{
				var ratio = BX.UploaderUtils.scaleImage(canvas, this.previewSize, "inscribed");
				var editorNode = BX.create("DIV", {
					attrs : {
						id : this.id + 'Proper',
						className : "bxu-edit-popup"
					},
					style : { display : "none" },
					html : [
						'<div class="bxu-edit-top"> \
							<span class="bxu-edit-name" id="', this.id, 'title">', BX.util.htmlspecialchars(params["title"]), '</span> \
							<span class="bxu-edit-cls" id="', this.id, 'close"></span> \
						</div> \
						<div class="bxu-edit-img-wrap">\
							<div class="bxu-edit-img-wrap-in" style="position:relative; margin:0;padding:0;border:none;"> \
								<div style="position:relative; margin:0;padding:0;border:none;"> \
									<canvas id="', this.id, 'canvas" width="', ratio.destin.width, '" height="', ratio.destin.height, '"><canvas> \
								</div> \
							</div> \
						</div> \
						<div class="bxu-edit-btn-block"> \
							<div class="bxu-edit-btn-wrap"> \
								<span class="bxu-edit-btn bxu-edit-btn-turn-l" id="', this.id, 'turn-l', '" title="', BX.message("CANVAS_TURN_L"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-turn-r" id="', this.id, 'turn-r', '"title="', BX.message("CANVAS_TURN_R"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-flip-v" id="', this.id, 'flip-v', '" title="', BX.message("CANVAS_FLIP_V"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-flip-h" id="', this.id, 'flip-h', '" title="', BX.message("CANVAS_FLIP_H"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-crop" id="', this.id, 'crop', '" title="', BX.message("CANVAS_CROP"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-grayscale" id="', this.id, 'grayscale', '" title="', BX.message("CANVAS_GRAYSCALE"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
								<span class="bxu-edit-btn bxu-edit-btn-sign" id="', this.id, 'sign', '" title="', BX.message("CANVAS_SIGN"),'"> \
									<span class="bxu-edit-btn-icon"></span> \
								</span> \
							</div> \
							<div class="bxu-edit-inp-wrap"> \
								<form onsubmit="return false;" id="', this.id , 'params">', (params["template"] || ''), '</form> \
							</div> \
						</div>'].join("")
				});
				var func = BX.delegate(function() {
					BX(this.id + 'canvas').parentNode.replaceChild(this.canvas.cnv, BX(this.id + 'canvas'));
					BX.bind(BX(this.id + 'turn-l'), "click", BX.proxy(function(){ this.rotate(false); }, this.canvas));
					BX.bind(BX(this.id + 'turn-r'), "click", BX.proxy(function(){ this.rotate(true); }, this.canvas));
					BX.bind(BX(this.id + 'flip-v'), "click", BX.proxy(function(){ this.flip(false); }, this.canvas));
					BX.bind(BX(this.id + 'flip-h'), "click", BX.proxy(function(){ this.flip(true); }, this.canvas));
					BX.bind(BX(this.id + 'crop'), "click", BX.proxy(function(){ this.crop(BX.proxy_context); }, this.canvas));
					BX.bind(BX(this.id + 'grayscale'), "click", BX.proxy(function(){ this.blackAndWhite(); }, this.canvas));
					BX.bind(BX(this.id + 'sign'), "click", BX.proxy(function(){ this.poster(BX.proxy_context); }, this.canvas));
					BX.bind(BX(this.id + 'close'), "click", BX.proxy(this.popup.close, this.popup));
					BX.bind(BX(this.id + 'params'), "submit", BX.proxy(this.onApply, this));

					BX.removeCustomEvent(this.popup, "onPopupShow", func);
				}, this), func3 = BX.delegate(this.onCancel, this);

				this.popup = BX.PopupWindowManager.create(
					'popup' + this.id,
					null,
					{
						className : "bxu-popup",
						autoHide : false,
						lightShadow : true,
						closeIcon : false,
						closeByEsc : true,
						zIndex : 1,
						content : editorNode,
						overlay : {},
						events : {
							onPopupClose : BX.delegate(
								function(){
									BX.onCustomEvent(this, "onClose", [this]);
									this.canvas.reset();
								}, this
							)
						},
						buttons : [
							new BX.PopupWindowButton( {text : BX.message('CANVAS_OK'), className : "", events : { click : BX.delegate(function(){
								this.onApply();
								BX.removeCustomEvent(this.popup, "onPopupClose", func3);
								this.popup.close();
							}, this) } } )
							, new BX.PopupWindowButton( {text : BX.message('CANVAS_CANCEL'), className : "", events : { click : BX.delegate(function(){
								this.popup.close();
							}, this) } } )
							//, new BX.PopupWindowButton( {text : BX.message('CANVAS_DELETE'), className : "", events : { click : BX.delegate(this.onDelete, this) } } )
						]
					}
				);
				BX.addCustomEvent(this.popup, "onPopupShow", func);
				BX.addCustomEvent(this.popup, "onPopupClose", func3);

			}
			var func2 = BX.delegate(function(){
				if (canvas != null)
					this.copyCanvas(canvas);
				BX(this.id + 'params').innerHTML = (params["template"] || '');
				if (!!params["template"])
				{
					BX.defer_proxy(function(){
						var form = BX(this.id + 'params');
						if (!!form)
						{
							for (var ii = 0; ii < form.elements.length; ii++)
							{
								if (form.elements[ii].type.toUpperCase() == "TEXT" || form.elements[ii].tagName.toUpperCase() == "TEXTAREA")
								{
									BX.focus(form.elements[ii]);
									break;
								}
							}
						}
					}, this)();
				}
				BX(this.id + 'title').innerHTML = BX.util.htmlspecialchars(params["title"] || '');
				BX.removeCustomEvent(this.popup, "onAfterPopupShow", func2);
			}, this);
			BX.addCustomEvent(this.popup, "onAfterPopupShow", func2);

			this.popup.show();
			this.popup.adjustPosition();
			BX.onCustomEvent(this, "onAfterShow");

			return true;
		},
		copyCanvas : function(canvas)
		{
			this.canvas.copy(canvas, this.previewSize);
		}
	};
	BX.CanvasEditor.show = function(canvas, html, params)
	{
		var id = "";
		if (typeof params == "string")
			id = params;
		else if (typeof params == "object")
			id = params["id"];
		id = (typeof id === "string" && id.length > 0 ? id : "default");
		if(!E[id])
			E[id] = new BX.CanvasEditor(id);
		E[id].showEditor(canvas, html, params);
		return E[id];
	};
	BX.CanvasEditor.replaceCanvas = function(canvas, id)
	{
		id = (typeof id === "string" && id.length > 0 ? id : "default");
		if(!!E[id])
			E[id].copyCanvas(canvas);
	};

	BX.Canvas = function()
	{
		this.cnv = null;
		this.ctx = null;
		this.init();
		return this;
	};
	BX.Canvas.prototype = {
		getVisFromReal : function(prop)
		{
			var c = this.cnv.getAttribute("bx-bxu-html-compression-ratio");
			return ((0 < c && c < 1) ? parseInt(c * prop) : prop);
		},
		getRealFromVis : function(prop)
		{
			var c = this.cnv.getAttribute("bx-bxu-html-compression-ratio");
			return ((0 < c && c < 1) ? parseInt(prop / c) : prop);
		},
		setStyles : function(props)
		{
			var p = {width : this.getRealFromVis(props.width), height : this.getRealFromVis(props.height)},
				styles = {width : props.width + 'px', height : props.height + 'px'};
			BX.adjust(this.cnv, {props : p, style : styles });
			BX.onCustomEvent(this, "onChangeSize", [{props : p, style : styles }])
		},
		setProps : function(props, recalcCoeff)
		{
			var p = ({width : props.width, height : props.height}),
				styles = {width : this.getVisFromReal(props.width) + 'px', height : this.getVisFromReal(props.height) + 'px'};
			BX.adjust(this.cnv, {props : p, style : styles });
			BX.onCustomEvent(this, "onChangeSize", [{props : p, style : styles }, recalcCoeff]);
		},
		getCanvas : function()
		{
			return this.cnv;
		},
		init : function()
		{
			this.cnv = BX.create('CANVAS');
			BX.adjust(this.cnv, { width : 100, height : 100 } );
			this.ctx = this.cnv.getContext("2d");
			this.initDnD();
			return this.cnv;
		},
		reset : function()
		{
			this.ctx.clearRect(0, 0, this.cnv.width, this.cnv.height);
			BX.adjust(this.cnv, { width : 100, height : 100 } );
		},
		apply : function()
		{
			this.orig.width = this.cnv.width;
			this.orig.height = this.cnv.height;
			this.orig.ctx = this.orig.getContext("2d");
			this.orig.ctx.drawImage(this.cnv, 0, 0);
		},
		copy : function(canvas, params)
		{
			this.orig = canvas;

			params = (params || {});
			params.width = (params.width > 0 ? params.width : 0);
			params.height = (params.height > 0 ? params.height : 0);

			var ratio = BX.UploaderUtils.scaleImage(canvas, params, "inscribed");
			this.cnv.setAttribute("bx-bxu-html-compression-ratio", ratio.coeff);

			this.setProps(canvas);
			BX.onCustomEvent(this, "onChangeCanvas", [ratio]);

			this.ctx = this.cnv.getContext("2d");
			this.ctx.drawImage(canvas, 0, 0);
			return this.cnv;
		},
		poster : function(node)
		{
			if (!!this.posterPopup)
				this.posterPopup.close();
			var res = BX.pos(node);

			this.posterPopup = new BX.PopupWindow('bx-poster-popup-' + node.id, node, {
				lightShadow : true,
				offsetTop: -3,
				className : "bxu-poster-popup",
				offsetLeft: Math.ceil(res.width / 2),
				autoHide: true,
				closeByEsc: true,
				bindOptions: {position: "top"},
				overlay : false,
				events : {
					onPopupClose : function() { this.destroy() },
					onPopupDestroy : BX.proxy(function() { this.posterPopup = null; }, this)
				},
				buttons : [
					new BX.PopupWindowButton( {text : BX.message('CANVAS_OK'), events : { click : BX.delegate(function() {
						var msg = BX('posterPopupText' + node.id);
						if (!!msg && msg.value.length > 0)
							this.posterApply(msg.value);
						this.posterPopup.close();
					}, this) } } )
					, new BX.PopupWindowButton( {text : BX.message('CANVAS_CANCEL'), events : { click : BX.delegate(function(){this.posterPopup.close();}, this) } } )
				],
				content : ['<div class="bxu-poster-popup-dt">', BX.message("CANVAS_POSTER_SIGN"), '</div> \
					<input type="text" id="posterPopupText', node.id,'" maxlength="255" value="" />'].join("")
			});
			this.posterPopup.show();
			this.posterPopup.setAngle({position:'bottom'});
			this.posterPopup.bindOptions.forceBindPosition = true;
			this.posterPopup.adjustPosition();
			BX.focus(BX('posterPopupText' + node.id));
			this.posterPopup.bindOptions.forceBindPosition = false;
		},
		posterApply : function(msg)
		{
			if (msg)
			{
				var size = Math.min(this.cnv.width, this.cnv.height) / 10;
				this.ctx.fillStyle = "black";
				this.ctx.fillRect(0, 0, this.cnv.width, size);
				this.ctx.fillRect(0, this.cnv.height - 2 * size, this.cnv.width, 2 * size);
				this.ctx.fillRect(0, 0, size, this.cnv.height);
				this.ctx.fillRect(this.cnv.width - size, 0, size, this.cnv.height);
				this.ctx.strokeStyle = "white";
				var border = 5;
				this.ctx.strokeRect(size - border, size - border,
					this.cnv.width - (size * 2) + 2 * border,
					this.cnv.height - (size * 3) + 2 * border);
				this.ctx.fillStyle = "white";
				this.ctx.textAlign = "center";
				this.ctx.textBaseline = "middle";
				this.ctx.font = size + "px marketing";
				this.ctx.fillText(msg, this.cnv.width / 2, this.cnv.height - size, this.cnv.width);
			}
		},
		blackAndWhite : function()
		{
			var frame = this.ctx.getImageData(0, 0, this.cnv.width, this.cnv.height), v, i;
			for (i = 0; i < frame.data.length; i += 4)
			{
				v = (frame.data[i] + frame.data[i + 1] + frame.data[i + 2]) / 3;
				frame.data[i] = v;
				frame.data[i + 1] = v;
				frame.data[i + 2] = v;
			}
			this.ctx.putImageData(frame, 0, 0);
		},
		flip : function(verticaly)
		{
			this.ctx.save();
			if (verticaly)
			{
				this.ctx.scale(1, -1);
				this.ctx.translate(0, - this.cnv.height);
			}
			else
			{
				this.ctx.scale(-1, 1);
				this.ctx.translate(-this.cnv.width, 0);
			}
			this.ctx.drawImage(this.cnv, 0, 0);
			this.ctx.restore();
		},
		rotate : function(clockwise)
		{
			this.turn(this.cnv, this.ctx, clockwise);
		},
		turn : function(cnv, ctx, clockwise)
		{
			var tmpCanvas = BX.create('CANVAS', {props : { width : cnv.width, height : cnv.height }, style : { display : "none" } } );
			tmpCanvas.getContext("2d").drawImage(cnv, 0, 0);

			this.setProps({width : tmpCanvas.height, height : tmpCanvas.width}, true);

			ctx.save();

			if (clockwise)
				ctx.translate(this.cnv.width, 0);
			else
				ctx.translate(0, this.cnv.height);
			var rad = Math.PI / 2 * (clockwise ? 1 : -1);
			ctx.rotate(rad);
			ctx.drawImage(tmpCanvas, 0, 0);
			ctx.restore();
			tmpCanvas = null;
		},
		resize : function(ratio)
		{
			var tmpCanvas = BX.create('CANVAS', {props : { width : this.cnv.width, height : this.cnv.height }, style : { display : "none" } } );
			tmpCanvas.getContext("2d").drawImage(this.cnv, 0, 0);

			this.cnv.width *= ratio;
			this.cnv.height *= ratio;

			this.ctx.save();
			this.ctx.scale(ratio, ratio);
			this.ctx.drawImage(tmpCanvas, 0, 0);
			this.ctx.restore();

			tmpCanvas = null;
		},
		_imageDropped : function(url, x, y, drawBorder)
		{
			var img = BX.create("IMG", {
					style : { display : "none" },
					events : {
						load : BX.delegate(function()
						{
							var ratioX = (img.width > this.cnv.width / 3 ? (this.cnv.width / 3) / img.width : 1),
								ratioY = (img.height > this.cnv.height / 3 ? (this.cnv.height / 3) / img.height : 1),
								ratio = Math.min(ratioX, ratioY);
							this.cnv.save();
							this.cnv.translate(x - img.width * ratio / 2, y - img.height * ratio / 2);
							this.cnv.scale(ratio, ratio);
							this.cnv.drawImage(img, 0, 0);
							if (drawBorder)
							{
								this.cnv.strokeStyle = "white";
								this.cnv.lineWidth = 5 / ratio;
								this.cnv.strokeRect(0, 0, img.width, img.height);
							}
							this.cnv.restore();
							document.body.removeChild(img);
							img = null;
						}, this)
					}
				});
			img.src = url;
			document.body.appendChild(img);
		},
		initDnD : function()
		{
			if (!!BX.DD && BX.type.isDomNode(this.cnv) && this.cnv.parentNode)
			{
				this.cnvDD = new BX.DD.dropFiles(this.cnv.canvas);
				if (this.cnvDD && this.cnvDD.supported() && BX.ajax.FormData.isSupported())
				{
					BX.addCustomEvent(this.cnvDD, 'dragover', BX.preventDefault);
					BX.addCustomEvent(this.cnvDD, 'drop', BX.delegate(function(e)
					{
						BX.preventDefault(e);
						BX.fixEventPageXY(e);

						var dt = e.dataTransfer,
							x = e.pageX - this.cnv.canvas.offsetLeft - this.cnv.canvas.parentNode.offsetLeft,
							y = e.pageY - this.cnv.canvas.offsetTop - this.cnv.canvas.parentNode.offsetTop,
							files = dt.files;
						if (files.length == 0)
						{
							var type = "application/x-moz-file-promise-url";
							if (dt.types.contains(type)) { this._imageDropped(dt.getData(type), x, y, false); }
						}
						else
						{
							var file = files[0], reader = new FileReader();
							reader.onload = BX.proxy(function(e) {
								this._imageDropped(e.target.result, x, y, true);
								reader = null;
							}, this);
							reader.readAsDataURL(file);
						}
					}, this));
				}
			}
		},
		cropParams : null,
		crop : function(button)
		{
			if (!!button)
				BX.addClass(button, "bxu-edit-btn-active");
			var cropBox = BX.create("DIV", {
				attrs : { id : "crop" + this.id, className : "bx-bxu-canvas-crop-rectangle" },
				style : { border : "3px dashed gray", position : "absolute", display : "none", zIndex : 1201 } } );

			this.cropParams = {
				x : 0, y : 0, width : 0, height : 0, top : 0, left : 0,
				mousedown : BX.delegate(function(e)
					{
						BX.fixEventPageXY(e);
						if (e.layerX || e.layerX == 0)
						{
							this.cropParams.left = e.layerX;
							this.cropParams.top = e.layerY;
						}
						else if(e.offsetX || e.offsetX == 0)
						{
							this.cropParams.left = e.offsetX;
							this.cropParams.top = e.offsetY;
						}
						else
						{
							this.cropParams.top = e.pageX - this.cnv.pos["left"];
							this.cropParams.left = e.pageY - this.cnv.pos["top"];
						}
						this.cropParams["~top"] = this.cropParams.top;
						this.cropParams["~left"] = this.cropParams.left;
						this.cropParams.x = e.pageX;
						this.cropParams.y = e.pageY;

						BX.bind(document, "mousemove", this.cropParams.mousemove);
					}, this),
				mousemove : BX.delegate(function(e)
					{
						BX.fixEventPageXY(e);
						var x = e.pageX, y = e.pageY;

						this.cropParams.width = (x - this.cropParams.x);
						if (this.cropParams.width < 0)
						{
							this.cropParams.left = this.cropParams["~left"] + this.cropParams.width;
							this.cropParams.width *= -1;
							if (this.cropParams.left < 0)
							{
								this.cropParams.left = 0;
								this.cropParams.width = this.cropParams["~left"];
							}
						}
						else
						{
							this.cropParams.left = this.cropParams["~left"];
							if ((this.cropParams.left + this.cropParams.width) > this.cnv.pos.width)
								this.cropParams.width = this.cnv.pos.width - this.cropParams.left;
						}

						this.cropParams.height = y - this.cropParams.y;
						if (this.cropParams.height < 0)
						{
							this.cropParams.top = this.cropParams["~top"] + this.cropParams.height;
							this.cropParams.height *= -1;
							if (this.cropParams.top < 0)
							{
								this.cropParams.top = 0;
								this.cropParams.height = this.cropParams["~top"];
							}
						}
						else
						{
							this.cropParams.top = this.cropParams["~top"];
							if ((this.cropParams.top + this.cropParams.height) > this.cnv.pos.height)
								this.cropParams.height = this.cnv.pos.height - this.cropParams.top;
						}

						BX.adjust(cropBox, {style : {
							left : (this.cropParams.left + 'px'),
							top : (this.cropParams.top + 'px'),
							width : ((this.cropParams.width - (cropBox.borderLeft + cropBox.borderRight)) + 'px'),
							height : ((this.cropParams.height - (cropBox.borderTop + cropBox.borderBottom)) + 'px'),
							display : "block"
						}});
					}, this),
				mouseup : BX.delegate(function(e)
					{
						BX.PreventDefault(e);
						if (this.cropParams.width > 0 && this.cropParams.height > 0)
						{
							var cnv = BX.create("CANVAS", {
								props : { width : this.cnv.width, height : this.cnv.height },
								style : { display : "none" } } );

							cnv.getContext("2d").drawImage(this.cnv, 0, 0);

							this.setStyles(this.cropParams);

							this.ctx.save();

							this.ctx.drawImage(cnv, -this.getRealFromVis(this.cropParams["left"]), -this.getRealFromVis(this.cropParams["top"]));
							this.ctx.restore();

							cnv = null;
						}
						this.cropParams.clear(e);
					}, this),
				clear :  BX.delegate(function(e)
					{
						if (!!button)
							BX.removeClass(button, "bxu-edit-btn-active");
						BX.unbind(this.cnv, "mousedown", this.cropParams.mousedown);
						BX.unbind(document, "mousemove", this.cropParams.mousemove);
						BX.unbind(this.cnv, "mouseup", this.cropParams.mouseup);
						BX.unbind(cropBox, "mouseup", this.cropParams.mouseup);
						BX.unbind(document, "mouseup", this.cropParams.mouseup);
						this.cnv.parentNode.style.position = this.cnv.parentNode.style._position;
						this.cnv.parentNode.removeChild(cropBox);
						cropBox = null;
						this.cropParams = null;
					}, this)
			};
			BX.bind(this.cnv, "mousedown", this.cropParams.mousedown);
			BX.bind(this.cnv, "mouseup", this.cropParams.mouseup);
			BX.bind(cropBox, "mouseup", this.cropParams.mouseup);
			BX.bind(document, "mouseup", this.cropParams.mouseup);
			this.cnv.pos = BX.pos(this.cnv);
			this.cnv.parentNode.style._position = this.cnv.parentNode.style.position;
			this.cnv.parentNode.style.position = "relative";
			this.cnv.parentNode.appendChild(cropBox);
			for (var ii = 0, i = ["top", "right", "bottom", "left"]; ii < i.length; ii++)
			{
				cropBox["b" + i[ii]] = parseInt(BX.style(cropBox, 'border-' + i[ii] + '-width'));
				cropBox["b" + i[ii]] = (!isNaN(cropBox["b" + i[ii]]) && cropBox["b" + i[ii]] > 0 ? cropBox["b" + i[ii]] : 0);
			}
			cropBox.borderLeft = cropBox["bleft"];
			cropBox.borderTop = cropBox["btop"];
			cropBox.borderRight = cropBox["bright"];
			cropBox.borderBottom = cropBox["bbottom"];
		}
	};
}(window));