Skip to content
This repository has been archived by the owner on Aug 1, 2020. It is now read-only.

Commit

Permalink
build: release 4.0.0
Browse files Browse the repository at this point in the history
  • Loading branch information
fengyuanchen committed Apr 1, 2018
1 parent 3d51fff commit 799ab63
Show file tree
Hide file tree
Showing 12 changed files with 6,545 additions and 6,073 deletions.
6 changes: 5 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
# Changelog

## 4.0.0 (Apr 1, 2018)

- Upgrade Cropper.js to 1.3.4.

## 4.0.0-beta (Mar 3, 2018)

- Upgrade Cropper.js from 1.3.1 to 1.3.2.
- Upgrade Cropper.js to 1.3.2.

## 4.0.0-alpha (Mar 1, 2018)

Expand Down
126 changes: 102 additions & 24 deletions dist/cropper.common.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
/*!
* Cropper v4.0.0-beta
* Cropper v4.0.0
* https://github.com/fengyuanchen/cropper
*
* Copyright (c) 2014-2018 Chen Fengyuan
* Released under the MIT license
*
* Date: 2018-03-03T03:59:36.917Z
* Date: 2018-04-01T06:27:27.267Z
*/

'use strict';
Expand All @@ -14,7 +14,8 @@ function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'defau

var $ = _interopDefault(require('jquery'));

var WINDOW = typeof window !== 'undefined' ? window : {};
var IN_BROWSER = typeof window !== 'undefined';
var WINDOW = IN_BROWSER ? window : {};
var NAMESPACE = 'cropper';

// Actions
Expand Down Expand Up @@ -329,7 +330,7 @@ var REGEXP_DECIMALS = /\.\d*(?:0|9){12}\d*$/i;

/**
* Normalize decimal number.
* Check out {@link http://0.30000000000000004.com/ }
* Check out {@link http://0.30000000000000004.com/}
* @param {number} value - The value to normalize.
* @param {number} [times=100000000000] - The times for normalizing.
* @returns {number} Returns the normalized number.
Expand Down Expand Up @@ -522,6 +523,35 @@ function removeData(element, name) {
}

var REGEXP_SPACES = /\s\s*/;
var onceSupported = function () {
var supported = false;

if (IN_BROWSER) {
var once = false;
var listener = function listener() {};
var options = Object.defineProperty({}, 'once', {
get: function get$$1() {
supported = true;
return once;
},


/**
* This setter can fix a `TypeError` in strict mode
* {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Errors/Getter_only}
* @param {boolean} value - The value to set
*/
set: function set$$1(value) {
once = value;
}
});

WINDOW.addEventListener('test', listener, options);
WINDOW.removeEventListener('test', listener, options);
}

return supported;
}();

/**
* Remove event listener from the target element.
Expand All @@ -533,8 +563,28 @@ var REGEXP_SPACES = /\s\s*/;
function removeListener(element, type, listener) {
var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};

forEach(type.trim().split(REGEXP_SPACES), function (t) {
element.removeEventListener(t, listener, options);
var handler = listener;

type.trim().split(REGEXP_SPACES).forEach(function (event) {
if (!onceSupported) {
var listeners = element.listeners;


if (listeners && listeners[event] && listeners[event][listener]) {
handler = listeners[event][listener];
delete listeners[event][listener];

if (Object.keys(listeners[event]).length === 0) {
delete listeners[event];
}

if (Object.keys(listeners).length === 0) {
delete element.listeners;
}
}
}

element.removeEventListener(event, handler, options);
});
}

Expand All @@ -545,24 +595,40 @@ function removeListener(element, type, listener) {
* @param {Function} listener - The event listener.
* @param {Object} options - The event options.
*/
function addListener(element, type, _listener) {
function addListener(element, type, listener) {
var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};

if (options.once) {
var originalListener = _listener;
var _handler = listener;

_listener = function listener() {
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
args[_key2] = arguments[_key2];
type.trim().split(REGEXP_SPACES).forEach(function (event) {
if (options.once && !onceSupported) {
var _element$listeners = element.listeners,
listeners = _element$listeners === undefined ? {} : _element$listeners;


_handler = function handler() {
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
args[_key2] = arguments[_key2];
}

delete listeners[event][listener];
element.removeEventListener(event, _handler, options);
listener.apply(element, args);
};

if (!listeners[event]) {
listeners[event] = {};
}

removeListener(element, type, _listener, options);
return originalListener.apply(element, args);
};
}
if (listeners[event][listener]) {
element.removeEventListener(event, listeners[event][listener], options);
}

listeners[event][listener] = _handler;
element.listeners = listeners;
}

forEach(type.trim().split(REGEXP_SPACES), function (t) {
element.addEventListener(t, _listener, options);
element.addEventListener(event, _handler, options);
});
}

Expand Down Expand Up @@ -841,7 +907,8 @@ function getRotatedSizes(_ref5) {
* @returns {HTMLCanvasElement} The result canvas.
*/
function getSourceCanvas(image, _ref6, _ref7, _ref8) {
var imageNaturalWidth = _ref6.naturalWidth,
var imageAspectRatio = _ref6.aspectRatio,
imageNaturalWidth = _ref6.naturalWidth,
imageNaturalHeight = _ref6.naturalHeight,
_ref6$rotate = _ref6.rotate,
rotate = _ref6$rotate === undefined ? 0 : _ref6$rotate,
Expand Down Expand Up @@ -884,8 +951,18 @@ function getSourceCanvas(image, _ref6, _ref7, _ref8) {

// Note: should always use image's natural sizes for drawing as
// imageData.naturalWidth === canvasData.naturalHeight when rotate % 180 === 90
var destWidth = Math.min(maxSizes.width, Math.max(minSizes.width, imageNaturalWidth));
var destHeight = Math.min(maxSizes.height, Math.max(minSizes.height, imageNaturalHeight));
var destMaxSizes = getAdjustedSizes({
aspectRatio: imageAspectRatio,
width: maxWidth,
height: maxHeight
});
var destMinSizes = getAdjustedSizes({
aspectRatio: imageAspectRatio,
width: minWidth,
height: minHeight
}, 'cover');
var destWidth = Math.min(destMaxSizes.width, Math.max(destMinSizes.width, imageNaturalWidth));
var destHeight = Math.min(destMaxSizes.height, Math.max(destMinSizes.height, imageNaturalHeight));
var params = [-destWidth / 2, -destHeight / 2, destWidth, destHeight];

canvas.width = normalizeDecimalNumber(width);
Expand Down Expand Up @@ -3099,8 +3176,6 @@ var methods = {
dstHeight = srcHeight;
}

// All the numerical parameters should be integer for `drawImage`
// https://github.com/fengyuanchen/cropper/issues/476
var params = [srcX, srcY, srcWidth, srcHeight];

// Avoid "IndexSizeError"
Expand All @@ -3110,6 +3185,8 @@ var methods = {
params.push(dstX * scale, dstY * scale, dstWidth * scale, dstHeight * scale);
}

// All the numerical parameters should be integer for `drawImage`
// https://github.com/fengyuanchen/cropper/issues/476
context.drawImage.apply(context, [source].concat(toConsumableArray(params.map(function (param) {
return Math.floor(normalizeDecimalNumber(param));
}))));
Expand Down Expand Up @@ -3380,6 +3457,7 @@ var Cropper = function () {

if (this.isImg) {
if (element.complete) {
// start asynchronously to keep `this.cropper` is accessible in `ready` event handler.
this.timeout = setTimeout(start, 0);
} else {
addListener(element, EVENT_LOAD, start, {
Expand Down Expand Up @@ -3667,7 +3745,7 @@ if ($.fn) {
}
});

return typeof result === 'undefined' ? this : result;
return result !== undefined ? result : this;
};

$.fn.cropper.Constructor = Cropper;
Expand Down
4 changes: 2 additions & 2 deletions dist/cropper.css
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
/*!
* Cropper v4.0.0-beta
* Cropper v4.0.0
* https://github.com/fengyuanchen/cropper
*
* Copyright (c) 2014-2018 Chen Fengyuan
* Released under the MIT license
*
* Date: 2018-03-03T03:58:44.059Z
* Date: 2018-04-01T06:26:32.417Z
*/

.cropper-container {
Expand Down
Loading

0 comments on commit 799ab63

Please sign in to comment.