| Server IP : 170.10.162.208 / Your IP : 216.73.216.38 Web Server : LiteSpeed System : Linux altar19.supremepanel19.com 4.18.0-553.69.1.lve.el8.x86_64 #1 SMP Wed Aug 13 19:53:59 UTC 2025 x86_64 User : deltahospital ( 1806) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home1/deltahospital/www/wp-content/plugins/imagify/assets/js/ |
Upload File : |
/*
* imagify-gulpjs - version 0.0.1 - 2017-07-28
* WP Media <contact@wp-media.me>
*/
'use strict';
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var ImagifyGulp = function () {
function ImagifyGulp(settings) {
_classCallCheck(this, ImagifyGulp);
this.buffer_size = settings.buffer_size || 1;
this.lib_url = settings.lib;
this.default_thumb = "";
this.images = settings.images;
this.images_ids = Object.keys(settings.images);
this.total_images = this.images_ids.length;
this.processed_images = 0;
this.inprocess_images = 0;
this._before = new Function();
this._each = new Function();
this._done = new Function();
this._error = new Function();
this.global_original_size = 0;
this.global_optimized_size = 0;
this.global_gain = 0;
this.global_percent = 0;
this.context = settings.context || 'wp';
}
_createClass(ImagifyGulp, [{
key: 'before',
value: function before(fnc) {
this._before = fnc;
return this;
}
}, {
key: 'each',
value: function each(fnc) {
this._each = fnc;
return this;
}
}, {
key: 'done',
value: function done(fnc) {
this._done = fnc;
return this;
}
}, {
key: 'error',
value: function error(fnc) {
this._error = fnc;
return this;
}
}, {
key: 'humanSize',
value: function humanSize(bytes) {
if (0 === bytes) return '0\xA0kB';
var sizes = ['B', 'kB', 'MB'],
i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)), 10);
return (bytes / Math.pow(1024, i)).toFixed(2) + '\xA0' + sizes[i];
}
}, {
key: 'run',
value: function run() {
var cpt = this.images_ids.length > this.buffer_size ? this.buffer_size : this.images_ids.length;
for (var i = 0; i < cpt; i++) {
var id = this.images_ids.shift();
this.process(id);
}
return this;
}
}, {
key: 'stopProcess',
value: function stopProcess() {
this.total_images = this.total_images - this.images_ids.length;
this.images_ids = [];
return this;
}
}, {
key: 'process',
value: function process(id) {
this.inprocess_images++;
var data = {
id: id,
image_id: parseInt(id.toString().substr(1), 10),
image_src: this.images[id],
filename: this.images[id].split('/').pop(),
thumbnail: this.default_thumb,
error: ''
};
this.createThumb(data);
}
}, {
key: 'createThumb',
value: function createThumb(data) {
var self = this,
image = new Image();
image.onerror = function () {
var data_before = data;
data_before.id = data.image_id;
self._before(data_before);
self.send(data);
};
image.onload = function () {
var maxWidth = 33,
maxHeight = 33,
imageWidth = image.width,
imageHeight = image.height,
ratio = 1,
newHeight = 0,
newWidth = 0,
canvas = null,
ctx = null;
if (imageWidth < imageHeight) {
ratio = maxWidth / imageWidth;
newWidth = maxWidth;
newHeight = imageHeight * ratio;
} else {
ratio = maxHeight / imageHeight;
newHeight = maxHeight;
newWidth = imageWidth * ratio;
}
canvas = document.createElement('canvas');
canvas.width = newWidth;
canvas.height = newHeight;
image.width = newWidth;
image.height = newHeight;
ctx = canvas.getContext('2d');
ctx.drawImage(this, 0, 0, newWidth, newHeight);
try {
data.thumbnail = canvas.toDataURL('image/jpeg');
} catch (e) {
data.thumbnail = self.default_thumb;
}
var before_data = data;
before_data.id = data.image_id;
self._before(before_data);
self.send(data);
canvas = null;
};
image.src = data.image_src;
}
}, {
key: 'send',
value: function send(data) {
var self = this,
transport = new XMLHttpRequest(),
err = false,
json = {},
response = {
id: data.id,
image: data.image_id,
filename: data.filename,
thumbnail: data.thumbnail,
error: ''
};
transport.onreadystatechange = function () {
if (4 === this.readyState) {
self.processed_images++;
try {
json = JSON.parse(this.responseText);
err = false;
} catch (e) {
response.success = false;
response.error = 'Unknown error occured';
err = true;
}
response.progress = Math.floor(self.processed_images / self.total_images * 100);
if (!err) {
var json_data = json.data;
response.success = json.success;
if (true === json.success) {
self.global_original_size += json_data.original_overall_size;
self.global_optimized_size += json_data.new_overall_size;
self.global_gain += json_data.overall_saving;
self.global_percent = ( 100 - self.global_optimized_size / self.global_optimized_size * 100 ).toFixed( 2 );
response.original_size_human = json_data.original_size_human;
response.new_size_human = json_data.new_size_human;
response.overall_saving_human = json_data.overall_saving_human;
response.original_overall_size_human = json_data.original_overall_size_human;
response.percent_human = json_data.percent_human;
response.thumbnails = json_data.thumbnails;
} else {
response.error_code = json_data.error_code;
response.error = json_data.error;
}
}
self._each(response);
if (self.inprocess_images < self.total_images) {
self.process(self.images_ids.shift());
}
if ( self.processed_images === self.total_images ) {
self._done( {
global_original_size: self.global_original_size,
global_optimized_size: self.global_optimized_size,
global_gain: self.global_gain
} );
}
}
};
transport.open('POST', this.lib_url, true);
transport.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
transport.send('image=' + data.image_id + '&context=' + this.context);
}
}]);
return ImagifyGulp;
}();
//# sourceMappingURL=imagify-gulp.js.map