From a072962a53f67e7ce393ffb365b99a5b83ac1969 Mon Sep 17 00:00:00 2001 From: Lars Jung Date: Tue, 16 Jul 2013 13:23:52 +0200 Subject: [PATCH] Updates previews. Removes spin.js. --- src/_h5ai/client/css/inc/preview-txt.less | 4 + src/_h5ai/client/js/inc/ext/preview-img.js | 4 +- src/_h5ai/client/js/inc/ext/preview-txt.js | 33 +- src/_h5ai/client/js/lib/jquery.spin-1.2.6.js | 21 -- src/_h5ai/client/js/lib/spin-1.2.7.js | 320 ------------------- 5 files changed, 26 insertions(+), 356 deletions(-) delete mode 100644 src/_h5ai/client/js/lib/jquery.spin-1.2.6.js delete mode 100644 src/_h5ai/client/js/lib/spin-1.2.7.js diff --git a/src/_h5ai/client/css/inc/preview-txt.less b/src/_h5ai/client/css/inc/preview-txt.less index 69abfc50..bbbb893a 100644 --- a/src/_h5ai/client/css/inc/preview-txt.less +++ b/src/_h5ai/client/css/inc/preview-txt.less @@ -25,6 +25,10 @@ position: relative; } +#pv-txt-spinner { + position: fixed; +} + #pv-txt-text { &.highlighted { diff --git a/src/_h5ai/client/js/inc/ext/preview-img.js b/src/_h5ai/client/js/inc/ext/preview-img.js index 2c89d02f..bce04108 100644 --- a/src/_h5ai/client/js/inc/ext/preview-img.js +++ b/src/_h5ai/client/js/inc/ext/preview-img.js @@ -100,8 +100,8 @@ modulejs.define('ext/preview-img', ['_', '$', 'core/settings', 'core/resource', var $img = $('') .one('load', function () { - callback($img); - // setTimeout(function () { callback($img); }, 1000); // for testing + // callback($img); + setTimeout(function () { callback($img); }, 1000); // for testing }) .attr('src', src); }, diff --git a/src/_h5ai/client/js/inc/ext/preview-txt.js b/src/_h5ai/client/js/inc/ext/preview-txt.js index 1ac2a43b..7f9ca4d2 100644 --- a/src/_h5ai/client/js/inc/ext/preview-txt.js +++ b/src/_h5ai/client/js/inc/ext/preview-txt.js @@ -33,6 +33,9 @@ modulejs.define('ext/preview-txt', ['_', '$', 'core/settings', 'core/resource', '
' + '
' + '
' + + '
' + + '' + + '
' + '
' + '
    ' + '
  • ' + @@ -117,6 +120,8 @@ modulejs.define('ext/preview-txt', ['_', '$', 'core/settings', 'core/resource', var $window = $(window), $container = $('#pv-txt-content'), + $spinner = $('#pv-txt-spinner'), + $spinnerimg = $spinner.find('img').width(100).height(100), margin = 20, barheight = 31; @@ -124,6 +129,17 @@ modulejs.define('ext/preview-txt', ['_', '$', 'core/settings', 'core/resource', height: $window.height() - 2 * margin - barheight - 32, top: margin }); + + $spinner.css({ + width: $window.width() - 2 * margin, + height: $window.height() - 2 * margin - barheight, + left: margin, + top: margin + }); + + $spinnerimg.css({ + margin: '' + (($spinner.height() - $spinnerimg.height()) / 2) + 'px ' + (($spinner.width() - $spinnerimg.height()) / 2) + 'px' + }); }, preloadText = function (absHref, callback) { @@ -133,8 +149,8 @@ modulejs.define('ext/preview-txt', ['_', '$', 'core/settings', 'core/resource', dataType: 'text', success: function (content) { - callback(content); - // setTimeout(function () { callback(content); }, 1000); // for testing + // callback(content); + setTimeout(function () { callback(content); }, 1000); // for testing }, error: function (jqXHR, textStatus, errorThrown) { @@ -150,21 +166,12 @@ modulejs.define('ext/preview-txt', ['_', '$', 'core/settings', 'core/resource', var $container = $('#pv-txt-content'), $text = $('#pv-txt-text'), current = currentEntries[currentIdx], - spinnerTimeout = setTimeout(function () { - - $container.spin({ - length: 12, - width: 4, - radius: 24, - color: '#ccc', - shadow: true - }); - }, 200); + spinnerTimeout = setTimeout(function () { $('#pv-txt-spinner').show(); }, 200); preloadText(current.absHref, function (content) { clearTimeout(spinnerTimeout); - $container.spin(false); + $('#pv-txt-spinner').hide(); $text.fadeOut(100, function () { diff --git a/src/_h5ai/client/js/lib/jquery.spin-1.2.6.js b/src/_h5ai/client/js/lib/jquery.spin-1.2.6.js deleted file mode 100644 index faa9a8dd..00000000 --- a/src/_h5ai/client/js/lib/jquery.spin-1.2.6.js +++ /dev/null @@ -1,21 +0,0 @@ - -(function ($) { - - $.fn.spin = function (options) { - - return this.each(function () { - - var $this = $(this), - data = $this.data(); - - if (data.spinner) { - data.spinner.stop(); - delete data.spinner; - } - - if (options !== false) { - data.spinner = new Spinner($.extend({color: $this.css('color')}, options)).spin(this); - } - }); - }; -}(jQuery)); diff --git a/src/_h5ai/client/js/lib/spin-1.2.7.js b/src/_h5ai/client/js/lib/spin-1.2.7.js deleted file mode 100644 index 434d76a6..00000000 --- a/src/_h5ai/client/js/lib/spin-1.2.7.js +++ /dev/null @@ -1,320 +0,0 @@ -//fgnass.github.com/spin.js#v1.2.7 -!function(window, document, undefined) { - - /** - * Copyright (c) 2011 Felix Gnass [fgnass at neteye dot de] - * Licensed under the MIT license - */ - - var prefixes = ['webkit', 'Moz', 'ms', 'O'] /* Vendor prefixes */ - , animations = {} /* Animation rules keyed by their name */ - , useCssAnimations - - /** - * Utility function to create elements. If no tag name is given, - * a DIV is created. Optionally properties can be passed. - */ - function createEl(tag, prop) { - var el = document.createElement(tag || 'div') - , n - - for(n in prop) el[n] = prop[n] - return el - } - - /** - * Appends children and returns the parent. - */ - function ins(parent /* child1, child2, ...*/) { - for (var i=1, n=arguments.length; i> 1) : parseInt(o.left, 10) + mid) + 'px', - top: (o.top == 'auto' ? tp.y-ep.y + (target.offsetHeight >> 1) : parseInt(o.top, 10) + mid) + 'px' - }) - } - - el.setAttribute('aria-role', 'progressbar') - self.lines(el, self.opts) - - if (!useCssAnimations) { - // No CSS animation support, use setTimeout() instead - var i = 0 - , fps = o.fps - , f = fps/o.speed - , ostep = (1-o.opacity) / (f*o.trail / 100) - , astep = f/o.lines - - ;(function anim() { - i++; - for (var s=o.lines; s; s--) { - var alpha = Math.max(1-(i+s*astep)%f * ostep, o.opacity) - self.opacity(el, o.lines-s, alpha, o) - } - self.timeout = self.el && setTimeout(anim, ~~(1000/fps)) - })() - } - return self - }, - - stop: function() { - var el = this.el - if (el) { - clearTimeout(this.timeout) - if (el.parentNode) el.parentNode.removeChild(el) - this.el = undefined - } - return this - }, - - lines: function(el, o) { - var i = 0 - , seg - - function fill(color, shadow) { - return css(createEl(), { - position: 'absolute', - width: (o.length+o.width) + 'px', - height: o.width + 'px', - background: color, - boxShadow: shadow, - transformOrigin: 'left', - transform: 'rotate(' + ~~(360/o.lines*i+o.rotate) + 'deg) translate(' + o.radius+'px' +',0)', - borderRadius: (o.corners * o.width>>1) + 'px' - }) - } - - for (; i < o.lines; i++) { - seg = css(createEl(), { - position: 'absolute', - top: 1+~(o.width/2) + 'px', - transform: o.hwaccel ? 'translate3d(0,0,0)' : '', - opacity: o.opacity, - animation: useCssAnimations && addAnimation(o.opacity, o.trail, i, o.lines) + ' ' + 1/o.speed + 's linear infinite' - }) - - if (o.shadow) ins(seg, css(fill('#000', '0 0 4px ' + '#000'), {top: 2+'px'})) - - ins(el, ins(seg, fill(o.color, '0 0 1px rgba(0,0,0,.1)'))) - } - return el - }, - - opacity: function(el, i, val) { - if (i < el.childNodes.length) el.childNodes[i].style.opacity = val - } - - }) - - ///////////////////////////////////////////////////////////////////////// - // VML rendering for IE - ///////////////////////////////////////////////////////////////////////// - - /** - * Check and init VML support - */ - ;(function() { - - function vml(tag, attr) { - return createEl('<' + tag + ' xmlns="urn:schemas-microsoft.com:vml" class="spin-vml">', attr) - } - - var s = css(createEl('group'), {behavior: 'url(#default#VML)'}) - - if (!vendor(s, 'transform') && s.adj) { - - // VML support detected. Insert CSS rule ... - sheet.addRule('.spin-vml', 'behavior:url(#default#VML)') - - Spinner.prototype.lines = function(el, o) { - var r = o.length+o.width - , s = 2*r - - function grp() { - return css( - vml('group', { - coordsize: s + ' ' + s, - coordorigin: -r + ' ' + -r - }), - { width: s, height: s } - ) - } - - var margin = -(o.width+o.length)*2 + 'px' - , g = css(grp(), {position: 'absolute', top: margin, left: margin}) - , i - - function seg(i, dx, filter) { - ins(g, - ins(css(grp(), {rotation: 360 / o.lines * i + 'deg', left: ~~dx}), - ins(css(vml('roundrect', {arcsize: o.corners}), { - width: r, - height: o.width, - left: o.radius, - top: -o.width>>1, - filter: filter - }), - vml('fill', {color: o.color, opacity: o.opacity}), - vml('stroke', {opacity: 0}) // transparent stroke to fix color bleeding upon opacity change - ) - ) - ) - } - - if (o.shadow) - for (i = 1; i <= o.lines; i++) - seg(i, -2, 'progid:DXImageTransform.Microsoft.Blur(pixelradius=2,makeshadow=1,shadowopacity=.3)') - - for (i = 1; i <= o.lines; i++) seg(i) - return ins(el, g) - } - - Spinner.prototype.opacity = function(el, i, val, o) { - var c = el.firstChild - o = o.shadow && o.lines || 0 - if (c && i+o < c.childNodes.length) { - c = c.childNodes[i+o]; c = c && c.firstChild; c = c && c.firstChild - if (c) c.opacity = val - } - } - } - else - useCssAnimations = vendor(s, 'animation') - })() - - if (typeof define == 'function' && define.amd) - define(function() { return Spinner }) - else - window.Spinner = Spinner - -}(window, document);