Created
July 6, 2013 18:37
-
-
Save juliangruber/5940808 to your computer and use it in GitHub Desktop.
made with requirebin.com
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<style type='text/css'> html, body { margin: 0; padding: 0; border: 0; } </style> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var Spinning = require('spinning'); | |
var spinner = Spinning().text('loading...').light().size(200); | |
setTimeout(function () { | |
spinner.remove(); | |
}, 3000); |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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