This repository has been archived by the owner on May 26, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #73 from joomla-projects/upstream-sync-media
Upstream sync media
- Loading branch information
Showing
6 changed files
with
276 additions
and
251 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,93 +1,99 @@ | ||
/** | ||
* PLEASE DO NOT MODIFY THIS FILE. WORK ON THE ES6 VERSION. | ||
* OTHERWISE YOUR CHANGES WILL BE REPLACED ON THE NEXT BUILD. | ||
**/ | ||
|
||
/** | ||
* @copyright Copyright (C) 2005 - 2017 Open Source Matters, Inc. All rights reserved. | ||
* @license GNU General Public License version 2 or later; see LICENSE.txt | ||
*/ | ||
|
||
/* global Cropper */ | ||
|
||
Joomla = window.Joomla || {}; | ||
|
||
Joomla.MediaManager = Joomla.MediaManager || {}; | ||
Joomla.MediaManager.Edit = Joomla.MediaManager.Edit || {}; | ||
|
||
(function () { | ||
"use strict"; | ||
|
||
var initCrop = function (mediaData) { | ||
var image = document.getElementById('image-preview'); | ||
|
||
// Initiate the cropper | ||
Joomla.MediaManager.Edit.crop.cropper = new Cropper(image, { | ||
viewMode: 1, | ||
responsive: true, | ||
restore: true, | ||
autoCrop: true, | ||
movable: false, | ||
zoomable: false, | ||
rotatable: false, | ||
autoCropArea: 1, | ||
// scalable: false, | ||
minContainerWidth: image.offsetWidth, | ||
minContainerHeight: image.offsetHeight, | ||
crop: function (e) { | ||
document.getElementById('jform_crop_x').value = Math.round(e.detail.x); | ||
document.getElementById('jform_crop_y').value = Math.round(e.detail.y); | ||
document.getElementById('jform_crop_width').value = Math.round(e.detail.width); | ||
document.getElementById('jform_crop_height').value = Math.round(e.detail.height); | ||
'use strict'; | ||
|
||
var format = Joomla.MediaManager.Edit.original.extension === 'jpg' ? 'jpeg' : Joomla.MediaManager.Edit.original.extension; | ||
var initCrop = function initCrop() { | ||
var image = document.getElementById('image-preview'); | ||
|
||
var quality = document.getElementById('jform_crop_quality').value; | ||
// Initiate the cropper | ||
Joomla.MediaManager.Edit.crop.cropper = new Cropper(image, { | ||
viewMode: 1, | ||
responsive: true, | ||
restore: true, | ||
autoCrop: true, | ||
movable: false, | ||
zoomable: false, | ||
rotatable: false, | ||
autoCropArea: 1, | ||
// scalable: false, | ||
minContainerWidth: image.offsetWidth, | ||
minContainerHeight: image.offsetHeight, | ||
crop: function crop(e) { | ||
document.getElementById('jform_crop_x').value = Math.round(e.detail.x); | ||
document.getElementById('jform_crop_y').value = Math.round(e.detail.y); | ||
document.getElementById('jform_crop_width').value = Math.round(e.detail.width); | ||
document.getElementById('jform_crop_height').value = Math.round(e.detail.height); | ||
|
||
// Update the store | ||
Joomla.MediaManager.Edit.current.contents = this.cropper.getCroppedCanvas().toDataURL("image/" + format, quality); | ||
var format = Joomla.MediaManager.Edit.original.extension === 'jpg' ? 'jpeg' : Joomla.MediaManager.Edit.original.extension; | ||
|
||
// Notify the app that a change has been made | ||
window.dispatchEvent(new Event('mediaManager.history.point')); | ||
} | ||
}); | ||
var quality = document.getElementById('jform_crop_quality').value; | ||
|
||
document.getElementById('jform_crop_x').addEventListener('change', function (e) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({x: parseInt(this.value)}); | ||
}); | ||
document.getElementById('jform_crop_y').addEventListener('change', function (e) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({y: parseInt(this.value)}); | ||
}); | ||
document.getElementById('jform_crop_width').addEventListener('change', function (e) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({width: parseInt(this.value)}); | ||
}); | ||
document.getElementById('jform_crop_height').addEventListener('change', function (e) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({height: parseInt(this.value)}); | ||
}); | ||
document.getElementById('jform_aspectRatio').addEventListener("change", function (e) { | ||
Joomla.MediaManager.Edit.crop.cropper.setAspectRatio(this.value); | ||
}); | ||
// Update the store | ||
Joomla.MediaManager.Edit.current.contents = this.cropper.getCroppedCanvas().toDataURL('image/' + format, quality); | ||
|
||
// Wait for the image to load its data | ||
image.addEventListener('load', function() { | ||
// Notify the app that a change has been made | ||
window.dispatchEvent(new Event('mediaManager.history.point')); | ||
} | ||
}); | ||
|
||
// Get all option elements if future need | ||
var elements = [].slice.call(document.querySelectorAll(".crop-aspect-ratio-option")); | ||
document.getElementById('jform_crop_x').addEventListener('change', function (event) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({ x: parseInt(event.target.value, 10) }); | ||
}); | ||
document.getElementById('jform_crop_y').addEventListener('change', function (event) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({ y: parseInt(event.target.value, 10) }); | ||
}); | ||
document.getElementById('jform_crop_width').addEventListener('change', function (event) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({ width: parseInt(event.target.value, 10) }); | ||
}); | ||
document.getElementById('jform_crop_height').addEventListener('change', function (event) { | ||
Joomla.MediaManager.Edit.crop.cropper.setData({ height: parseInt(event.target.value, 10) }); | ||
}); | ||
document.getElementById('jform_aspectRatio').addEventListener('change', function (event) { | ||
Joomla.MediaManager.Edit.crop.cropper.setAspectRatio(event.target.value); | ||
}); | ||
|
||
// Set default aspect ratio after numeric check, option has a dummy value | ||
var defaultCropFactor = image.naturalWidth / image.naturalHeight; | ||
if (!isNaN(+defaultCropFactor) && isFinite(defaultCropFactor)){ | ||
elements[0].value = defaultCropFactor; | ||
} | ||
Joomla.MediaManager.Edit.crop.cropper.setAspectRatio(elements[0].value); | ||
// Wait for the image to load its data | ||
image.addEventListener('load', function () { | ||
// Get all option elements if future need | ||
var elements = [].slice.call(document.querySelectorAll('.crop-aspect-ratio-option')); | ||
|
||
}); | ||
}; | ||
// Set default aspect ratio after numeric check, option has a dummy value | ||
var defaultCropFactor = image.naturalWidth / image.naturalHeight; | ||
if (!Number.isNaN(defaultCropFactor) && Number.isFinite(defaultCropFactor)) { | ||
elements[0].value = defaultCropFactor; | ||
} | ||
Joomla.MediaManager.Edit.crop.cropper.setAspectRatio(elements[0].value); | ||
}); | ||
}; | ||
|
||
// Register the Events | ||
Joomla.MediaManager.Edit.crop = { | ||
Activate: function (mediaData) { | ||
// Initialize | ||
initCrop(mediaData); | ||
}, | ||
Deactivate: function () { | ||
if (!Joomla.MediaManager.Edit.crop.cropper) { | ||
return; | ||
} | ||
// Destroy the instance | ||
Joomla.MediaManager.Edit.crop.cropper.destroy(); | ||
} | ||
}; | ||
// Register the Events | ||
Joomla.MediaManager.Edit.crop = { | ||
Activate: function Activate(mediaData) { | ||
// Initialize | ||
initCrop(mediaData); | ||
}, | ||
Deactivate: function Deactivate() { | ||
if (!Joomla.MediaManager.Edit.crop.cropper) { | ||
return; | ||
} | ||
// Destroy the instance | ||
Joomla.MediaManager.Edit.crop.cropper.destroy(); | ||
} | ||
}; | ||
})(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.