##// END OF EJS Templates
Removed cast to int for the bumplimit progress bar, cause CSS understands float values
Removed cast to int for the bumplimit progress bar, cause CSS understands float values

File last commit:

r266:451b799c default
r284:19ad65b5 default
Show More
image.js
70 lines | 2.4 KiB | application/javascript | JavascriptLexer
function addImgPreview() {
var margin = 20; //..change
//keybind
$(document).on('keyup.removepic', function(e) {
if(e.which === 27) {
$('.img-full').remove();
}
});
$('body').on('click', '.thumb', function() {
var el = $(this);
var thumb_id = 'full' + el.find('img').attr('alt');
if(!$('#'+thumb_id).length) {
var img_w = el.find('img').attr('data-width');
var img_h = el.find('img').attr('data-height');
var win_w = $(window).width();
var win_h = $(window).height();
//new image size
if (img_w > win_w) {
img_h = img_h * (win_w/img_w) - margin;
img_w = win_w - margin;
}
if (img_h > win_h) {
img_w = img_w * (win_h/img_h) - margin;
img_h = win_h - margin;
}
var img_pv = new Image();
$(img_pv)
.addClass('img-full')
.attr('id', thumb_id)
.attr('src', $(el).attr('href'))
.appendTo($(el))
.css({
'width': img_w,
'height': img_h,
'left': (win_w - img_w) / 2,
'top': ((win_h - img_h) / 2)
})
//scaling preview
.mousewheel(function(event, delta) {
var cx = event.originalEvent.clientX,
cy = event.originalEvent.clientY,
i_w = parseFloat($(img_pv).width()),
i_h = parseFloat($(img_pv).height()),
newIW = i_w * (delta > 0 ? 1.25 : 0.8),
newIH = i_h * (delta > 0 ? 1.25 : 0.8);
$(img_pv).width(newIW);
$(img_pv).height(newIH);
//set position
$(img_pv)
.css({
left: parseInt(cx - (newIW/i_w) * (cx - parseInt($(img_pv).position().left, 10)), 10),
top: parseInt(cy - (newIH/i_h) * (cy - parseInt($(img_pv).position().top, 10)), 10)
});
return false;
}
).draggable()
}
else {
$('#'+thumb_id).remove();
}
//prevent default
return false;
});
}