Skip to content

Instantly share code, notes, and snippets.

@unixcult
Forked from juliangruber/head.html
Created July 27, 2013 19:58
Show Gist options
  • Select an option

  • Save unixcult/6096073 to your computer and use it in GitHub Desktop.

Select an option

Save unixcult/6096073 to your computer and use it in GitHub Desktop.

Revisions

  1. unixcult revised this gist Jul 27, 2013. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion requirebin.md
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    view on [requirebin](http://requirebin.com?gist=5940808)
    view on [requirebin](http://requirebin.com?gist=6096073)
  2. unixcult revised this gist Jul 27, 2013. 4 changed files with 18 additions and 811 deletions.
    19 changes: 14 additions & 5 deletions index.js
    Original file line number Diff line number Diff line change
    @@ -1,7 +1,16 @@
    var Spinning = require('spinning');
    function eat(food, digest){
    var ateTheFood = food + " got eaten";
    digest(ateTheFood);
    }

    var spinner = Spinning().text('loading...').light().size(200);
    //eat('pizza', function(poop){
    // console.log(poop);
    //});

    setTimeout(function () {
    spinner.remove();
    }, 3000);
    //the line below more elegantly does the work of the lines above

    eat('pizza', poop);

    function poop(food) {
    console.log(food);
    }
    807 changes: 1 addition & 806 deletions minified.js
    Original file line number Diff line number Diff line change
    @@ -1,806 +1 @@
    require=(function(e,t,n){function i(n,s){if(!t[n]){if(!e[n]){var o=typeof require=="function"&&require;if(!s&&o)return o(n,!0);if(r)return r(n,!0);throw new Error("Cannot find module '"+n+"'")}var u=t[n]={exports:{}};e[n][0].call(u.exports,function(t){var r=e[n][1][t];return i(r?r:t)},u,u.exports)}return t[n].exports}var r=typeof require=="function"&&require;for(var s=0;s<n.length;s++)i(n[s]);return i})({1:[function(require,module,exports){
    module.exports = '.spinner, .overlay {\n position: fixed;\n opacity: 0;\n}\n\n.spinner {\n left: 50%;\n top: 50%;\n margin-left: -100px;\n margin-top: -100px;\n z-index: 2222222222;\n}\n\n.overlay {\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: white;\n z-index: 1111111111;\n}\n';
    },{}],"spinning":[function(require,module,exports){
    module.exports=require('JGIiXp');
    },{}],"JGIiXp":[function(require,module,exports){
    (function(){var Spinner = require('spinner-browserify');
    var insertCss = require('insert-css');
    var style = require('./style');
    var fade = require('fade');
    var process = require('process'); // be nice to browserify

    module.exports = Spin;

    function Spin () {
    insertCss(style);

    // durations
    var fadeIn = 1000;
    var fadeOut = 300;

    var overlay = document.createElement('div');
    overlay.className = 'overlay';
    document.body.appendChild(overlay);

    var spinner = new Spinner();
    spinner.el.className = 'spinner';
    document.body.appendChild(spinner.el);

    process.nextTick(function () {
    fade(overlay, 0.8, fadeIn);
    fade.in(spinner.el, fadeIn);
    });

    spinner.remove = function () {
    fade.out(overlay, fadeOut);
    fade.out(spinner.el, fadeOut);

    setTimeout(function () {
    spinner.stop();
    document.body.removeChild(overlay);
    document.body.removeChild(spinner.el);
    }, fadeOut);
    };

    // reposition
    var size = spinner.size;
    spinner.size = function (n) {
    spinner.el.style.marginLeft =
    spinner.el.style.marginTop = '-' + (n/2) + 'px';
    return size.call(spinner, n);
    };

    var light = spinner.light;
    spinner.light = function () {
    overlay.style.backgroundColor = 'black';
    return light.call(spinner);
    };

    // set durations
    spinner['in'] = function (ms) { fadeIn = ms };
    spinner.out = function (ms) { fadeOut = ms };

    return spinner;
    }

    })()
    },{"process":2,"./style":1,"insert-css":3,"fade":4,"spinner-browserify":5}],2:[function(require,module,exports){
    (function(){var process = module.exports = {};

    process.nextTick = (function () {
    var canSetImmediate = typeof window !== 'undefined'
    && window.setImmediate;
    var canPost = typeof window !== 'undefined'
    && window.postMessage && window.addEventListener
    ;

    if (canSetImmediate) {
    return function (f) { return window.setImmediate(f) };
    }

    if (canPost) {
    var queue = [];
    window.addEventListener('message', function (ev) {
    if (ev.source === window && ev.data === 'browserify-tick') {
    ev.stopPropagation();
    if (queue.length > 0) {
    var fn = queue.shift();
    fn();
    }
    }
    }, true);

    return function nextTick(fn) {
    queue.push(fn);
    window.postMessage('browserify-tick', '*');
    };
    }

    return function nextTick(fn) {
    setTimeout(fn, 0);
    };
    })();

    process.title = 'browser';
    process.browser = true;
    process.env = {};
    process.argv = [];

    process.binding = function (name) {
    if (name === 'evals') return (require)('vm')
    else throw new Error('No such module. (Possibly not yet loaded)')
    };

    (function () {
    var cwd = '/';
    var path;
    process.cwd = function () { return cwd };
    process.chdir = function (dir) {
    if (!path) path = require('path');
    cwd = path.resolve(dir, cwd);
    };
    })();

    })()
    },{"path":6,"vm":7}],8:[function(require,module,exports){
    // shim for using process in browser

    var process = module.exports = {};

    process.nextTick = (function () {
    var canSetImmediate = typeof window !== 'undefined'
    && window.setImmediate;
    var canPost = typeof window !== 'undefined'
    && window.postMessage && window.addEventListener
    ;

    if (canSetImmediate) {
    return function (f) { return window.setImmediate(f) };
    }

    if (canPost) {
    var queue = [];
    window.addEventListener('message', function (ev) {
    if (ev.source === window && ev.data === 'process-tick') {
    ev.stopPropagation();
    if (queue.length > 0) {
    var fn = queue.shift();
    fn();
    }
    }
    }, true);

    return function nextTick(fn) {
    queue.push(fn);
    window.postMessage('process-tick', '*');
    };
    }

    return function nextTick(fn) {
    setTimeout(fn, 0);
    };
    })();

    process.title = 'browser';
    process.browser = true;
    process.env = {};
    process.argv = [];

    process.binding = function (name) {
    throw new Error('process.binding is not supported');
    }

    // TODO(shtylman)
    process.cwd = function () { return '/' };
    process.chdir = function (dir) {
    throw new Error('process.chdir is not supported');
    };

    },{}],6:[function(require,module,exports){
    (function(process){function filter (xs, fn) {
    var res = [];
    for (var i = 0; i < xs.length; i++) {
    if (fn(xs[i], i, xs)) res.push(xs[i]);
    }
    return res;
    }

    // resolves . and .. elements in a path array with directory names there
    // must be no slashes, empty elements, or device names (c:\) in the array
    // (so also no leading and trailing slashes - it does not distinguish
    // relative and absolute paths)
    function normalizeArray(parts, allowAboveRoot) {
    // if the path tries to go above the root, `up` ends up > 0
    var up = 0;
    for (var i = parts.length; i >= 0; i--) {
    var last = parts[i];
    if (last == '.') {
    parts.splice(i, 1);
    } else if (last === '..') {
    parts.splice(i, 1);
    up++;
    } else if (up) {
    parts.splice(i, 1);
    up--;
    }
    }

    // if the path is allowed to go above the root, restore leading ..s
    if (allowAboveRoot) {
    for (; up--; up) {
    parts.unshift('..');
    }
    }

    return parts;
    }

    // Regex to split a filename into [*, dir, basename, ext]
    // posix version
    var splitPathRe = /^(.+\/(?!$)|\/)?((?:.+?)?(\.[^.]*)?)$/;

    // path.resolve([from ...], to)
    // posix version
    exports.resolve = function() {
    var resolvedPath = '',
    resolvedAbsolute = false;

    for (var i = arguments.length; i >= -1 && !resolvedAbsolute; i--) {
    var path = (i >= 0)
    ? arguments[i]
    : process.cwd();

    // Skip empty and invalid entries
    if (typeof path !== 'string' || !path) {
    continue;
    }

    resolvedPath = path + '/' + resolvedPath;
    resolvedAbsolute = path.charAt(0) === '/';
    }

    // At this point the path should be resolved to a full absolute path, but
    // handle relative paths to be safe (might happen when process.cwd() fails)

    // Normalize the path
    resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {
    return !!p;
    }), !resolvedAbsolute).join('/');

    return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';
    };

    // path.normalize(path)
    // posix version
    exports.normalize = function(path) {
    var isAbsolute = path.charAt(0) === '/',
    trailingSlash = path.slice(-1) === '/';

    // Normalize the path
    path = normalizeArray(filter(path.split('/'), function(p) {
    return !!p;
    }), !isAbsolute).join('/');

    if (!path && !isAbsolute) {
    path = '.';
    }
    if (path && trailingSlash) {
    path += '/';
    }

    return (isAbsolute ? '/' : '') + path;
    };


    // posix version
    exports.join = function() {
    var paths = Array.prototype.slice.call(arguments, 0);
    return exports.normalize(filter(paths, function(p, index) {
    return p && typeof p === 'string';
    }).join('/'));
    };


    exports.dirname = function(path) {
    var dir = splitPathRe.exec(path)[1] || '';
    var isWindows = false;
    if (!dir) {
    // No dirname
    return '.';
    } else if (dir.length === 1 ||
    (isWindows && dir.length <= 3 && dir.charAt(1) === ':')) {
    // It is just a slash or a drive letter with a slash
    return dir;
    } else {
    // It is a full dirname, strip trailing slash
    return dir.substring(0, dir.length - 1);
    }
    };


    exports.basename = function(path, ext) {
    var f = splitPathRe.exec(path)[2] || '';
    // TODO: make this comparison case-insensitive on windows?
    if (ext && f.substr(-1 * ext.length) === ext) {
    f = f.substr(0, f.length - ext.length);
    }
    return f;
    };


    exports.extname = function(path) {
    return splitPathRe.exec(path)[3] || '';
    };

    exports.relative = function(from, to) {
    from = exports.resolve(from).substr(1);
    to = exports.resolve(to).substr(1);

    function trim(arr) {
    var start = 0;
    for (; start < arr.length; start++) {
    if (arr[start] !== '') break;
    }

    var end = arr.length - 1;
    for (; end >= 0; end--) {
    if (arr[end] !== '') break;
    }

    if (start > end) return [];
    return arr.slice(start, end - start + 1);
    }

    var fromParts = trim(from.split('/'));
    var toParts = trim(to.split('/'));

    var length = Math.min(fromParts.length, toParts.length);
    var samePartsLength = length;
    for (var i = 0; i < length; i++) {
    if (fromParts[i] !== toParts[i]) {
    samePartsLength = i;
    break;
    }
    }

    var outputParts = [];
    for (var i = samePartsLength; i < fromParts.length; i++) {
    outputParts.push('..');
    }

    outputParts = outputParts.concat(toParts.slice(samePartsLength));

    return outputParts.join('/');
    };

    })(require("__browserify_process"))
    },{"__browserify_process":8}],3:[function(require,module,exports){
    var inserted = [];

    module.exports = function (css) {
    if (inserted.indexOf(css) >= 0) return;
    inserted.push(css);

    var elem = document.createElement('style');
    var text = document.createTextNode(css);
    elem.appendChild(text);

    if (document.head.childNodes.length) {
    document.head.insertBefore(elem, document.head.childNodes[0]);
    }
    else {
    document.head.appendChild(elem);
    }
    };

    },{}],7:[function(require,module,exports){
    var Object_keys = function (obj) {
    if (Object.keys) return Object.keys(obj)
    else {
    var res = [];
    for (var key in obj) res.push(key)
    return res;
    }
    };

    var forEach = function (xs, fn) {
    if (xs.forEach) return xs.forEach(fn)
    else for (var i = 0; i < xs.length; i++) {
    fn(xs[i], i, xs);
    }
    };

    var Script = exports.Script = function NodeScript (code) {
    if (!(this instanceof Script)) return new Script(code);
    this.code = code;
    };

    Script.prototype.runInNewContext = function (context) {
    if (!context) context = {};

    var iframe = document.createElement('iframe');
    if (!iframe.style) iframe.style = {};
    iframe.style.display = 'none';

    document.body.appendChild(iframe);

    var win = iframe.contentWindow;

    forEach(Object_keys(context), function (key) {
    win[key] = context[key];
    });

    if (!win.eval && win.execScript) {
    // win.eval() magically appears when this is called in IE:
    win.execScript('null');
    }

    var res = win.eval(this.code);

    forEach(Object_keys(win), function (key) {
    context[key] = win[key];
    });

    document.body.removeChild(iframe);

    return res;
    };

    Script.prototype.runInThisContext = function () {
    return eval(this.code); // maybe...
    };

    Script.prototype.runInContext = function (context) {
    // seems to be just runInNewContext on magical context objects which are
    // otherwise indistinguishable from objects except plain old objects
    // for the parameter segfaults node
    return this.runInNewContext(context);
    };

    forEach(Object_keys(Script.prototype), function (name) {
    exports[name] = Script[name] = function (code) {
    var s = Script(code);
    return s[name].apply(s, [].slice.call(arguments, 1));
    };
    });

    exports.createScript = function (code) {
    return exports.Script(code);
    };

    exports.createContext = Script.createContext = function (context) {
    // not really sure what this one does
    // seems to just make a shallow copy
    var copy = {};
    if(typeof context === 'object') {
    forEach(Object_keys(context), function (key) {
    copy[key] = context[key];
    });
    }
    return copy;
    };

    },{}],4:[function(require,module,exports){
    /**
    * Module dependencies.
    */

    var prefixed = require('prefixed');

    /**
    * Expose `fade`.
    */

    module.exports = fade;

    /**
    * Fade `el` to `opacity` in `duration` seconds.
    *
    * @param {Element} el
    * @param {Number} opacity
    * @param {Number=} duration
    *
    * @todo Add other vendor prefixes
    * @todo Properly clear transition
    */

    function fade (el, opacity, duration) {
    if (typeof duration === 'undefined') duration = 1000;

    var oldTransition = prefixed.get(el.style, 'transition') || '';
    prefixed(el.style, 'transition', 'opacity ' + (duration/1000) + 's');
    el.style.opacity = opacity;

    setTimeout(function () {
    prefixed(el.style, 'transition', oldTransition);
    }, duration);
    }

    /**
    * Fade in `el`.
    *
    * @param {Element} el
    * @param {Number=} duration
    */

    fade.out = function (el, duration) {
    fade(el, 0, duration);
    };

    /**
    * Fade out `el`.
    *
    * @param {Element} el
    * @param {Number=} duration
    */

    fade['in'] = function (el, duration) {
    fade(el, 1, duration);
    };

    },{"prefixed":9}],5:[function(require,module,exports){
    /**
    * Module dependencies.
    */

    var autoscale = require('autoscale-canvas');
    var raf = require('raf-component');

    /**
    * Expose `Spinner`.
    */

    module.exports = Spinner;

    /**
    * Initialize a new `Spinner`.
    */

    function Spinner() {
    var self = this;
    this.percent = 0;
    this.el = document.createElement('canvas');
    this.ctx = this.el.getContext('2d');
    this.size(50);
    this.fontSize(11);
    this.speed(60);
    this.font('helvetica, arial, sans-serif');
    this.stopped = false;

    (function animate() {
    if (self.stopped) return;
    raf(animate);
    self.percent = (self.percent + self._speed / 36) % 100;
    self.draw(self.ctx);
    })();
    }

    /**
    * Stop the animation.
    *
    * @api public
    */

    Spinner.prototype.stop = function(){
    this.stopped = true;
    };

    /**
    * Set spinner size to `n`.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.size = function(n){
    this.el.width = n;
    this.el.height = n;
    autoscale(this.el);
    return this;
    };

    /**
    * Set text to `str`.
    *
    * @param {String} str
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.text = function(str){
    this._text = str;
    return this;
    };

    /**
    * Set font size to `n`.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.fontSize = function(n){
    this._fontSize = n;
    return this;
    };

    /**
    * Set font `family`.
    *
    * @param {String} family
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.font = function(family){
    this._font = family;
    return this;
    };

    /**
    * Set speed to `n` rpm.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.speed = function(n) {
    this._speed = n;
    return this;
    };

    /**
    * Make the spinner light colored.
    *
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.light = function(){
    this._light = true;
    return this;
    };

    /**
    * Draw on `ctx`.
    *
    * @param {CanvasRenderingContext2d} ctx
    * @return {Spinner}
    * @api private
    */

    Spinner.prototype.draw = function(ctx){
    var percent = Math.min(this.percent, 100)
    , ratio = window.devicePixelRatio || 1
    , size = this.el.width / ratio
    , half = size / 2
    , x = half
    , y = half
    , rad = half - 1
    , fontSize = this._fontSize
    , light = this._light;

    ctx.font = fontSize + 'px ' + this._font;

    var angle = Math.PI * 2 * (percent / 100);
    ctx.clearRect(0, 0, size, size);

    // outer circle
    var grad = ctx.createLinearGradient(
    half + Math.sin(Math.PI * 1.5 - angle) * half,
    half + Math.cos(Math.PI * 1.5 - angle) * half,
    half + Math.sin(Math.PI * 0.5 - angle) * half,
    half + Math.cos(Math.PI * 0.5 - angle) * half
    );

    // color
    if (light) {
    grad.addColorStop(0, 'rgba(255, 255, 255, 0)');
    grad.addColorStop(1, 'rgba(255, 255, 255, 1)');
    } else {
    grad.addColorStop(0, 'rgba(0, 0, 0, 0)');
    grad.addColorStop(1, 'rgba(0, 0, 0, 1)');
    }

    ctx.strokeStyle = grad;
    ctx.beginPath();
    ctx.arc(x, y, rad, angle - Math.PI, angle, false);
    ctx.stroke();

    // inner circle
    ctx.strokeStyle = light ? 'rgba(255, 255, 255, .4)' : '#eee';
    ctx.beginPath();
    ctx.arc(x, y, rad - 1, 0, Math.PI * 2, true);
    ctx.stroke();

    // text
    var text = this._text || ''
    , w = ctx.measureText(text).width;

    if (light) ctx.fillStyle = 'rgba(255, 255, 255, .9)';
    ctx.fillText(
    text
    , x - w / 2 + 1
    , y + fontSize / 2 - 1);

    return this;
    };


    },{"autoscale-canvas":10,"raf-component":11}],9:[function(require,module,exports){
    /**
    * Supported prefixes.
    */

    var prefixes = [
    '-webkit-', '-moz-', '-o-', '-ms-', ''
    ];

    /**
    * Expose `prefixed`.
    */

    module.exports = prefixed;

    /**
    * Set a style with all the vendor prefixes.
    *
    * @param {Object} style
    * @param {String} attribute
    * @param {String} value
    */

    function prefixed (style, attribute, value) {
    for (var i = 0; i < prefixes.length; i++) {
    style[prefixes[i] + attribute] = value;
    }
    };

    /**
    * Get a (possibly prefixed) value.
    *
    * @param {Object} style
    * @param {String} attribute
    * @return {String}
    */

    prefixed.get = function (style, attribute) {
    for (var i = 0; i < prefixes.length; i++) {
    var value = style[prefixes[i] + attribute];
    if (value && value != '') return value;
    }
    return '';
    };


    },{}],10:[function(require,module,exports){

    /**
    * Retina-enable the given `canvas`.
    *
    * @param {Canvas} canvas
    * @return {Canvas}
    * @api public
    */

    module.exports = function(canvas){
    var ctx = canvas.getContext('2d');
    var ratio = window.devicePixelRatio || 1;
    if (1 != ratio) {
    canvas.style.width = canvas.width + 'px';
    canvas.style.height = canvas.height + 'px';
    canvas.width *= ratio;
    canvas.height *= ratio;
    ctx.scale(ratio, ratio);
    }
    return canvas;
    };
    },{}],11:[function(require,module,exports){

    module.exports = window.requestAnimationFrame
    || window.webkitRequestAnimationFrame
    || window.mozRequestAnimationFrame
    || window.oRequestAnimationFrame
    || window.msRequestAnimationFrame
    || fallback;

    var prev = new Date().getTime();
    function fallback(fn) {
    var curr = new Date().getTime();
    var ms = Math.max(0, 16 - (curr - prev));
    setTimeout(fn, ms);
    prev = curr;
    }

    },{}]},{},[])
    //@ sourceMappingURL=data:application/json;base64,{"version":3,"file":"generated.js","sources":["/tmp/spinning11366-11281-992eur/node_modules/spinning/style.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/index.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/builtin/process.js","/usr/local/lib/node_modules/browserify/node_modules/insert-module-globals/node_modules/process/browser.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/builtin/path.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/insert-css/index.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/node_modules/vm-browserify/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/fade/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/fade/node_modules/prefixed/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/node_modules/autoscale-canvas/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/node_modules/raf-component/index.js"],"names":[],"mappings":";AAAA;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourcesContent":["module.exports = '.spinner, .overlay {\\n  position: fixed;\\n  opacity: 0;\\n}\\n\\n.spinner {\\n  left: 50%;\\n  top: 50%;\\n  margin-left: -100px;\\n  margin-top: -100px;\\n  z-index: 2222222222;\\n}\\n\\n.overlay {\\n  left: 0;\\n  top: 0;\\n  width: 100%;\\n  height: 100%;\\n  background-color: white;\\n  z-index: 1111111111;\\n}\\n';","(function(){var Spinner = require('spinner-browserify');\nvar insertCss = require('insert-css');\nvar style = require('./style');\nvar fade = require('fade');\nvar process = require('process'); // be nice to browserify\n\nmodule.exports = Spin;\n\nfunction Spin () {\n  insertCss(style);\n\n  // durations\n  var fadeIn = 1000;\n  var fadeOut = 300;\n\n  var overlay = document.createElement('div');\n  overlay.className = 'overlay';\n  document.body.appendChild(overlay);\n\n  var spinner = new Spinner();\n  spinner.el.className = 'spinner';\n  document.body.appendChild(spinner.el);\n\n  process.nextTick(function () {\n    fade(overlay, 0.8, fadeIn);\n    fade.in(spinner.el, fadeIn);\n  });\n\n  spinner.remove = function () {\n    fade.out(overlay, fadeOut);\n    fade.out(spinner.el, fadeOut);\n\n    setTimeout(function () {\n      spinner.stop();\n      document.body.removeChild(overlay);\n      document.body.removeChild(spinner.el);\n    }, fadeOut);\n  };\n\n  // reposition\n  var size = spinner.size;\n  spinner.size = function (n) {\n    spinner.el.style.marginLeft =\n    spinner.el.style.marginTop = '-' + (n/2) + 'px';\n    return size.call(spinner, n);\n  };\n\n  var light = spinner.light;\n  spinner.light = function () {\n    overlay.style.backgroundColor = 'black';\n    return light.call(spinner);\n  };\n\n  // set durations\n  spinner['in'] = function (ms) { fadeIn = ms };\n  spinner.out = function (ms) { fadeOut = ms };\n\n  return spinner;\n}\n\n})()","(function(){var process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n        && window.setImmediate;\n    var canPost = typeof window !== 'undefined'\n        && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    if (canPost) {\n        var queue = [];\n        window.addEventListener('message', function (ev) {\n            if (ev.source === window && ev.data === 'browserify-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('browserify-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nprocess.binding = function (name) {\n    if (name === 'evals') return (require)('vm')\n    else throw new Error('No such module. (Possibly not yet loaded)')\n};\n\n(function () {\n    var cwd = '/';\n    var path;\n    process.cwd = function () { return cwd };\n    process.chdir = function (dir) {\n        if (!path) path = require('path');\n        cwd = path.resolve(dir, cwd);\n    };\n})();\n\n})()","// shim for using process in browser\n\nvar process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n    && window.setImmediate;\n    var canPost = typeof window !== 'undefined'\n    && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    if (canPost) {\n        var queue = [];\n        window.addEventListener('message', function (ev) {\n            if (ev.source === window && ev.data === 'process-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('process-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n}\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\n","(function(process){function filter (xs, fn) {\n    var res = [];\n    for (var i = 0; i < xs.length; i++) {\n        if (fn(xs[i], i, xs)) res.push(xs[i]);\n    }\n    return res;\n}\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  var up = 0;\n  for (var i = parts.length; i >= 0; i--) {\n    var last = parts[i];\n    if (last == '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Regex to split a filename into [*, dir, basename, ext]\n// posix version\nvar splitPathRe = /^(.+\\/(?!$)|\\/)?((?:.+?)?(\\.[^.]*)?)$/;\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\nvar resolvedPath = '',\n    resolvedAbsolute = false;\n\nfor (var i = arguments.length; i >= -1 && !resolvedAbsolute; i--) {\n  var path = (i >= 0)\n      ? arguments[i]\n      : process.cwd();\n\n  // Skip empty and invalid entries\n  if (typeof path !== 'string' || !path) {\n    continue;\n  }\n\n  resolvedPath = path + '/' + resolvedPath;\n  resolvedAbsolute = path.charAt(0) === '/';\n}\n\n// At this point the path should be resolved to a full absolute path, but\n// handle relative paths to be safe (might happen when process.cwd() fails)\n\n// Normalize the path\nresolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n    return !!p;\n  }), !resolvedAbsolute).join('/');\n\n  return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\nvar isAbsolute = path.charAt(0) === '/',\n    trailingSlash = path.slice(-1) === '/';\n\n// Normalize the path\npath = normalizeArray(filter(path.split('/'), function(p) {\n    return !!p;\n  }), !isAbsolute).join('/');\n\n  if (!path && !isAbsolute) {\n    path = '.';\n  }\n  if (path && trailingSlash) {\n    path += '/';\n  }\n  \n  return (isAbsolute ? '/' : '') + path;\n};\n\n\n// posix version\nexports.join = function() {\n  var paths = Array.prototype.slice.call(arguments, 0);\n  return exports.normalize(filter(paths, function(p, index) {\n    return p && typeof p === 'string';\n  }).join('/'));\n};\n\n\nexports.dirname = function(path) {\n  var dir = splitPathRe.exec(path)[1] || '';\n  var isWindows = false;\n  if (!dir) {\n    // No dirname\n    return '.';\n  } else if (dir.length === 1 ||\n      (isWindows && dir.length <= 3 && dir.charAt(1) === ':')) {\n    // It is just a slash or a drive letter with a slash\n    return dir;\n  } else {\n    // It is a full dirname, strip trailing slash\n    return dir.substring(0, dir.length - 1);\n  }\n};\n\n\nexports.basename = function(path, ext) {\n  var f = splitPathRe.exec(path)[2] || '';\n  // TODO: make this comparison case-insensitive on windows?\n  if (ext && f.substr(-1 * ext.length) === ext) {\n    f = f.substr(0, f.length - ext.length);\n  }\n  return f;\n};\n\n\nexports.extname = function(path) {\n  return splitPathRe.exec(path)[3] || '';\n};\n\nexports.relative = function(from, to) {\n  from = exports.resolve(from).substr(1);\n  to = exports.resolve(to).substr(1);\n\n  function trim(arr) {\n    var start = 0;\n    for (; start < arr.length; start++) {\n      if (arr[start] !== '') break;\n    }\n\n    var end = arr.length - 1;\n    for (; end >= 0; end--) {\n      if (arr[end] !== '') break;\n    }\n\n    if (start > end) return [];\n    return arr.slice(start, end - start + 1);\n  }\n\n  var fromParts = trim(from.split('/'));\n  var toParts = trim(to.split('/'));\n\n  var length = Math.min(fromParts.length, toParts.length);\n  var samePartsLength = length;\n  for (var i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  var outputParts = [];\n  for (var i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n};\n\n})(require(\"__browserify_process\"))","var inserted = [];\n\nmodule.exports = function (css) {\n    if (inserted.indexOf(css) >= 0) return;\n    inserted.push(css);\n    \n    var elem = document.createElement('style');\n    var text = document.createTextNode(css);\n    elem.appendChild(text);\n    \n    if (document.head.childNodes.length) {\n        document.head.insertBefore(elem, document.head.childNodes[0]);\n    }\n    else {\n        document.head.appendChild(elem);\n    }\n};\n","var Object_keys = function (obj) {\n    if (Object.keys) return Object.keys(obj)\n    else {\n        var res = [];\n        for (var key in obj) res.push(key)\n        return res;\n    }\n};\n\nvar forEach = function (xs, fn) {\n    if (xs.forEach) return xs.forEach(fn)\n    else for (var i = 0; i < xs.length; i++) {\n        fn(xs[i], i, xs);\n    }\n};\n\nvar Script = exports.Script = function NodeScript (code) {\n    if (!(this instanceof Script)) return new Script(code);\n    this.code = code;\n};\n\nScript.prototype.runInNewContext = function (context) {\n    if (!context) context = {};\n    \n    var iframe = document.createElement('iframe');\n    if (!iframe.style) iframe.style = {};\n    iframe.style.display = 'none';\n    \n    document.body.appendChild(iframe);\n    \n    var win = iframe.contentWindow;\n    \n    forEach(Object_keys(context), function (key) {\n        win[key] = context[key];\n    });\n     \n    if (!win.eval && win.execScript) {\n        // win.eval() magically appears when this is called in IE:\n        win.execScript('null');\n    }\n    \n    var res = win.eval(this.code);\n    \n    forEach(Object_keys(win), function (key) {\n        context[key] = win[key];\n    });\n    \n    document.body.removeChild(iframe);\n    \n    return res;\n};\n\nScript.prototype.runInThisContext = function () {\n    return eval(this.code); // maybe...\n};\n\nScript.prototype.runInContext = function (context) {\n    // seems to be just runInNewContext on magical context objects which are\n    // otherwise indistinguishable from objects except plain old objects\n    // for the parameter segfaults node\n    return this.runInNewContext(context);\n};\n\nforEach(Object_keys(Script.prototype), function (name) {\n    exports[name] = Script[name] = function (code) {\n        var s = Script(code);\n        return s[name].apply(s, [].slice.call(arguments, 1));\n    };\n});\n\nexports.createScript = function (code) {\n    return exports.Script(code);\n};\n\nexports.createContext = Script.createContext = function (context) {\n    // not really sure what this one does\n    // seems to just make a shallow copy\n    var copy = {};\n    if(typeof context === 'object') {\n        forEach(Object_keys(context), function (key) {\n            copy[key] = context[key];\n        });\n    }\n    return copy;\n};\n","/**\n * Module dependencies.\n */\n\nvar prefixed = require('prefixed');\n\n/**\n * Expose `fade`.\n */\n\nmodule.exports = fade;\n\n/**\n * Fade `el` to `opacity` in `duration` seconds.\n *\n * @param {Element} el\n * @param {Number} opacity\n * @param {Number=} duration\n *\n * @todo Add other vendor prefixes\n * @todo Properly clear transition\n */\n\nfunction fade (el, opacity, duration) {\n  if (typeof duration === 'undefined') duration = 1000;\n\n  var oldTransition = prefixed.get(el.style, 'transition') || '';\n  prefixed(el.style, 'transition', 'opacity ' + (duration/1000) + 's');\n  el.style.opacity = opacity;\n\n  setTimeout(function () {\n    prefixed(el.style, 'transition', oldTransition);\n  }, duration);\n}\n\n/**\n * Fade in `el`.\n *\n * @param {Element} el\n * @param {Number=} duration\n */\n\nfade.out = function (el, duration) {\n  fade(el, 0, duration);\n};\n\n/**\n * Fade out `el`.\n *\n * @param {Element} el\n * @param {Number=} duration\n */\n\nfade['in'] = function (el, duration) {\n  fade(el, 1, duration);\n};\n","/**\n * Module dependencies.\n */\n\nvar autoscale = require('autoscale-canvas');\nvar raf = require('raf-component');\n\n/**\n * Expose `Spinner`.\n */\n\nmodule.exports = Spinner;\n\n/**\n * Initialize a new `Spinner`.\n */\n\nfunction Spinner() {\n  var self = this;\n  this.percent = 0;\n  this.el = document.createElement('canvas');\n  this.ctx = this.el.getContext('2d');\n  this.size(50);\n  this.fontSize(11);\n  this.speed(60);\n  this.font('helvetica, arial, sans-serif');\n  this.stopped = false;\n\n  (function animate() {\n    if (self.stopped) return;\n    raf(animate);\n    self.percent = (self.percent + self._speed / 36) % 100;\n    self.draw(self.ctx);\n  })();\n}\n\n/**\n * Stop the animation.\n *\n * @api public\n */\n\nSpinner.prototype.stop = function(){\n  this.stopped = true;\n};\n\n/**\n * Set spinner size to `n`.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.size = function(n){\n  this.el.width = n;\n  this.el.height = n;\n  autoscale(this.el);\n  return this;\n};\n\n/**\n * Set text to `str`.\n *\n * @param {String} str\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.text = function(str){\n  this._text = str;\n  return this;\n};\n\n/**\n * Set font size to `n`.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.fontSize = function(n){\n  this._fontSize = n;\n  return this;\n};\n\n/**\n * Set font `family`.\n *\n * @param {String} family\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.font = function(family){\n  this._font = family;\n  return this;\n};\n\n/**\n * Set speed to `n` rpm.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.speed = function(n) {\n  this._speed = n;\n  return this;\n};\n\n/**\n * Make the spinner light colored.\n *\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.light = function(){\n  this._light = true;\n  return this;\n};\n\n/**\n * Draw on `ctx`.\n *\n * @param {CanvasRenderingContext2d} ctx\n * @return {Spinner}\n * @api private\n */\n\nSpinner.prototype.draw = function(ctx){\n  var percent = Math.min(this.percent, 100)\n    , ratio = window.devicePixelRatio || 1\n    , size = this.el.width / ratio\n    , half = size / 2\n    , x = half\n    , y = half\n    , rad = half - 1\n    , fontSize = this._fontSize\n    , light = this._light;\n\n  ctx.font = fontSize + 'px ' + this._font;\n\n  var angle = Math.PI * 2 * (percent / 100);\n  ctx.clearRect(0, 0, size, size);\n\n  // outer circle\n  var grad = ctx.createLinearGradient(\n    half + Math.sin(Math.PI * 1.5 - angle) * half,\n    half + Math.cos(Math.PI * 1.5 - angle) * half,\n    half + Math.sin(Math.PI * 0.5 - angle) * half,\n    half + Math.cos(Math.PI * 0.5 - angle) * half\n  );\n\n  // color\n  if (light) {\n    grad.addColorStop(0, 'rgba(255, 255, 255, 0)');\n    grad.addColorStop(1, 'rgba(255, 255, 255, 1)');\n  } else {\n    grad.addColorStop(0, 'rgba(0, 0, 0, 0)');\n    grad.addColorStop(1, 'rgba(0, 0, 0, 1)');\n  }\n\n  ctx.strokeStyle = grad;\n  ctx.beginPath();\n  ctx.arc(x, y, rad, angle - Math.PI, angle, false);\n  ctx.stroke();\n\n  // inner circle\n  ctx.strokeStyle = light ? 'rgba(255, 255, 255, .4)' : '#eee';\n  ctx.beginPath();\n  ctx.arc(x, y, rad - 1, 0, Math.PI * 2, true);\n  ctx.stroke();\n\n  // text\n  var text = this._text || ''\n    , w = ctx.measureText(text).width;\n\n  if (light) ctx.fillStyle = 'rgba(255, 255, 255, .9)';\n  ctx.fillText(\n      text\n    , x - w / 2 + 1\n    , y + fontSize / 2 - 1);\n\n  return this;\n};\n\n","/**\n * Supported prefixes.\n */\n\nvar prefixes = [\n  '-webkit-', '-moz-', '-o-', '-ms-', ''\n];\n\n/**\n * Expose `prefixed`.\n */\n\nmodule.exports = prefixed;\n\n/**\n * Set a style with all the vendor prefixes.\n *\n * @param {Object} style\n * @param {String} attribute\n * @param {String} value\n */\n\nfunction prefixed (style, attribute, value) {\n  for (var i = 0; i < prefixes.length; i++) {\n    style[prefixes[i] + attribute] = value;\n  }\n};\n\n/**\n * Get a (possibly prefixed) value.\n *\n * @param {Object} style\n * @param {String} attribute\n * @return {String}\n */\n\nprefixed.get = function (style, attribute) {\n  for (var i = 0; i < prefixes.length; i++) {\n    var value = style[prefixes[i] + attribute];\n    if (value && value != '') return value;\n  }\n  return '';\n};\n\n","\n/**\n * Retina-enable the given `canvas`.\n *\n * @param {Canvas} canvas\n * @return {Canvas}\n * @api public\n */\n\nmodule.exports = function(canvas){\n  var ctx = canvas.getContext('2d');\n  var ratio = window.devicePixelRatio || 1;\n  if (1 != ratio) {\n    canvas.style.width = canvas.width + 'px';\n    canvas.style.height = canvas.height + 'px';\n    canvas.width *= ratio;\n    canvas.height *= ratio;\n    ctx.scale(ratio, ratio);\n  }\n  return canvas;\n};","\nmodule.exports = window.requestAnimationFrame\n  || window.webkitRequestAnimationFrame\n  || window.mozRequestAnimationFrame\n  || window.oRequestAnimationFrame\n  || window.msRequestAnimationFrame\n  || fallback;\n\nvar prev = new Date().getTime();\nfunction fallback(fn) {\n  var curr = new Date().getTime();\n  var ms = Math.max(0, 16 - (curr - prev));\n  setTimeout(fn, ms);\n  prev = curr;\n}\n"]}
    ;var Spinning = require('spinning');

    var spinner = Spinning().text('loading...').light().size(200);

    setTimeout(function () {
    spinner.remove();
    }, 3000);
    function eat(o,n){var t=o+" got eaten";n(t)}function poop(o){console.log(o)}eat("pizza",poop);
    2 changes: 2 additions & 0 deletions page-head.html
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,2 @@
    <style type='text/css'>html, body { margin: 0; padding: 0; border: 0; }
    body, html { height: 100%; width: 100%; }</style>
    1 change: 1 addition & 0 deletions requirebin.md
    Original file line number Diff line number Diff line change
    @@ -0,0 +1 @@
    view on [requirebin](http://requirebin.com?gist=5940808)
  3. @juliangruber juliangruber created this gist Jul 6, 2013.
    1 change: 1 addition & 0 deletions head.html
    Original file line number Diff line number Diff line change
    @@ -0,0 +1 @@
    <style type='text/css'> html, body { margin: 0; padding: 0; border: 0; } </style>
    7 changes: 7 additions & 0 deletions index.js
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,7 @@
    var Spinning = require('spinning');

    var spinner = Spinning().text('loading...').light().size(200);

    setTimeout(function () {
    spinner.remove();
    }, 3000);
    806 changes: 806 additions & 0 deletions minified.js
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,806 @@
    require=(function(e,t,n){function i(n,s){if(!t[n]){if(!e[n]){var o=typeof require=="function"&&require;if(!s&&o)return o(n,!0);if(r)return r(n,!0);throw new Error("Cannot find module '"+n+"'")}var u=t[n]={exports:{}};e[n][0].call(u.exports,function(t){var r=e[n][1][t];return i(r?r:t)},u,u.exports)}return t[n].exports}var r=typeof require=="function"&&require;for(var s=0;s<n.length;s++)i(n[s]);return i})({1:[function(require,module,exports){
    module.exports = '.spinner, .overlay {\n position: fixed;\n opacity: 0;\n}\n\n.spinner {\n left: 50%;\n top: 50%;\n margin-left: -100px;\n margin-top: -100px;\n z-index: 2222222222;\n}\n\n.overlay {\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: white;\n z-index: 1111111111;\n}\n';
    },{}],"spinning":[function(require,module,exports){
    module.exports=require('JGIiXp');
    },{}],"JGIiXp":[function(require,module,exports){
    (function(){var Spinner = require('spinner-browserify');
    var insertCss = require('insert-css');
    var style = require('./style');
    var fade = require('fade');
    var process = require('process'); // be nice to browserify

    module.exports = Spin;

    function Spin () {
    insertCss(style);

    // durations
    var fadeIn = 1000;
    var fadeOut = 300;

    var overlay = document.createElement('div');
    overlay.className = 'overlay';
    document.body.appendChild(overlay);

    var spinner = new Spinner();
    spinner.el.className = 'spinner';
    document.body.appendChild(spinner.el);

    process.nextTick(function () {
    fade(overlay, 0.8, fadeIn);
    fade.in(spinner.el, fadeIn);
    });

    spinner.remove = function () {
    fade.out(overlay, fadeOut);
    fade.out(spinner.el, fadeOut);

    setTimeout(function () {
    spinner.stop();
    document.body.removeChild(overlay);
    document.body.removeChild(spinner.el);
    }, fadeOut);
    };

    // reposition
    var size = spinner.size;
    spinner.size = function (n) {
    spinner.el.style.marginLeft =
    spinner.el.style.marginTop = '-' + (n/2) + 'px';
    return size.call(spinner, n);
    };

    var light = spinner.light;
    spinner.light = function () {
    overlay.style.backgroundColor = 'black';
    return light.call(spinner);
    };

    // set durations
    spinner['in'] = function (ms) { fadeIn = ms };
    spinner.out = function (ms) { fadeOut = ms };

    return spinner;
    }

    })()
    },{"process":2,"./style":1,"insert-css":3,"fade":4,"spinner-browserify":5}],2:[function(require,module,exports){
    (function(){var process = module.exports = {};

    process.nextTick = (function () {
    var canSetImmediate = typeof window !== 'undefined'
    && window.setImmediate;
    var canPost = typeof window !== 'undefined'
    && window.postMessage && window.addEventListener
    ;

    if (canSetImmediate) {
    return function (f) { return window.setImmediate(f) };
    }

    if (canPost) {
    var queue = [];
    window.addEventListener('message', function (ev) {
    if (ev.source === window && ev.data === 'browserify-tick') {
    ev.stopPropagation();
    if (queue.length > 0) {
    var fn = queue.shift();
    fn();
    }
    }
    }, true);

    return function nextTick(fn) {
    queue.push(fn);
    window.postMessage('browserify-tick', '*');
    };
    }

    return function nextTick(fn) {
    setTimeout(fn, 0);
    };
    })();

    process.title = 'browser';
    process.browser = true;
    process.env = {};
    process.argv = [];

    process.binding = function (name) {
    if (name === 'evals') return (require)('vm')
    else throw new Error('No such module. (Possibly not yet loaded)')
    };

    (function () {
    var cwd = '/';
    var path;
    process.cwd = function () { return cwd };
    process.chdir = function (dir) {
    if (!path) path = require('path');
    cwd = path.resolve(dir, cwd);
    };
    })();

    })()
    },{"path":6,"vm":7}],8:[function(require,module,exports){
    // shim for using process in browser

    var process = module.exports = {};

    process.nextTick = (function () {
    var canSetImmediate = typeof window !== 'undefined'
    && window.setImmediate;
    var canPost = typeof window !== 'undefined'
    && window.postMessage && window.addEventListener
    ;

    if (canSetImmediate) {
    return function (f) { return window.setImmediate(f) };
    }

    if (canPost) {
    var queue = [];
    window.addEventListener('message', function (ev) {
    if (ev.source === window && ev.data === 'process-tick') {
    ev.stopPropagation();
    if (queue.length > 0) {
    var fn = queue.shift();
    fn();
    }
    }
    }, true);

    return function nextTick(fn) {
    queue.push(fn);
    window.postMessage('process-tick', '*');
    };
    }

    return function nextTick(fn) {
    setTimeout(fn, 0);
    };
    })();

    process.title = 'browser';
    process.browser = true;
    process.env = {};
    process.argv = [];

    process.binding = function (name) {
    throw new Error('process.binding is not supported');
    }

    // TODO(shtylman)
    process.cwd = function () { return '/' };
    process.chdir = function (dir) {
    throw new Error('process.chdir is not supported');
    };

    },{}],6:[function(require,module,exports){
    (function(process){function filter (xs, fn) {
    var res = [];
    for (var i = 0; i < xs.length; i++) {
    if (fn(xs[i], i, xs)) res.push(xs[i]);
    }
    return res;
    }

    // resolves . and .. elements in a path array with directory names there
    // must be no slashes, empty elements, or device names (c:\) in the array
    // (so also no leading and trailing slashes - it does not distinguish
    // relative and absolute paths)
    function normalizeArray(parts, allowAboveRoot) {
    // if the path tries to go above the root, `up` ends up > 0
    var up = 0;
    for (var i = parts.length; i >= 0; i--) {
    var last = parts[i];
    if (last == '.') {
    parts.splice(i, 1);
    } else if (last === '..') {
    parts.splice(i, 1);
    up++;
    } else if (up) {
    parts.splice(i, 1);
    up--;
    }
    }

    // if the path is allowed to go above the root, restore leading ..s
    if (allowAboveRoot) {
    for (; up--; up) {
    parts.unshift('..');
    }
    }

    return parts;
    }

    // Regex to split a filename into [*, dir, basename, ext]
    // posix version
    var splitPathRe = /^(.+\/(?!$)|\/)?((?:.+?)?(\.[^.]*)?)$/;

    // path.resolve([from ...], to)
    // posix version
    exports.resolve = function() {
    var resolvedPath = '',
    resolvedAbsolute = false;

    for (var i = arguments.length; i >= -1 && !resolvedAbsolute; i--) {
    var path = (i >= 0)
    ? arguments[i]
    : process.cwd();

    // Skip empty and invalid entries
    if (typeof path !== 'string' || !path) {
    continue;
    }

    resolvedPath = path + '/' + resolvedPath;
    resolvedAbsolute = path.charAt(0) === '/';
    }

    // At this point the path should be resolved to a full absolute path, but
    // handle relative paths to be safe (might happen when process.cwd() fails)

    // Normalize the path
    resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {
    return !!p;
    }), !resolvedAbsolute).join('/');

    return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';
    };

    // path.normalize(path)
    // posix version
    exports.normalize = function(path) {
    var isAbsolute = path.charAt(0) === '/',
    trailingSlash = path.slice(-1) === '/';

    // Normalize the path
    path = normalizeArray(filter(path.split('/'), function(p) {
    return !!p;
    }), !isAbsolute).join('/');

    if (!path && !isAbsolute) {
    path = '.';
    }
    if (path && trailingSlash) {
    path += '/';
    }

    return (isAbsolute ? '/' : '') + path;
    };


    // posix version
    exports.join = function() {
    var paths = Array.prototype.slice.call(arguments, 0);
    return exports.normalize(filter(paths, function(p, index) {
    return p && typeof p === 'string';
    }).join('/'));
    };


    exports.dirname = function(path) {
    var dir = splitPathRe.exec(path)[1] || '';
    var isWindows = false;
    if (!dir) {
    // No dirname
    return '.';
    } else if (dir.length === 1 ||
    (isWindows && dir.length <= 3 && dir.charAt(1) === ':')) {
    // It is just a slash or a drive letter with a slash
    return dir;
    } else {
    // It is a full dirname, strip trailing slash
    return dir.substring(0, dir.length - 1);
    }
    };


    exports.basename = function(path, ext) {
    var f = splitPathRe.exec(path)[2] || '';
    // TODO: make this comparison case-insensitive on windows?
    if (ext && f.substr(-1 * ext.length) === ext) {
    f = f.substr(0, f.length - ext.length);
    }
    return f;
    };


    exports.extname = function(path) {
    return splitPathRe.exec(path)[3] || '';
    };

    exports.relative = function(from, to) {
    from = exports.resolve(from).substr(1);
    to = exports.resolve(to).substr(1);

    function trim(arr) {
    var start = 0;
    for (; start < arr.length; start++) {
    if (arr[start] !== '') break;
    }

    var end = arr.length - 1;
    for (; end >= 0; end--) {
    if (arr[end] !== '') break;
    }

    if (start > end) return [];
    return arr.slice(start, end - start + 1);
    }

    var fromParts = trim(from.split('/'));
    var toParts = trim(to.split('/'));

    var length = Math.min(fromParts.length, toParts.length);
    var samePartsLength = length;
    for (var i = 0; i < length; i++) {
    if (fromParts[i] !== toParts[i]) {
    samePartsLength = i;
    break;
    }
    }

    var outputParts = [];
    for (var i = samePartsLength; i < fromParts.length; i++) {
    outputParts.push('..');
    }

    outputParts = outputParts.concat(toParts.slice(samePartsLength));

    return outputParts.join('/');
    };

    })(require("__browserify_process"))
    },{"__browserify_process":8}],3:[function(require,module,exports){
    var inserted = [];

    module.exports = function (css) {
    if (inserted.indexOf(css) >= 0) return;
    inserted.push(css);

    var elem = document.createElement('style');
    var text = document.createTextNode(css);
    elem.appendChild(text);

    if (document.head.childNodes.length) {
    document.head.insertBefore(elem, document.head.childNodes[0]);
    }
    else {
    document.head.appendChild(elem);
    }
    };

    },{}],7:[function(require,module,exports){
    var Object_keys = function (obj) {
    if (Object.keys) return Object.keys(obj)
    else {
    var res = [];
    for (var key in obj) res.push(key)
    return res;
    }
    };

    var forEach = function (xs, fn) {
    if (xs.forEach) return xs.forEach(fn)
    else for (var i = 0; i < xs.length; i++) {
    fn(xs[i], i, xs);
    }
    };

    var Script = exports.Script = function NodeScript (code) {
    if (!(this instanceof Script)) return new Script(code);
    this.code = code;
    };

    Script.prototype.runInNewContext = function (context) {
    if (!context) context = {};

    var iframe = document.createElement('iframe');
    if (!iframe.style) iframe.style = {};
    iframe.style.display = 'none';

    document.body.appendChild(iframe);

    var win = iframe.contentWindow;

    forEach(Object_keys(context), function (key) {
    win[key] = context[key];
    });

    if (!win.eval && win.execScript) {
    // win.eval() magically appears when this is called in IE:
    win.execScript('null');
    }

    var res = win.eval(this.code);

    forEach(Object_keys(win), function (key) {
    context[key] = win[key];
    });

    document.body.removeChild(iframe);

    return res;
    };

    Script.prototype.runInThisContext = function () {
    return eval(this.code); // maybe...
    };

    Script.prototype.runInContext = function (context) {
    // seems to be just runInNewContext on magical context objects which are
    // otherwise indistinguishable from objects except plain old objects
    // for the parameter segfaults node
    return this.runInNewContext(context);
    };

    forEach(Object_keys(Script.prototype), function (name) {
    exports[name] = Script[name] = function (code) {
    var s = Script(code);
    return s[name].apply(s, [].slice.call(arguments, 1));
    };
    });

    exports.createScript = function (code) {
    return exports.Script(code);
    };

    exports.createContext = Script.createContext = function (context) {
    // not really sure what this one does
    // seems to just make a shallow copy
    var copy = {};
    if(typeof context === 'object') {
    forEach(Object_keys(context), function (key) {
    copy[key] = context[key];
    });
    }
    return copy;
    };

    },{}],4:[function(require,module,exports){
    /**
    * Module dependencies.
    */

    var prefixed = require('prefixed');

    /**
    * Expose `fade`.
    */

    module.exports = fade;

    /**
    * Fade `el` to `opacity` in `duration` seconds.
    *
    * @param {Element} el
    * @param {Number} opacity
    * @param {Number=} duration
    *
    * @todo Add other vendor prefixes
    * @todo Properly clear transition
    */

    function fade (el, opacity, duration) {
    if (typeof duration === 'undefined') duration = 1000;

    var oldTransition = prefixed.get(el.style, 'transition') || '';
    prefixed(el.style, 'transition', 'opacity ' + (duration/1000) + 's');
    el.style.opacity = opacity;

    setTimeout(function () {
    prefixed(el.style, 'transition', oldTransition);
    }, duration);
    }

    /**
    * Fade in `el`.
    *
    * @param {Element} el
    * @param {Number=} duration
    */

    fade.out = function (el, duration) {
    fade(el, 0, duration);
    };

    /**
    * Fade out `el`.
    *
    * @param {Element} el
    * @param {Number=} duration
    */

    fade['in'] = function (el, duration) {
    fade(el, 1, duration);
    };

    },{"prefixed":9}],5:[function(require,module,exports){
    /**
    * Module dependencies.
    */

    var autoscale = require('autoscale-canvas');
    var raf = require('raf-component');

    /**
    * Expose `Spinner`.
    */

    module.exports = Spinner;

    /**
    * Initialize a new `Spinner`.
    */

    function Spinner() {
    var self = this;
    this.percent = 0;
    this.el = document.createElement('canvas');
    this.ctx = this.el.getContext('2d');
    this.size(50);
    this.fontSize(11);
    this.speed(60);
    this.font('helvetica, arial, sans-serif');
    this.stopped = false;

    (function animate() {
    if (self.stopped) return;
    raf(animate);
    self.percent = (self.percent + self._speed / 36) % 100;
    self.draw(self.ctx);
    })();
    }

    /**
    * Stop the animation.
    *
    * @api public
    */

    Spinner.prototype.stop = function(){
    this.stopped = true;
    };

    /**
    * Set spinner size to `n`.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.size = function(n){
    this.el.width = n;
    this.el.height = n;
    autoscale(this.el);
    return this;
    };

    /**
    * Set text to `str`.
    *
    * @param {String} str
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.text = function(str){
    this._text = str;
    return this;
    };

    /**
    * Set font size to `n`.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.fontSize = function(n){
    this._fontSize = n;
    return this;
    };

    /**
    * Set font `family`.
    *
    * @param {String} family
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.font = function(family){
    this._font = family;
    return this;
    };

    /**
    * Set speed to `n` rpm.
    *
    * @param {Number} n
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.speed = function(n) {
    this._speed = n;
    return this;
    };

    /**
    * Make the spinner light colored.
    *
    * @return {Spinner}
    * @api public
    */

    Spinner.prototype.light = function(){
    this._light = true;
    return this;
    };

    /**
    * Draw on `ctx`.
    *
    * @param {CanvasRenderingContext2d} ctx
    * @return {Spinner}
    * @api private
    */

    Spinner.prototype.draw = function(ctx){
    var percent = Math.min(this.percent, 100)
    , ratio = window.devicePixelRatio || 1
    , size = this.el.width / ratio
    , half = size / 2
    , x = half
    , y = half
    , rad = half - 1
    , fontSize = this._fontSize
    , light = this._light;

    ctx.font = fontSize + 'px ' + this._font;

    var angle = Math.PI * 2 * (percent / 100);
    ctx.clearRect(0, 0, size, size);

    // outer circle
    var grad = ctx.createLinearGradient(
    half + Math.sin(Math.PI * 1.5 - angle) * half,
    half + Math.cos(Math.PI * 1.5 - angle) * half,
    half + Math.sin(Math.PI * 0.5 - angle) * half,
    half + Math.cos(Math.PI * 0.5 - angle) * half
    );

    // color
    if (light) {
    grad.addColorStop(0, 'rgba(255, 255, 255, 0)');
    grad.addColorStop(1, 'rgba(255, 255, 255, 1)');
    } else {
    grad.addColorStop(0, 'rgba(0, 0, 0, 0)');
    grad.addColorStop(1, 'rgba(0, 0, 0, 1)');
    }

    ctx.strokeStyle = grad;
    ctx.beginPath();
    ctx.arc(x, y, rad, angle - Math.PI, angle, false);
    ctx.stroke();

    // inner circle
    ctx.strokeStyle = light ? 'rgba(255, 255, 255, .4)' : '#eee';
    ctx.beginPath();
    ctx.arc(x, y, rad - 1, 0, Math.PI * 2, true);
    ctx.stroke();

    // text
    var text = this._text || ''
    , w = ctx.measureText(text).width;

    if (light) ctx.fillStyle = 'rgba(255, 255, 255, .9)';
    ctx.fillText(
    text
    , x - w / 2 + 1
    , y + fontSize / 2 - 1);

    return this;
    };


    },{"autoscale-canvas":10,"raf-component":11}],9:[function(require,module,exports){
    /**
    * Supported prefixes.
    */

    var prefixes = [
    '-webkit-', '-moz-', '-o-', '-ms-', ''
    ];

    /**
    * Expose `prefixed`.
    */

    module.exports = prefixed;

    /**
    * Set a style with all the vendor prefixes.
    *
    * @param {Object} style
    * @param {String} attribute
    * @param {String} value
    */

    function prefixed (style, attribute, value) {
    for (var i = 0; i < prefixes.length; i++) {
    style[prefixes[i] + attribute] = value;
    }
    };

    /**
    * Get a (possibly prefixed) value.
    *
    * @param {Object} style
    * @param {String} attribute
    * @return {String}
    */

    prefixed.get = function (style, attribute) {
    for (var i = 0; i < prefixes.length; i++) {
    var value = style[prefixes[i] + attribute];
    if (value && value != '') return value;
    }
    return '';
    };


    },{}],10:[function(require,module,exports){

    /**
    * Retina-enable the given `canvas`.
    *
    * @param {Canvas} canvas
    * @return {Canvas}
    * @api public
    */

    module.exports = function(canvas){
    var ctx = canvas.getContext('2d');
    var ratio = window.devicePixelRatio || 1;
    if (1 != ratio) {
    canvas.style.width = canvas.width + 'px';
    canvas.style.height = canvas.height + 'px';
    canvas.width *= ratio;
    canvas.height *= ratio;
    ctx.scale(ratio, ratio);
    }
    return canvas;
    };
    },{}],11:[function(require,module,exports){

    module.exports = window.requestAnimationFrame
    || window.webkitRequestAnimationFrame
    || window.mozRequestAnimationFrame
    || window.oRequestAnimationFrame
    || window.msRequestAnimationFrame
    || fallback;

    var prev = new Date().getTime();
    function fallback(fn) {
    var curr = new Date().getTime();
    var ms = Math.max(0, 16 - (curr - prev));
    setTimeout(fn, ms);
    prev = curr;
    }

    },{}]},{},[])
    //@ sourceMappingURL=data:application/json;base64,{"version":3,"file":"generated.js","sources":["/tmp/spinning11366-11281-992eur/node_modules/spinning/style.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/index.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/builtin/process.js","/usr/local/lib/node_modules/browserify/node_modules/insert-module-globals/node_modules/process/browser.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/builtin/path.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/insert-css/index.js","/usr/local/lib/node_modules/browserify/node_modules/browser-builtins/node_modules/vm-browserify/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/fade/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/fade/node_modules/prefixed/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/node_modules/autoscale-canvas/index.js","/tmp/spinning11366-11281-992eur/node_modules/spinning/node_modules/spinner-browserify/node_modules/raf-component/index.js"],"names":[],"mappings":";AAAA;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourcesContent":["module.exports = '.spinner, .overlay {\\n  position: fixed;\\n  opacity: 0;\\n}\\n\\n.spinner {\\n  left: 50%;\\n  top: 50%;\\n  margin-left: -100px;\\n  margin-top: -100px;\\n  z-index: 2222222222;\\n}\\n\\n.overlay {\\n  left: 0;\\n  top: 0;\\n  width: 100%;\\n  height: 100%;\\n  background-color: white;\\n  z-index: 1111111111;\\n}\\n';","(function(){var Spinner = require('spinner-browserify');\nvar insertCss = require('insert-css');\nvar style = require('./style');\nvar fade = require('fade');\nvar process = require('process'); // be nice to browserify\n\nmodule.exports = Spin;\n\nfunction Spin () {\n  insertCss(style);\n\n  // durations\n  var fadeIn = 1000;\n  var fadeOut = 300;\n\n  var overlay = document.createElement('div');\n  overlay.className = 'overlay';\n  document.body.appendChild(overlay);\n\n  var spinner = new Spinner();\n  spinner.el.className = 'spinner';\n  document.body.appendChild(spinner.el);\n\n  process.nextTick(function () {\n    fade(overlay, 0.8, fadeIn);\n    fade.in(spinner.el, fadeIn);\n  });\n\n  spinner.remove = function () {\n    fade.out(overlay, fadeOut);\n    fade.out(spinner.el, fadeOut);\n\n    setTimeout(function () {\n      spinner.stop();\n      document.body.removeChild(overlay);\n      document.body.removeChild(spinner.el);\n    }, fadeOut);\n  };\n\n  // reposition\n  var size = spinner.size;\n  spinner.size = function (n) {\n    spinner.el.style.marginLeft =\n    spinner.el.style.marginTop = '-' + (n/2) + 'px';\n    return size.call(spinner, n);\n  };\n\n  var light = spinner.light;\n  spinner.light = function () {\n    overlay.style.backgroundColor = 'black';\n    return light.call(spinner);\n  };\n\n  // set durations\n  spinner['in'] = function (ms) { fadeIn = ms };\n  spinner.out = function (ms) { fadeOut = ms };\n\n  return spinner;\n}\n\n})()","(function(){var process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n        && window.setImmediate;\n    var canPost = typeof window !== 'undefined'\n        && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    if (canPost) {\n        var queue = [];\n        window.addEventListener('message', function (ev) {\n            if (ev.source === window && ev.data === 'browserify-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('browserify-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nprocess.binding = function (name) {\n    if (name === 'evals') return (require)('vm')\n    else throw new Error('No such module. (Possibly not yet loaded)')\n};\n\n(function () {\n    var cwd = '/';\n    var path;\n    process.cwd = function () { return cwd };\n    process.chdir = function (dir) {\n        if (!path) path = require('path');\n        cwd = path.resolve(dir, cwd);\n    };\n})();\n\n})()","// shim for using process in browser\n\nvar process = module.exports = {};\n\nprocess.nextTick = (function () {\n    var canSetImmediate = typeof window !== 'undefined'\n    && window.setImmediate;\n    var canPost = typeof window !== 'undefined'\n    && window.postMessage && window.addEventListener\n    ;\n\n    if (canSetImmediate) {\n        return function (f) { return window.setImmediate(f) };\n    }\n\n    if (canPost) {\n        var queue = [];\n        window.addEventListener('message', function (ev) {\n            if (ev.source === window && ev.data === 'process-tick') {\n                ev.stopPropagation();\n                if (queue.length > 0) {\n                    var fn = queue.shift();\n                    fn();\n                }\n            }\n        }, true);\n\n        return function nextTick(fn) {\n            queue.push(fn);\n            window.postMessage('process-tick', '*');\n        };\n    }\n\n    return function nextTick(fn) {\n        setTimeout(fn, 0);\n    };\n})();\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n}\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\n","(function(process){function filter (xs, fn) {\n    var res = [];\n    for (var i = 0; i < xs.length; i++) {\n        if (fn(xs[i], i, xs)) res.push(xs[i]);\n    }\n    return res;\n}\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  var up = 0;\n  for (var i = parts.length; i >= 0; i--) {\n    var last = parts[i];\n    if (last == '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Regex to split a filename into [*, dir, basename, ext]\n// posix version\nvar splitPathRe = /^(.+\\/(?!$)|\\/)?((?:.+?)?(\\.[^.]*)?)$/;\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\nvar resolvedPath = '',\n    resolvedAbsolute = false;\n\nfor (var i = arguments.length; i >= -1 && !resolvedAbsolute; i--) {\n  var path = (i >= 0)\n      ? arguments[i]\n      : process.cwd();\n\n  // Skip empty and invalid entries\n  if (typeof path !== 'string' || !path) {\n    continue;\n  }\n\n  resolvedPath = path + '/' + resolvedPath;\n  resolvedAbsolute = path.charAt(0) === '/';\n}\n\n// At this point the path should be resolved to a full absolute path, but\n// handle relative paths to be safe (might happen when process.cwd() fails)\n\n// Normalize the path\nresolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n    return !!p;\n  }), !resolvedAbsolute).join('/');\n\n  return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\nvar isAbsolute = path.charAt(0) === '/',\n    trailingSlash = path.slice(-1) === '/';\n\n// Normalize the path\npath = normalizeArray(filter(path.split('/'), function(p) {\n    return !!p;\n  }), !isAbsolute).join('/');\n\n  if (!path && !isAbsolute) {\n    path = '.';\n  }\n  if (path && trailingSlash) {\n    path += '/';\n  }\n  \n  return (isAbsolute ? '/' : '') + path;\n};\n\n\n// posix version\nexports.join = function() {\n  var paths = Array.prototype.slice.call(arguments, 0);\n  return exports.normalize(filter(paths, function(p, index) {\n    return p && typeof p === 'string';\n  }).join('/'));\n};\n\n\nexports.dirname = function(path) {\n  var dir = splitPathRe.exec(path)[1] || '';\n  var isWindows = false;\n  if (!dir) {\n    // No dirname\n    return '.';\n  } else if (dir.length === 1 ||\n      (isWindows && dir.length <= 3 && dir.charAt(1) === ':')) {\n    // It is just a slash or a drive letter with a slash\n    return dir;\n  } else {\n    // It is a full dirname, strip trailing slash\n    return dir.substring(0, dir.length - 1);\n  }\n};\n\n\nexports.basename = function(path, ext) {\n  var f = splitPathRe.exec(path)[2] || '';\n  // TODO: make this comparison case-insensitive on windows?\n  if (ext && f.substr(-1 * ext.length) === ext) {\n    f = f.substr(0, f.length - ext.length);\n  }\n  return f;\n};\n\n\nexports.extname = function(path) {\n  return splitPathRe.exec(path)[3] || '';\n};\n\nexports.relative = function(from, to) {\n  from = exports.resolve(from).substr(1);\n  to = exports.resolve(to).substr(1);\n\n  function trim(arr) {\n    var start = 0;\n    for (; start < arr.length; start++) {\n      if (arr[start] !== '') break;\n    }\n\n    var end = arr.length - 1;\n    for (; end >= 0; end--) {\n      if (arr[end] !== '') break;\n    }\n\n    if (start > end) return [];\n    return arr.slice(start, end - start + 1);\n  }\n\n  var fromParts = trim(from.split('/'));\n  var toParts = trim(to.split('/'));\n\n  var length = Math.min(fromParts.length, toParts.length);\n  var samePartsLength = length;\n  for (var i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  var outputParts = [];\n  for (var i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n};\n\n})(require(\"__browserify_process\"))","var inserted = [];\n\nmodule.exports = function (css) {\n    if (inserted.indexOf(css) >= 0) return;\n    inserted.push(css);\n    \n    var elem = document.createElement('style');\n    var text = document.createTextNode(css);\n    elem.appendChild(text);\n    \n    if (document.head.childNodes.length) {\n        document.head.insertBefore(elem, document.head.childNodes[0]);\n    }\n    else {\n        document.head.appendChild(elem);\n    }\n};\n","var Object_keys = function (obj) {\n    if (Object.keys) return Object.keys(obj)\n    else {\n        var res = [];\n        for (var key in obj) res.push(key)\n        return res;\n    }\n};\n\nvar forEach = function (xs, fn) {\n    if (xs.forEach) return xs.forEach(fn)\n    else for (var i = 0; i < xs.length; i++) {\n        fn(xs[i], i, xs);\n    }\n};\n\nvar Script = exports.Script = function NodeScript (code) {\n    if (!(this instanceof Script)) return new Script(code);\n    this.code = code;\n};\n\nScript.prototype.runInNewContext = function (context) {\n    if (!context) context = {};\n    \n    var iframe = document.createElement('iframe');\n    if (!iframe.style) iframe.style = {};\n    iframe.style.display = 'none';\n    \n    document.body.appendChild(iframe);\n    \n    var win = iframe.contentWindow;\n    \n    forEach(Object_keys(context), function (key) {\n        win[key] = context[key];\n    });\n     \n    if (!win.eval && win.execScript) {\n        // win.eval() magically appears when this is called in IE:\n        win.execScript('null');\n    }\n    \n    var res = win.eval(this.code);\n    \n    forEach(Object_keys(win), function (key) {\n        context[key] = win[key];\n    });\n    \n    document.body.removeChild(iframe);\n    \n    return res;\n};\n\nScript.prototype.runInThisContext = function () {\n    return eval(this.code); // maybe...\n};\n\nScript.prototype.runInContext = function (context) {\n    // seems to be just runInNewContext on magical context objects which are\n    // otherwise indistinguishable from objects except plain old objects\n    // for the parameter segfaults node\n    return this.runInNewContext(context);\n};\n\nforEach(Object_keys(Script.prototype), function (name) {\n    exports[name] = Script[name] = function (code) {\n        var s = Script(code);\n        return s[name].apply(s, [].slice.call(arguments, 1));\n    };\n});\n\nexports.createScript = function (code) {\n    return exports.Script(code);\n};\n\nexports.createContext = Script.createContext = function (context) {\n    // not really sure what this one does\n    // seems to just make a shallow copy\n    var copy = {};\n    if(typeof context === 'object') {\n        forEach(Object_keys(context), function (key) {\n            copy[key] = context[key];\n        });\n    }\n    return copy;\n};\n","/**\n * Module dependencies.\n */\n\nvar prefixed = require('prefixed');\n\n/**\n * Expose `fade`.\n */\n\nmodule.exports = fade;\n\n/**\n * Fade `el` to `opacity` in `duration` seconds.\n *\n * @param {Element} el\n * @param {Number} opacity\n * @param {Number=} duration\n *\n * @todo Add other vendor prefixes\n * @todo Properly clear transition\n */\n\nfunction fade (el, opacity, duration) {\n  if (typeof duration === 'undefined') duration = 1000;\n\n  var oldTransition = prefixed.get(el.style, 'transition') || '';\n  prefixed(el.style, 'transition', 'opacity ' + (duration/1000) + 's');\n  el.style.opacity = opacity;\n\n  setTimeout(function () {\n    prefixed(el.style, 'transition', oldTransition);\n  }, duration);\n}\n\n/**\n * Fade in `el`.\n *\n * @param {Element} el\n * @param {Number=} duration\n */\n\nfade.out = function (el, duration) {\n  fade(el, 0, duration);\n};\n\n/**\n * Fade out `el`.\n *\n * @param {Element} el\n * @param {Number=} duration\n */\n\nfade['in'] = function (el, duration) {\n  fade(el, 1, duration);\n};\n","/**\n * Module dependencies.\n */\n\nvar autoscale = require('autoscale-canvas');\nvar raf = require('raf-component');\n\n/**\n * Expose `Spinner`.\n */\n\nmodule.exports = Spinner;\n\n/**\n * Initialize a new `Spinner`.\n */\n\nfunction Spinner() {\n  var self = this;\n  this.percent = 0;\n  this.el = document.createElement('canvas');\n  this.ctx = this.el.getContext('2d');\n  this.size(50);\n  this.fontSize(11);\n  this.speed(60);\n  this.font('helvetica, arial, sans-serif');\n  this.stopped = false;\n\n  (function animate() {\n    if (self.stopped) return;\n    raf(animate);\n    self.percent = (self.percent + self._speed / 36) % 100;\n    self.draw(self.ctx);\n  })();\n}\n\n/**\n * Stop the animation.\n *\n * @api public\n */\n\nSpinner.prototype.stop = function(){\n  this.stopped = true;\n};\n\n/**\n * Set spinner size to `n`.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.size = function(n){\n  this.el.width = n;\n  this.el.height = n;\n  autoscale(this.el);\n  return this;\n};\n\n/**\n * Set text to `str`.\n *\n * @param {String} str\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.text = function(str){\n  this._text = str;\n  return this;\n};\n\n/**\n * Set font size to `n`.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.fontSize = function(n){\n  this._fontSize = n;\n  return this;\n};\n\n/**\n * Set font `family`.\n *\n * @param {String} family\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.font = function(family){\n  this._font = family;\n  return this;\n};\n\n/**\n * Set speed to `n` rpm.\n *\n * @param {Number} n\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.speed = function(n) {\n  this._speed = n;\n  return this;\n};\n\n/**\n * Make the spinner light colored.\n *\n * @return {Spinner}\n * @api public\n */\n\nSpinner.prototype.light = function(){\n  this._light = true;\n  return this;\n};\n\n/**\n * Draw on `ctx`.\n *\n * @param {CanvasRenderingContext2d} ctx\n * @return {Spinner}\n * @api private\n */\n\nSpinner.prototype.draw = function(ctx){\n  var percent = Math.min(this.percent, 100)\n    , ratio = window.devicePixelRatio || 1\n    , size = this.el.width / ratio\n    , half = size / 2\n    , x = half\n    , y = half\n    , rad = half - 1\n    , fontSize = this._fontSize\n    , light = this._light;\n\n  ctx.font = fontSize + 'px ' + this._font;\n\n  var angle = Math.PI * 2 * (percent / 100);\n  ctx.clearRect(0, 0, size, size);\n\n  // outer circle\n  var grad = ctx.createLinearGradient(\n    half + Math.sin(Math.PI * 1.5 - angle) * half,\n    half + Math.cos(Math.PI * 1.5 - angle) * half,\n    half + Math.sin(Math.PI * 0.5 - angle) * half,\n    half + Math.cos(Math.PI * 0.5 - angle) * half\n  );\n\n  // color\n  if (light) {\n    grad.addColorStop(0, 'rgba(255, 255, 255, 0)');\n    grad.addColorStop(1, 'rgba(255, 255, 255, 1)');\n  } else {\n    grad.addColorStop(0, 'rgba(0, 0, 0, 0)');\n    grad.addColorStop(1, 'rgba(0, 0, 0, 1)');\n  }\n\n  ctx.strokeStyle = grad;\n  ctx.beginPath();\n  ctx.arc(x, y, rad, angle - Math.PI, angle, false);\n  ctx.stroke();\n\n  // inner circle\n  ctx.strokeStyle = light ? 'rgba(255, 255, 255, .4)' : '#eee';\n  ctx.beginPath();\n  ctx.arc(x, y, rad - 1, 0, Math.PI * 2, true);\n  ctx.stroke();\n\n  // text\n  var text = this._text || ''\n    , w = ctx.measureText(text).width;\n\n  if (light) ctx.fillStyle = 'rgba(255, 255, 255, .9)';\n  ctx.fillText(\n      text\n    , x - w / 2 + 1\n    , y + fontSize / 2 - 1);\n\n  return this;\n};\n\n","/**\n * Supported prefixes.\n */\n\nvar prefixes = [\n  '-webkit-', '-moz-', '-o-', '-ms-', ''\n];\n\n/**\n * Expose `prefixed`.\n */\n\nmodule.exports = prefixed;\n\n/**\n * Set a style with all the vendor prefixes.\n *\n * @param {Object} style\n * @param {String} attribute\n * @param {String} value\n */\n\nfunction prefixed (style, attribute, value) {\n  for (var i = 0; i < prefixes.length; i++) {\n    style[prefixes[i] + attribute] = value;\n  }\n};\n\n/**\n * Get a (possibly prefixed) value.\n *\n * @param {Object} style\n * @param {String} attribute\n * @return {String}\n */\n\nprefixed.get = function (style, attribute) {\n  for (var i = 0; i < prefixes.length; i++) {\n    var value = style[prefixes[i] + attribute];\n    if (value && value != '') return value;\n  }\n  return '';\n};\n\n","\n/**\n * Retina-enable the given `canvas`.\n *\n * @param {Canvas} canvas\n * @return {Canvas}\n * @api public\n */\n\nmodule.exports = function(canvas){\n  var ctx = canvas.getContext('2d');\n  var ratio = window.devicePixelRatio || 1;\n  if (1 != ratio) {\n    canvas.style.width = canvas.width + 'px';\n    canvas.style.height = canvas.height + 'px';\n    canvas.width *= ratio;\n    canvas.height *= ratio;\n    ctx.scale(ratio, ratio);\n  }\n  return canvas;\n};","\nmodule.exports = window.requestAnimationFrame\n  || window.webkitRequestAnimationFrame\n  || window.mozRequestAnimationFrame\n  || window.oRequestAnimationFrame\n  || window.msRequestAnimationFrame\n  || fallback;\n\nvar prev = new Date().getTime();\nfunction fallback(fn) {\n  var curr = new Date().getTime();\n  var ms = Math.max(0, 16 - (curr - prev));\n  setTimeout(fn, ms);\n  prev = curr;\n}\n"]}
    ;var Spinning = require('spinning');

    var spinner = Spinning().text('loading...').light().size(200);

    setTimeout(function () {
    spinner.remove();
    }, 3000);