modulejs.define('ext/preview-img', ['_', '$', 'core/event', 'core/server', 'core/settings', 'ext/preview'], function (_, $, event, server, allsettings, preview) { var settings = _.extend({ enabled: false, size: null, types: [] }, allsettings['preview-img']); var spinnerThreshold = 200; var spinnerTimeoutId; var currentItems; var currentIdx; var currentItem; function requestSample(href, callback) { if (!settings.size) { callback(href); return; } server.request({ action: 'getThumbHref', type: 'img', href: href, width: settings.size, height: 0 }, function (json) { callback(json && json.code === 0 ? json.absHref : null); }); } function preloadImage(item, callback) { requestSample(item.absHref, function (src) { $('') .one('load', function (ev) { callback(item, ev.target); // for testing // setTimeout(function () { callback(item, ev.target); }, 1000); }) .attr('src', src); }); } function onAdjustSize() { var $content = $('#pv-content'); var $img = $('#pv-img-image'); if ($img.length === 0) { return; } $img.css({ left: ($content.width() - $img.width()) * 0.5, top: ($content.height() - $img.height()) * 0.5 }); var labels = [currentItem.label]; if (!settings.size) { labels.push(String($img[0].naturalWidth) + 'x' + String($img[0].naturalHeight)); labels.push(String((100 * $img.width() / $img[0].naturalWidth).toFixed(0)) + '%'); } preview.setLabels(labels); } function onIdxChange(rel) { currentIdx = (currentIdx + rel + currentItems.length) % currentItems.length; currentItem = currentItems[currentIdx]; preview.setLabels([currentItem.label]); preview.setIndex(currentIdx + 1, currentItems.length); preview.setRawLink(currentItem.absHref); $('#pv-content').hide(); if (preview.isSpinnerVisible()) { preview.showSpinner(true, currentItem.thumbSquare); } else { clearTimeout(spinnerTimeoutId); spinnerTimeoutId = setTimeout(function () { preview.showSpinner(true, currentItem.thumbSquare); }, spinnerThreshold); } preloadImage(currentItem, function (item, preloadedImage) { if (item !== currentItem) { return; } clearTimeout(spinnerTimeoutId); preview.showSpinner(false); $('#pv-content') .empty() .append($(preloadedImage).attr('id', 'pv-img-image')) .show(); onAdjustSize(); }); } function onEnter(items, idx) { currentItems = items; currentIdx = idx; onIdxChange(0); preview.setOnIndexChange(onIdxChange); preview.setOnAdjustSize(onAdjustSize); preview.enter(); } function initItem(item) { if (item.$view && _.indexOf(settings.types, item.type) >= 0) { item.$view.find('a').on('click', function (ev) { ev.preventDefault(); var matchedEntries = _.compact(_.map($('#items .item'), function (item) { item = $(item).data('item'); return _.indexOf(settings.types, item.type) >= 0 ? item : null; })); onEnter(matchedEntries, _.indexOf(matchedEntries, item)); }); } } function onLocationChanged(item) { _.each(item.content, initItem); } function onLocationRefreshed(item, added) { _.each(added, initItem); } function init() { if (!settings.enabled) { return; } event.sub('location.changed', onLocationChanged); event.sub('location.refreshed', onLocationRefreshed); } init(); });