|
1 | 1 |
|
2 | | -// Methods |
3 | | -/* |
4 | | - case 'getCroppedCanvas': |
5 | | - try { |
6 | | - data.option = JSON.parse(data.option); |
7 | | - } catch (e) { |
8 | | - console.log(e.message); |
9 | | - } |
10 | | -
|
11 | | - if (image.data('uploadedImageType') === 'image/jpeg') { |
12 | | - if (!data.option) { |
13 | | - data.option = {}; |
14 | | - } |
15 | | -
|
16 | | - data.option.fillColor = '#fff'; |
17 | | - } |
18 | | -
|
19 | | - break; |
20 | | - } |
21 | | -
|
22 | | - result = cropper[data.method](data.option, data.secondOption); |
23 | | -
|
24 | | - switch (data.method) { |
25 | | - case 'getCroppedCanvas': |
26 | | - if (result) { |
27 | | - // Bootstrap's Modal |
28 | | - $('#getCroppedCanvasModal').modal().find('.modal-body').html(result); |
29 | | -
|
30 | | - if (!download.disabled) { |
31 | | - download.download = image.data('uploadedImageName'); |
32 | | - download.href = result.toDataURL(image.data('uploadedImageType')); |
33 | | - } |
34 | | - } |
35 | | -
|
36 | | - break; |
37 | | -
|
38 | | - case 'destroy': |
39 | | - cropper = null; |
40 | | -
|
41 | | - if (image.data('uploadedImageURL')) { |
42 | | - URL.revokeObjectURL(image.data('uploadedImageURL')); |
43 | | - image.data('uploadedImageURL', ''); |
44 | | - image.attr('src') = image.data('originalImageURL'); |
45 | | - } |
46 | | -
|
47 | | - break; |
48 | | - } |
49 | | -
|
50 | | - if (typeof result === 'object' && result !== cropper && input) { |
51 | | - try { |
52 | | - input.value = JSON.stringify(result); |
53 | | - } catch (e) { |
54 | | - console.log(e.message); |
55 | | - } |
56 | | - } |
57 | | - } |
58 | | - }); |
59 | | -
|
60 | | -jQuery('.cropper .docs-toggles').on('change', function() { |
61 | | - var e = event || window.event; |
62 | | - var target = e.target || e.srcElement; |
63 | | - var cropBoxData; |
64 | | - var canvasData; |
65 | | - var isCheckbox; |
66 | | - var isRadio; |
67 | | -
|
68 | | - if (target.tagName.toLowerCase() === 'label') { |
69 | | - target = target.querySelector('input'); |
70 | | - } |
71 | | -
|
72 | | - isCheckbox = target.type === 'checkbox'; |
73 | | - isRadio = target.type === 'radio'; |
74 | | -
|
75 | | - if (isCheckbox || isRadio) { |
76 | | - if (isCheckbox) { |
77 | | - options[target.name] = target.checked; |
78 | | - cropBoxData = cropper.getCropBoxData(); |
79 | | - canvasData = cropper.getCanvasData(); |
80 | | -
|
81 | | - options.ready = function () { |
82 | | - console.log('ready'); |
83 | | - cropper.setCropBoxData(cropBoxData).setCanvasData(canvasData); |
84 | | - }; |
85 | | - } else { |
86 | | - options[target.name] = target.value; |
87 | | - options.ready = function () { |
88 | | - console.log('ready'); |
89 | | - }; |
90 | | - } |
91 | | -
|
92 | | - // Restart |
93 | | - cropper.destroy(); |
94 | | - cropper = new Cropper(image, options); |
95 | | - } |
96 | | - } |
97 | | -); |
98 | | -*/ |
99 | | - |
100 | 2 | jQuery('.cropper input[type="file"]').on('change', function() { |
101 | 3 | var files = this.files; |
102 | 4 | var file; |
@@ -245,7 +147,8 @@ class CropperUI { |
245 | 147 | var elem = jQuery(domElement); |
246 | 148 | options.destroyed = false; |
247 | 149 | if (!cropperOptions) cropperOptions = {}; |
248 | | - cropperOptions.aspectRatio= 1; |
| 150 | + var mainElem = elem.closest('.cropper'); |
| 151 | + cropperOptions.aspectRatio = mainElem.data('aspect-ratio'); |
249 | 152 | options.cropper = new Cropper(domElement, cropperOptions); |
250 | 153 | elem.data('upload', options); |
251 | 154 | this.registerEvents(domElement); |
|
0 commit comments