mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-08 04:17:32 -08:00
163 lines
4 KiB
JavaScript
163 lines
4 KiB
JavaScript
/*
|
|
* JavaScript Load Image Demo JS
|
|
* https://github.com/blueimp/JavaScript-Load-Image
|
|
*
|
|
* Copyright 2013, Sebastian Tschan
|
|
* https://blueimp.net
|
|
*
|
|
* Licensed under the MIT license:
|
|
* http://www.opensource.org/licenses/MIT
|
|
*/
|
|
|
|
/* global loadImage, HTMLCanvasElement, $ */
|
|
|
|
$(function () {
|
|
'use strict'
|
|
|
|
var result = $('#result')
|
|
var exifNode = $('#exif')
|
|
var thumbNode = $('#thumbnail')
|
|
var actionsNode = $('#actions')
|
|
var currentFile
|
|
var coordinates
|
|
|
|
function displayExifData (exif) {
|
|
var thumbnail = exif.get('Thumbnail')
|
|
var tags = exif.getAll()
|
|
var table = exifNode.find('table').empty()
|
|
var row = $('<tr></tr>')
|
|
var cell = $('<td></td>')
|
|
var prop
|
|
if (thumbnail) {
|
|
thumbNode.empty()
|
|
loadImage(thumbnail, function (img) {
|
|
thumbNode.append(img).show()
|
|
}, {orientation: exif.get('Orientation')})
|
|
}
|
|
for (prop in tags) {
|
|
if (tags.hasOwnProperty(prop)) {
|
|
table.append(
|
|
row.clone()
|
|
.append(cell.clone().text(prop))
|
|
.append(cell.clone().text(tags[prop]))
|
|
)
|
|
}
|
|
}
|
|
exifNode.show()
|
|
}
|
|
|
|
function updateResults (img, data) {
|
|
var content
|
|
if (!(img.src || img instanceof HTMLCanvasElement)) {
|
|
content = $('<span>Loading image file failed</span>')
|
|
} else {
|
|
content = $('<a target="_blank">').append(img)
|
|
.attr('download', currentFile.name)
|
|
.attr('href', img.src || img.toDataURL())
|
|
}
|
|
result.children().replaceWith(content)
|
|
if (img.getContext) {
|
|
actionsNode.show()
|
|
}
|
|
if (data && data.exif) {
|
|
displayExifData(data.exif)
|
|
}
|
|
}
|
|
|
|
function displayImage (file, options) {
|
|
currentFile = file
|
|
if (!loadImage(
|
|
file,
|
|
updateResults,
|
|
options
|
|
)) {
|
|
result.children().replaceWith(
|
|
$('<span>' +
|
|
'Your browser does not support the URL or FileReader API.' +
|
|
'</span>')
|
|
)
|
|
}
|
|
}
|
|
|
|
function dropChangeHandler (e) {
|
|
e.preventDefault()
|
|
e = e.originalEvent
|
|
var target = e.dataTransfer || e.target
|
|
var file = target && target.files && target.files[0]
|
|
var options = {
|
|
maxWidth: result.width(),
|
|
canvas: true,
|
|
pixelRatio: window.devicePixelRatio,
|
|
downsamplingRatio: 0.5,
|
|
orientation: true
|
|
}
|
|
if (!file) {
|
|
return
|
|
}
|
|
exifNode.hide()
|
|
thumbNode.hide()
|
|
displayImage(file, options)
|
|
}
|
|
|
|
// Hide URL/FileReader API requirement message in capable browsers:
|
|
if (window.createObjectURL || window.URL || window.webkitURL ||
|
|
window.FileReader) {
|
|
result.children().hide()
|
|
}
|
|
|
|
$(document)
|
|
.on('dragover', function (e) {
|
|
e.preventDefault()
|
|
e = e.originalEvent
|
|
e.dataTransfer.dropEffect = 'copy'
|
|
})
|
|
.on('drop', dropChangeHandler)
|
|
|
|
$('#file-input')
|
|
.on('change', dropChangeHandler)
|
|
|
|
$('#edit')
|
|
.on('click', function (event) {
|
|
event.preventDefault()
|
|
var imgNode = result.find('img, canvas')
|
|
var img = imgNode[0]
|
|
var pixelRatio = window.devicePixelRatio || 1
|
|
imgNode.Jcrop({
|
|
setSelect: [
|
|
40,
|
|
40,
|
|
(img.width / pixelRatio) - 40,
|
|
(img.height / pixelRatio) - 40
|
|
],
|
|
onSelect: function (coords) {
|
|
coordinates = coords
|
|
},
|
|
onRelease: function () {
|
|
coordinates = null
|
|
}
|
|
}).parent().on('click', function (event) {
|
|
event.preventDefault()
|
|
})
|
|
})
|
|
|
|
$('#crop')
|
|
.on('click', function (event) {
|
|
event.preventDefault()
|
|
var img = result.find('img, canvas')[0]
|
|
var pixelRatio = window.devicePixelRatio || 1
|
|
if (img && coordinates) {
|
|
updateResults(loadImage.scale(img, {
|
|
left: coordinates.x * pixelRatio,
|
|
top: coordinates.y * pixelRatio,
|
|
sourceWidth: coordinates.w * pixelRatio,
|
|
sourceHeight: coordinates.h * pixelRatio,
|
|
minWidth: result.width(),
|
|
maxWidth: result.width(),
|
|
pixelRatio: pixelRatio,
|
|
downsamplingRatio: 0.5
|
|
}))
|
|
coordinates = null
|
|
}
|
|
})
|
|
})
|