ngx-cropperjs-wrapper
Version:
This angular library is a wrapper of Javascript image cropper
380 lines (379 loc) • 37.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import Cropper from 'cropperjs';
/**
* @record
*/
export function CropperOutputOptions() { }
/** @type {?} */
CropperOutputOptions.prototype.mimeType;
/** @type {?} */
CropperOutputOptions.prototype.qualityArgument;
/**
* @record
*/
export function CropperOptions() { }
/** @type {?} */
CropperOptions.prototype.minCropWidth;
/** @type {?} */
CropperOptions.prototype.minCropHeight;
/** @type {?} */
CropperOptions.prototype.outputOptions;
var CropperComponent = /** @class */ (function () {
function CropperComponent() {
this.crop = new EventEmitter();
this.cropMove = new EventEmitter();
this.cropStart = new EventEmitter();
this.cropEnd = new EventEmitter();
this.ready = new EventEmitter();
this.zoom = new EventEmitter();
this.init = new EventEmitter();
this.fail = new EventEmitter();
this.fileChange = new EventEmitter();
this.options = /** @type {?} */ ({});
this.data = /** @type {?} */ ({});
this.propagateChange = function (value) { return value; };
}
Object.defineProperty(CropperComponent.prototype, "imageFile", {
get: /**
* @return {?}
*/
function () {
return this.originalFile;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
var _this = this;
delete this.dataUrl;
this.destroyCropperIfExists();
if (!value) {
return;
}
if (['image/gif', 'image/jpeg', 'image/png'].indexOf(value.type) === -1) {
this.fail.emit(new Error('Invalid input file type'));
return;
}
/** @type {?} */
var reader = new FileReader();
reader.onload = function () {
_this.dataUrl = reader.result;
};
this.originalFile = value;
reader.readAsDataURL(this.originalFile);
},
enumerable: true,
configurable: true
});
Object.defineProperty(CropperComponent.prototype, "imageUrl", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
delete this.dataUrl;
this.destroyCropperIfExists();
if (!value) {
return;
}
this.dataUrl = value;
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
CropperComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.data = value;
if (this.data && this.cropper) {
this.cropper.setData(this.data);
}
};
/**
* @param {?} fn
* @return {?}
*/
CropperComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.propagateChange = fn;
};
/**
* @return {?}
*/
CropperComponent.prototype.registerOnTouched = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
CropperComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroyCropperIfExists();
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onImageLoad = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var img = /** @type {?} */ (event.target);
this.destroyCropperIfExists();
if ((this.options.minCropWidth && img.naturalWidth < this.options.minCropWidth)
|| (this.options.minCropHeight && img.naturalHeight < this.options.minCropHeight)) {
delete this.dataUrl;
this.fail.emit(new Error('Input image is too small'));
return;
}
this.isReady = false;
this.cropper = new Cropper(img, Object.assign({
crop: this.onCrop.bind(this),
cropmove: this.onCropMove.bind(this),
cropstart: this.onCropStart.bind(this),
cropend: this.onCropEnd.bind(this),
ready: this.onReady.bind(this),
zoom: this.onZoom.bind(this),
}, this.options));
this.init.emit(this.cropper);
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onCrop = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.options.viewMode !== 0) {
this.correctCropArea();
}
if (this.isReady) {
this.update();
}
this.crop.emit(event);
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onCropMove = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.options.viewMode === 0) {
this.correctCropArea();
}
this.update();
this.cropMove.emit(event);
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onCropStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.update();
this.cropStart.emit(event);
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onCropEnd = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.correctCropArea();
this.updateFile();
this.update();
this.cropEnd.emit(event);
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onReady = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.data) {
this.cropper.setData(this.data);
this.correctCropArea();
}
else {
this.correctCropArea();
this.update();
}
this.isReady = true;
this.ready.emit(event);
this.updateFile();
};
/**
* @param {?} event
* @return {?}
*/
CropperComponent.prototype.onZoom = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.update();
this.zoom.emit(event);
};
/**
* @return {?}
*/
CropperComponent.prototype.updateFile = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var name = 'cropped_file';
if (typeof this.dataUrl === 'string') {
/** @type {?} */
var urlParams = this.dataUrl.split('/');
name = urlParams[urlParams.length - 1];
}
/** @type {?} */
var mimeType = (this.options.outputOptions && this.options.outputOptions.mimeType) || 'image/png';
/** @type {?} */
var qualityArgument = (this.options.outputOptions && this.options.outputOptions.qualityArgument) || 0.9;
this.cropper.getCroppedCanvas().toBlob(function (blob) {
blob.lastModifiedDate = new Date();
blob.name = _this.originalFile ? _this.originalFile.name : name;
_this.fileChange.emit(blob);
}, mimeType, qualityArgument);
};
/**
* @return {?}
*/
CropperComponent.prototype.correctCropArea = /**
* @return {?}
*/
function () {
/** @type {?} */
var data = this.cropper.getData();
if (data.height < this.options.minCropHeight || data.width < this.options.minCropWidth) {
data.width = Math.max(data.width, this.options.minCropWidth || 0);
data.height = Math.max(data.height, this.options.minCropHeight || 0);
this.cropper.setData(data);
}
};
/**
* @return {?}
*/
CropperComponent.prototype.update = /**
* @return {?}
*/
function () {
this.data = this.cropper.getData();
this.propagateChange(this.data);
};
/**
* @return {?}
*/
CropperComponent.prototype.destroyCropperIfExists = /**
* @return {?}
*/
function () {
if (!this.cropper) {
return;
}
this.cropper.destroy();
delete this.cropper;
};
CropperComponent.decorators = [
{ type: Component, args: [{
selector: 'lib-cropper',
template: "<div class=\"cropper-component\" *ngIf=\"dataUrl\">\n <img #image alt=\"image\" [src]=\"dataUrl\" (load)=\"onImageLoad($event)\"/>\n</div>\n",
styles: [".cropper-component img{max-width:100%;max-height:100%}::ng-deep{/*!\n * Cropper.js v1.4.0\n * https://fengyuanchen.github.io/cropperjs\n *\n * Copyright 2015-present Chen Fengyuan\n * Released under the MIT license\n *\n * Date: 2018-06-01T15:18:09.891Z\n */}::ng-deep .cropper-container{direction:ltr;font-size:0;line-height:0;position:relative;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}::ng-deep .cropper-container img{display:block;height:100%;image-orientation:0deg;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}::ng-deep .cropper-canvas,::ng-deep .cropper-crop-box,::ng-deep .cropper-drag-box,::ng-deep .cropper-modal,::ng-deep .cropper-wrap-box{bottom:0;left:0;position:absolute;right:0;top:0}::ng-deep .cropper-canvas,::ng-deep .cropper-wrap-box{overflow:hidden}::ng-deep .cropper-drag-box{background-color:#fff;opacity:0}::ng-deep .cropper-modal{background-color:#000;opacity:.5}::ng-deep .cropper-view-box{display:block;height:100%;outline:#eee solid 1px;overflow:hidden;width:100%}::ng-deep .cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}::ng-deep .cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:33.33333%;left:0;top:33.33333%;width:100%}::ng-deep .cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:33.33333%;top:0;width:33.33333%}::ng-deep .cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}::ng-deep .cropper-center:after,::ng-deep .cropper-center:before{background-color:#eee;content:' ';display:block;position:absolute}::ng-deep .cropper-center:before{height:1px;left:-3px;top:0;width:7px}::ng-deep .cropper-center:after{height:7px;left:0;top:-3px;width:1px}::ng-deep .cropper-face,::ng-deep .cropper-line,::ng-deep .cropper-point{display:block;height:100%;opacity:.1;position:absolute;width:100%}::ng-deep .cropper-face{background-color:#fff;left:0;top:0}::ng-deep .cropper-line{background-color:#39f}::ng-deep .cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}::ng-deep .cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}::ng-deep .cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}::ng-deep .cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}::ng-deep .cropper-point{background-color:#39f;height:5px;opacity:.75;width:5px}::ng-deep .cropper-point.point-e{cursor:ew-resize;margin-top:-3px;right:-3px;top:50%}::ng-deep .cropper-point.point-n{cursor:ns-resize;left:50%;margin-left:-3px;top:-3px}::ng-deep .cropper-point.point-w{cursor:ew-resize;left:-3px;margin-top:-3px;top:50%}::ng-deep .cropper-point.point-s{bottom:-3px;cursor:s-resize;left:50%;margin-left:-3px}::ng-deep .cropper-point.point-ne{cursor:nesw-resize;right:-3px;top:-3px}::ng-deep .cropper-point.point-nw{cursor:nwse-resize;left:-3px;top:-3px}::ng-deep .cropper-point.point-sw{bottom:-3px;cursor:nesw-resize;left:-3px}::ng-deep .cropper-point.point-se{bottom:-3px;cursor:nwse-resize;height:20px;opacity:1;right:-3px;width:20px}@media (min-width:768px){::ng-deep .cropper-point.point-se{height:15px;width:15px}}@media (min-width:992px){::ng-deep .cropper-point.point-se{height:10px;width:10px}}@media (min-width:1200px){::ng-deep .cropper-point.point-se{height:5px;opacity:.75;width:5px}}::ng-deep .cropper-point.point-se:before{background-color:#39f;bottom:-50%;content:' ';display:block;height:200%;opacity:0;position:absolute;right:-50%;width:200%}::ng-deep .cropper-invisible{opacity:0}::ng-deep .cropper-bg{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC)}::ng-deep .cropper-hide{display:block;height:0;position:absolute;width:0}::ng-deep .cropper-hidden{display:none!important}::ng-deep .cropper-move{cursor:move}::ng-deep .cropper-crop{cursor:crosshair}::ng-deep .cropper-disabled .cropper-drag-box,::ng-deep .cropper-disabled .cropper-face,::ng-deep .cropper-disabled .cropper-line,::ng-deep .cropper-disabled .cropper-point{cursor:not-allowed}::ng-deep .cropper-line,::ng-deep .cropper-point,::ng-deep .cropper-point.point-se::before{background-color:#eee}"],
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return CropperComponent; }),
multi: true
}
],
},] },
];
CropperComponent.propDecorators = {
crop: [{ type: Output }],
cropMove: [{ type: Output }],
cropStart: [{ type: Output }],
cropEnd: [{ type: Output }],
ready: [{ type: Output }],
zoom: [{ type: Output }],
init: [{ type: Output }],
fail: [{ type: Output }],
fileChange: [{ type: Output }],
options: [{ type: Input }],
imageFile: [{ type: Input, args: ['imageFile',] }],
imageUrl: [{ type: Input, args: ['imageUrl',] }]
};
return CropperComponent;
}());
export { CropperComponent };
if (false) {
/** @type {?} */
CropperComponent.prototype.crop;
/** @type {?} */
CropperComponent.prototype.cropMove;
/** @type {?} */
CropperComponent.prototype.cropStart;
/** @type {?} */
CropperComponent.prototype.cropEnd;
/** @type {?} */
CropperComponent.prototype.ready;
/** @type {?} */
CropperComponent.prototype.zoom;
/** @type {?} */
CropperComponent.prototype.init;
/** @type {?} */
CropperComponent.prototype.fail;
/** @type {?} */
CropperComponent.prototype.fileChange;
/** @type {?} */
CropperComponent.prototype.options;
/** @type {?} */
CropperComponent.prototype.dataUrl;
/** @type {?} */
CropperComponent.prototype.cropper;
/** @type {?} */
CropperComponent.prototype.isReady;
/** @type {?} */
CropperComponent.prototype.originalFile;
/** @type {?} */
CropperComponent.prototype.data;
/** @type {?} */
CropperComponent.prototype.propagateChange;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cropper.component.js","sourceRoot":"ng://ngx-cropperjs-wrapper/","sources":["lib/cropper/cropper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, Output, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport Cropper from 'cropperjs';\nimport { SafeUrl } from '@angular/platform-browser';\n\nexport interface CropperOutputOptions {\n  mimeType: string;\n  qualityArgument: number;\n}\n\nexport interface CropperOptions extends Cropper.Options {\n  minCropWidth: number;\n  minCropHeight: number;\n  outputOptions: CropperOutputOptions;\n}\n\n@Component({\n  selector: 'lib-cropper',\n  template: `<div class=\"cropper-component\" *ngIf=\"dataUrl\">\n  <img #image alt=\"image\" [src]=\"dataUrl\" (load)=\"onImageLoad($event)\"/>\n</div>\n`,\n  styles: [`.cropper-component img{max-width:100%;max-height:100%}::ng-deep{/*!\n * Cropper.js v1.4.0\n * https://fengyuanchen.github.io/cropperjs\n *\n * Copyright 2015-present Chen Fengyuan\n * Released under the MIT license\n *\n * Date: 2018-06-01T15:18:09.891Z\n */}::ng-deep .cropper-container{direction:ltr;font-size:0;line-height:0;position:relative;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}::ng-deep .cropper-container img{display:block;height:100%;image-orientation:0deg;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}::ng-deep .cropper-canvas,::ng-deep .cropper-crop-box,::ng-deep .cropper-drag-box,::ng-deep .cropper-modal,::ng-deep .cropper-wrap-box{bottom:0;left:0;position:absolute;right:0;top:0}::ng-deep .cropper-canvas,::ng-deep .cropper-wrap-box{overflow:hidden}::ng-deep .cropper-drag-box{background-color:#fff;opacity:0}::ng-deep .cropper-modal{background-color:#000;opacity:.5}::ng-deep .cropper-view-box{display:block;height:100%;outline:#eee solid 1px;overflow:hidden;width:100%}::ng-deep .cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}::ng-deep .cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:33.33333%;left:0;top:33.33333%;width:100%}::ng-deep .cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:33.33333%;top:0;width:33.33333%}::ng-deep .cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}::ng-deep .cropper-center:after,::ng-deep .cropper-center:before{background-color:#eee;content:' ';display:block;position:absolute}::ng-deep .cropper-center:before{height:1px;left:-3px;top:0;width:7px}::ng-deep .cropper-center:after{height:7px;left:0;top:-3px;width:1px}::ng-deep .cropper-face,::ng-deep .cropper-line,::ng-deep .cropper-point{display:block;height:100%;opacity:.1;position:absolute;width:100%}::ng-deep .cropper-face{background-color:#fff;left:0;top:0}::ng-deep .cropper-line{background-color:#39f}::ng-deep .cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}::ng-deep .cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}::ng-deep .cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}::ng-deep .cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}::ng-deep .cropper-point{background-color:#39f;height:5px;opacity:.75;width:5px}::ng-deep .cropper-point.point-e{cursor:ew-resize;margin-top:-3px;right:-3px;top:50%}::ng-deep .cropper-point.point-n{cursor:ns-resize;left:50%;margin-left:-3px;top:-3px}::ng-deep .cropper-point.point-w{cursor:ew-resize;left:-3px;margin-top:-3px;top:50%}::ng-deep .cropper-point.point-s{bottom:-3px;cursor:s-resize;left:50%;margin-left:-3px}::ng-deep .cropper-point.point-ne{cursor:nesw-resize;right:-3px;top:-3px}::ng-deep .cropper-point.point-nw{cursor:nwse-resize;left:-3px;top:-3px}::ng-deep .cropper-point.point-sw{bottom:-3px;cursor:nesw-resize;left:-3px}::ng-deep .cropper-point.point-se{bottom:-3px;cursor:nwse-resize;height:20px;opacity:1;right:-3px;width:20px}@media (min-width:768px){::ng-deep .cropper-point.point-se{height:15px;width:15px}}@media (min-width:992px){::ng-deep .cropper-point.point-se{height:10px;width:10px}}@media (min-width:1200px){::ng-deep .cropper-point.point-se{height:5px;opacity:.75;width:5px}}::ng-deep .cropper-point.point-se:before{background-color:#39f;bottom:-50%;content:' ';display:block;height:200%;opacity:0;position:absolute;right:-50%;width:200%}::ng-deep .cropper-invisible{opacity:0}::ng-deep .cropper-bg{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC)}::ng-deep .cropper-hide{display:block;height:0;position:absolute;width:0}::ng-deep .cropper-hidden{display:none!important}::ng-deep .cropper-move{cursor:move}::ng-deep .cropper-crop{cursor:crosshair}::ng-deep .cropper-disabled .cropper-drag-box,::ng-deep .cropper-disabled .cropper-face,::ng-deep .cropper-disabled .cropper-line,::ng-deep .cropper-disabled .cropper-point{cursor:not-allowed}::ng-deep .cropper-line,::ng-deep .cropper-point,::ng-deep .cropper-point.point-se::before{background-color:#eee}`],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CropperComponent),\n      multi: true\n    }\n  ],\n})\nexport class CropperComponent implements OnDestroy, ControlValueAccessor {\n\n  @Output() crop = new EventEmitter<CustomEvent>();\n  @Output() cropMove = new EventEmitter<CustomEvent>();\n  @Output() cropStart = new EventEmitter<CustomEvent>();\n  @Output() cropEnd = new EventEmitter<CustomEvent>();\n  @Output() ready = new EventEmitter<CustomEvent>();\n  @Output() zoom = new EventEmitter<CustomEvent>();\n  @Output() init = new EventEmitter<Cropper>();\n  @Output() fail = new EventEmitter<Error>();\n  @Output() fileChange = new EventEmitter<File>();\n\n  @Input() options = {} as CropperOptions;\n\n  get imageFile(): File {\n    return this.originalFile;\n  }\n\n  @Input('imageFile') set imageFile(value: File) {\n    delete this.dataUrl;\n    this.destroyCropperIfExists();\n\n    if (!value) {\n      return;\n    }\n\n    if (['image/gif', 'image/jpeg', 'image/png'].indexOf(value.type) === -1) {\n      this.fail.emit(new Error('Invalid input file type'));\n      return;\n    }\n\n    const reader = new FileReader();\n    reader.onload = () => {\n      this.dataUrl = reader.result;\n    };\n\n    this.originalFile = value;\n    reader.readAsDataURL(this.originalFile);\n  }\n\n  @Input('imageUrl') set imageUrl(value: string) {\n    delete this.dataUrl;\n    this.destroyCropperIfExists();\n\n    if (!value) {\n      return;\n    }\n\n    this.dataUrl = value;\n  }\n\n  dataUrl: string|SafeUrl;\n  private cropper: Cropper;\n  private isReady: boolean;\n  private originalFile: File;\n  private data = {} as Cropper.SetDataOptions;\n\n  propagateChange = (value: Cropper.SetDataOptions) => value;\n\n  writeValue(value: Cropper.SetDataOptions) {\n    this.data = value;\n\n    if (this.data && this.cropper) {\n      this.cropper.setData(this.data);\n    }\n  }\n\n  registerOnChange(fn) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched() {}\n\n  ngOnDestroy() {\n    this.destroyCropperIfExists();\n  }\n\n  onImageLoad(event: Event) {\n    const img = event.target as HTMLImageElement;\n\n    this.destroyCropperIfExists();\n\n    if ((this.options.minCropWidth && img.naturalWidth < this.options.minCropWidth)\n      || (this.options.minCropHeight && img.naturalHeight < this.options.minCropHeight)) {\n      delete this.dataUrl;\n      this.fail.emit(new Error('Input image is too small'));\n      return;\n    }\n\n    this.isReady = false;\n    this.cropper = new Cropper(img, Object.assign({\n      crop: this.onCrop.bind(this),\n      cropmove: this.onCropMove.bind(this),\n      cropstart: this.onCropStart.bind(this),\n      cropend: this.onCropEnd.bind(this),\n      ready: this.onReady.bind(this),\n      zoom: this.onZoom.bind(this),\n    }, this.options));\n\n    this.init.emit(this.cropper);\n  }\n\n  private onCrop(event: CustomEvent) {\n    if (this.options.viewMode !== 0) {\n      this.correctCropArea();\n    }\n\n    if (this.isReady) {\n      this.update();\n    }\n\n    this.crop.emit(event);\n  }\n\n  private onCropMove(event: CustomEvent) {\n    if (this.options.viewMode === 0) {\n      this.correctCropArea();\n    }\n\n    this.update();\n    this.cropMove.emit(event);\n  }\n\n  private onCropStart(event: CustomEvent) {\n    this.update();\n    this.cropStart.emit(event);\n  }\n\n  private onCropEnd(event: CustomEvent) {\n    this.correctCropArea();\n    this.updateFile();\n    this.update();\n    this.cropEnd.emit(event);\n  }\n\n  private onReady(event: CustomEvent) {\n    if (this.data) {\n      this.cropper.setData(this.data);\n      this.correctCropArea();\n    } else {\n      this.correctCropArea();\n      this.update();\n    }\n\n    this.isReady = true;\n    this.ready.emit(event);\n    this.updateFile();\n  }\n\n  private onZoom(event: CustomEvent) {\n    this.update();\n    this.zoom.emit(event);\n  }\n\n  private updateFile() {\n    let name = 'cropped_file';\n\n    if (typeof this.dataUrl === 'string') {\n      const urlParams = this.dataUrl.split('/');\n      name = urlParams[urlParams.length - 1];\n    }\n\n\n    const mimeType = (this.options.outputOptions && this.options.outputOptions.mimeType) || 'image/png';\n    const qualityArgument = (this.options.outputOptions && this.options.outputOptions.qualityArgument) || 0.9;\n\n    this.cropper.getCroppedCanvas().toBlob((blob: any) => {\n      blob.lastModifiedDate = new Date();\n      blob.name = this.originalFile ? this.originalFile.name : name;\n      this.fileChange.emit(blob);\n    }, mimeType, qualityArgument);\n  }\n\n  private correctCropArea() {\n    const data = this.cropper.getData();\n\n    if (data.height < this.options.minCropHeight || data.width < this.options.minCropWidth) {\n      data.width = Math.max(data.width, this.options.minCropWidth || 0);\n      data.height = Math.max(data.height, this.options.minCropHeight || 0);\n      this.cropper.setData(data);\n    }\n  }\n\n  private update() {\n    this.data = this.cropper.getData();\n    this.propagateChange(this.data);\n  }\n\n  private destroyCropperIfExists() {\n    if (!this.cropper) {\n      return;\n    }\n\n    this.cropper.destroy();\n    delete this.cropper;\n  }\n\n}\n"]}