From 09fa3acc4de375222e524455686636be33be584a Mon Sep 17 00:00:00 2001 From: Lars Jung Date: Sun, 17 May 2015 00:16:31 +0200 Subject: [PATCH] Update text preview. --- src/_h5ai/public/js/inc/ext/preview-txt.js | 154 ++++++++++++--------- 1 file changed, 86 insertions(+), 68 deletions(-) diff --git a/src/_h5ai/public/js/inc/ext/preview-txt.js b/src/_h5ai/public/js/inc/ext/preview-txt.js index b59a85dd..d7812f8d 100644 --- a/src/_h5ai/public/js/inc/ext/preview-txt.js +++ b/src/_h5ai/public/js/inc/ext/preview-txt.js @@ -6,90 +6,108 @@ modulejs.define('ext/preview-txt', ['_', '$', 'marked', 'prism', 'core/event', ' }, allsettings['preview-txt']); var templateText = '
';
     var templateMarkdown = '
'; + var spinnerThreshold = 200; + var spinnerTimeoutId; + var currentItems; + var currentIdx; + var currentItem; - function preloadText(absHref, callback) { + function preloadText(item, callback) { $.ajax({ - url: absHref, + url: item.absHref, dataType: 'text' }) .done(function (content) { - callback(content); - // setTimeout(function () { callback(content); }, 1000); // for testing + // callback(item, content); + + // for testing + setTimeout(function () { callback(item, content); }, 1000); }) .fail(function (jqXHR, textStatus) { - callback('[ajax error] ' + textStatus); + callback(item, '[ajax error] ' + textStatus); }); } + function onAdjustSize() { + + var $content = $('#pv-content'); + var $text = $('#pv-txt-text'); + + if ($text.length) { + $text.height($content.height() - 16); + } + } + + function onIdxChange(rel) { + + currentIdx = (currentIdx + rel + currentItems.length) % currentItems.length; + currentItem = currentItems[currentIdx]; + + preview.setLabels([ + currentItem.label, + String(currentItem.size) + ' bytes' + ]); + preview.setIndex(currentIdx + 1, currentItems.length); + preview.setRawLink(currentItem.absHref); + + $('#pv-content').hide(); + if (preview.isSpinnerVisible()) { + preview.showSpinner(true, currentItem.icon); + } else { + clearTimeout(spinnerTimeoutId); + spinnerTimeoutId = setTimeout(function () { + + preview.showSpinner(true, currentItem.icon); + }, spinnerThreshold); + } + + preloadText(currentItem, function (item, textContent) { + + if (item !== currentItem) { + return; + } + + var type = settings.types[currentItem.type]; + var $text; + var $code; + + if (type === 'none') { + $text = $(templateMarkdown).text(textContent); + } else if (type === 'fixed') { + $text = $(templateText).text(textContent); + } else if (type === 'markdown') { + $text = $(templateMarkdown).html(marked(textContent)); + } else { + $text = $(templateText); + $code = $('').appendTo($text); + + if (textContent.length < 20000) { + $code.empty().html(prism.highlight(textContent, prism.languages[type])); + } else { + $code.empty().text(textContent); + setTimeout(function () { $code.empty().html(prism.highlight(textContent, prism.languages[type])); }, 300); + } + } + + clearTimeout(spinnerTimeoutId); + preview.showSpinner(false); + $('#pv-content') + .empty() + .append($text) + .show(); + onAdjustSize(); + }); + } + function onEnter(items, idx) { - var currentItems = items; - var currentIdx = idx; - var currentItem = items[idx]; - - function onAdjustSize() { - - var $content = $('#pv-content'); - var $text = $('#pv-txt-text'); - - if ($text.length) { - - $text.height($content.height() - 16); - } - } - - function onIdxChange(rel) { - - currentIdx = (currentIdx + rel + currentItems.length) % currentItems.length; - currentItem = currentItems[currentIdx]; - - var spinnerTimeout = setTimeout(function () { preview.showSpinner(true); }, 200); - - preloadText(currentItem.absHref, function (textContent) { - - clearTimeout(spinnerTimeout); - preview.showSpinner(false); - - $('#pv-content').fadeOut(100, function () { - - var type = settings.types[currentItem.type]; - var $text; - var $code; - - if (type === 'none') { - $text = $(templateMarkdown).text(textContent); - } else if (type === 'fixed') { - $text = $(templateText).text(textContent); - } else if (type === 'markdown') { - $text = $(templateMarkdown).html(marked(textContent)); - } else { - $text = $(templateText); - $code = $('').appendTo($text); - - if (textContent.length < 20000) { - $code.empty().html(prism.highlight(textContent, prism.languages[type])); - } else { - $code.empty().text(textContent); - setTimeout(function () { $code.empty().html(prism.highlight(textContent, prism.languages[type])); }, 300); - } - } - $('#pv-content').empty().append($text).fadeIn(200); - onAdjustSize(); - - preview.setIndex(currentIdx + 1, currentItems.length); - preview.setLabels([ - currentItem.label, - String(currentItem.size) + ' bytes' - ]); - preview.setRawLink(currentItem.absHref); - }); - }); - } - + currentItems = items; + currentIdx = idx; + currentItem = items[idx]; onIdxChange(0); preview.setOnIndexChange(onIdxChange); preview.setOnAdjustSize(onAdjustSize);