Skip to content

Instantly share code, notes, and snippets.

@juliangruber
Created July 6, 2013 18:37
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 9 You must be signed in to fork a gist
  • Save juliangruber/5940808 to your computer and use it in GitHub Desktop.
Save juliangruber/5940808 to your computer and use it in GitHub Desktop.
made with requirebin.com
<style type='text/css'> html, body { margin: 0; padding: 0; border: 0; } </style>
var Spinning = require('spinning');
var spinner = Spinning().text('loading...').light().size(200);
setTimeout(function () {
spinner.remove();
}, 3000);
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);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment