hedera-web/js/htk/full-image.js

90 lines
1.6 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
var Popup = require ('./popup');
var Spinner = require ('./spinner');
module.exports = new Class
({
Extends: Vn.Object
2016-05-02 13:05:49 +00:00
,Properties:
{
2016-05-02 13:05:49 +00:00
/**
* Subdirectory where full images are allocated.
2016-12-20 09:32:17 +00:00
*/
2016-05-02 13:05:49 +00:00
fullDir:
2015-09-22 07:20:47 +00:00
{
2016-05-02 13:05:49 +00:00
type: String
,set: function (x)
{
this._fullDir = x;
}
,get: function ()
{
return this._fullDir;
}
2015-09-22 07:20:47 +00:00
}
2016-05-02 13:05:49 +00:00
}
2015-02-08 15:38:38 +00:00
2016-05-02 13:05:49 +00:00
,show: function (src)
{
2016-09-26 09:28:47 +00:00
var popup = new Popup ({class: 'htk-full-image', modal: true});
2016-05-02 13:05:49 +00:00
var img = document.createElement ('img');
img.className = 'htk-full-image';
img.addEventListener ('click', this._onImageClick.bind (this, popup));
//img.addEventListener ('error', this._onImageError.bind (this, popup));
img.src = src;
if (!img.complete)
{
2016-05-02 13:05:49 +00:00
img.addEventListener ('load', this._onImageLoad.bind (this, popup, img));
2016-09-26 09:28:47 +00:00
var spinner = new Spinner ();
2016-05-02 13:05:49 +00:00
spinner.start ();
popup.child = spinner;
}
2016-05-02 13:05:49 +00:00
else
this._onImageLoad (popup, img);
popup.open ();
}
2016-05-02 13:05:49 +00:00
,_onImageLoad: function (popup, img)
{
var scale = null;
var width = img.width;
var height = img.height;
2017-04-08 11:42:27 +00:00
var innerWidth = window.innerWidth - 50;
var innerHeight = window.innerHeight - 50;
if (width > innerWidth)
{
scale = width / innerWidth;
height = parseInt (height / scale);
width = innerWidth;
}
if (height > innerHeight)
{
scale = height / innerHeight;
width = parseInt (width / scale);
height = innerHeight;
}
2016-05-02 13:05:49 +00:00
if (scale !== null)
{
img.style.width = width +'px';
img.style.height = height +'px';
}
2016-05-02 13:05:49 +00:00
popup.childNode = img;
popup.reset ();
}
2016-05-02 13:05:49 +00:00
,_onImageClick: function (popup)
{
2016-05-02 13:05:49 +00:00
popup.hide ();
2015-02-01 03:21:54 +00:00
}
2016-05-02 13:05:49 +00:00
,_onImageError: function (popup) {}
});