crop_news.js
3.39 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
Copyright 2016, 2017 UFPE - Universidade Federal de Pernambuco
Este arquivo é parte do programa Amadeus Sistema de Gestão de Aprendizagem, ou simplesmente Amadeus LMS
O Amadeus LMS é um software livre; você pode redistribui-lo e/ou modifica-lo dentro dos termos da Licença Pública Geral GNU como publicada pela Fundação do Software Livre (FSF); na versão 2 da Licença.
Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU para maiores detalhes.
Você deve ter recebido uma cópia da Licença Pública Geral GNU, sob o título "LICENSE", junto com este programa, se não, escreva para a Fundação do Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*/
$(function () {
/* Script para abrir o modal com a imagem selecionada */
$("#id_image").change(function () {
var max_size = 5*1024*1024;
var submit_btn = $("#news-form").find("input[type='submit']");
var mimeTypes = $(this).data('mimetypes');
var errors = 0;
$(".client-file-errors").hide();
$(".size").hide();
$(".format").hide();
$(submit_btn).prop('disable', false);
$(submit_btn).prop('disabled', false);
if (this.files && this.files[0]) {
if (this.files[0].size > max_size) {
$(submit_btn).prop('disable', true);
$(submit_btn).prop('disabled', true);
$(".client-file-errors").show();
$(".size").show();
errors++;
}
if (!mimeTypes.includes(this.files[0].type)) {
$(submit_btn).prop('disable', true);
$(submit_btn).prop('disabled', true);
$(".client-file-errors").show();
$(".format").show();
errors++;
}
if (errors == 0) {
var reader = new FileReader();
reader.onload = function (e) {
$("#image").attr("src", e.target.result);
$("#modalCrop").modal("show");
}
reader.readAsDataURL(this.files[0]);
}
}
});
/* Scripts da caixa de corte da imagem */
var $image = $("#image");
var cropBoxData;
var canvasData;
$("#modalCrop").on("shown.bs.modal", function () {
$image.cropper({
viewMode: 1 ,
aspectRatio: 3/1,
minCropBoxWidth: 200,
minCropBoxHeight: 200,
dragMode: 'move',
ready: function () {
$image.cropper("setCanvasData", canvasData);
$image.cropper("setCropBoxData", cropBoxData);
}
});
}).on("hidden.bs.modal", function () {
cropBoxData = $image.cropper("getCropBoxData");
canvasData = $image.cropper("getCanvasData");
$image.cropper("destroy");
});
$(".js-zoom-in").click(function () {
$image.cropper("zoom", 0.1);
});
$(".js-zoom-out").click(function () {
$image.cropper("zoom", -0.1);
});
/* Script para pegar os valores das dimensões e depois fechar o modal */
$(".js-crop-and-upload").click(function () {
var cropData = $image.cropper("getData");
$("#id_x").val(cropData["x"]);
$("#id_y").val(cropData["y"]);
$("#id_height").val(cropData["height"]);
$("#id_width").val(cropData["width"]);
$("#modalCrop").modal('hide');
});
/* Script para remover o arquivo enviado caso o usuário clique em cancelar*/
$("#id_image").on('change', function(){
console.log(this.value);
});
$('#crop_cancel').on('click', function(e){
var input = $("#id_image");
var holder = $("#pic_holder");
input.replaceWith(input.val('').clone(true));
holder.replaceWith(holder.val('').clone(true));
});
});