made with requirebin
Created
October 6, 2016 15:45
-
-
Save yoshuawuyts/a0701206430d7a8d5466ac778b4d9c20 to your computer and use it in GitHub Desktop.
requirebin sketch
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
const chooet = require('chooet'); | |
const html = require('chooet/html'); | |
chooet(choo => { | |
app = choo(); | |
app.model({ | |
state: { title: 'Not quite set yet' }, | |
reducers: { | |
update: (data, state) => ({ title: data }) | |
} | |
}); | |
const mainView = (state, prev, send) => html` | |
<main> | |
<h1>Title: ${state.title}</h1> | |
<input | |
type="text" | |
name="title" | |
dataset=${{input: (event, value) => send('update', value.title)}}> | |
</main> | |
`; | |
app.router(route => [ | |
route('/', mainView) | |
]); | |
app.start('body'); | |
}); |
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
setTimeout(function(){ | |
;require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ | |
// http://wiki.commonjs.org/wiki/Unit_Testing/1.0 | |
// | |
// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8! | |
// | |
// Originally from narwhal.js (http://narwhaljs.org) | |
// Copyright (c) 2009 Thomas Robinson <280north.com> | |
// | |
// Permission is hereby granted, free of charge, to any person obtaining a copy | |
// of this software and associated documentation files (the 'Software'), to | |
// deal in the Software without restriction, including without limitation the | |
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | |
// sell copies of the Software, and to permit persons to whom the Software is | |
// furnished to do so, subject to the following conditions: | |
// | |
// The above copyright notice and this permission notice shall be included in | |
// all copies or substantial portions of the Software. | |
// | |
// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | |
// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN | |
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | |
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
// when used in node, this will actually load the util module we depend on | |
// versus loading the builtin util module as happens otherwise | |
// this is a bug in node module loading as far as I am concerned | |
var util = require('util/'); | |
var pSlice = Array.prototype.slice; | |
var hasOwn = Object.prototype.hasOwnProperty; | |
// 1. The assert module provides functions that throw | |
// AssertionError's when particular conditions are not met. The | |
// assert module must conform to the following interface. | |
var assert = module.exports = ok; | |
// 2. The AssertionError is defined in assert. | |
// new assert.AssertionError({ message: message, | |
// actual: actual, | |
// expected: expected }) | |
assert.AssertionError = function AssertionError(options) { | |
this.name = 'AssertionError'; | |
this.actual = options.actual; | |
this.expected = options.expected; | |
this.operator = options.operator; | |
if (options.message) { | |
this.message = options.message; | |
this.generatedMessage = false; | |
} else { | |
this.message = getMessage(this); | |
this.generatedMessage = true; | |
} | |
var stackStartFunction = options.stackStartFunction || fail; | |
if (Error.captureStackTrace) { | |
Error.captureStackTrace(this, stackStartFunction); | |
} | |
else { | |
// non v8 browsers so we can have a stacktrace | |
var err = new Error(); | |
if (err.stack) { | |
var out = err.stack; | |
// try to strip useless frames | |
var fn_name = stackStartFunction.name; | |
var idx = out.indexOf('\n' + fn_name); | |
if (idx >= 0) { | |
// once we have located the function frame | |
// we need to strip out everything before it (and its line) | |
var next_line = out.indexOf('\n', idx + 1); | |
out = out.substring(next_line + 1); | |
} | |
this.stack = out; | |
} | |
} | |
}; | |
// assert.AssertionError instanceof Error | |
util.inherits(assert.AssertionError, Error); | |
function replacer(key, value) { | |
if (util.isUndefined(value)) { | |
return '' + value; | |
} | |
if (util.isNumber(value) && (isNaN(value) || !isFinite(value))) { | |
return value.toString(); | |
} | |
if (util.isFunction(value) || util.isRegExp(value)) { | |
return value.toString(); | |
} | |
return value; | |
} | |
function truncate(s, n) { | |
if (util.isString(s)) { | |
return s.length < n ? s : s.slice(0, n); | |
} else { | |
return s; | |
} | |
} | |
function getMessage(self) { | |
return truncate(JSON.stringify(self.actual, replacer), 128) + ' ' + | |
self.operator + ' ' + | |
truncate(JSON.stringify(self.expected, replacer), 128); | |
} | |
// At present only the three keys mentioned above are used and | |
// understood by the spec. Implementations or sub modules can pass | |
// other keys to the AssertionError's constructor - they will be | |
// ignored. | |
// 3. All of the following functions must throw an AssertionError | |
// when a corresponding condition is not met, with a message that | |
// may be undefined if not provided. All assertion methods provide | |
// both the actual and expected values to the assertion error for | |
// display purposes. | |
function fail(actual, expected, message, operator, stackStartFunction) { | |
throw new assert.AssertionError({ | |
message: message, | |
actual: actual, | |
expected: expected, | |
operator: operator, | |
stackStartFunction: stackStartFunction | |
}); | |
} | |
// EXTENSION! allows for well behaved errors defined elsewhere. | |
assert.fail = fail; | |
// 4. Pure assertion tests whether a value is truthy, as determined | |
// by !!guard. | |
// assert.ok(guard, message_opt); | |
// This statement is equivalent to assert.equal(true, !!guard, | |
// message_opt);. To test strictly for the value true, use | |
// assert.strictEqual(true, guard, message_opt);. | |
function ok(value, message) { | |
if (!value) fail(value, true, message, '==', assert.ok); | |
} | |
assert.ok = ok; | |
// 5. The equality assertion tests shallow, coercive equality with | |
// ==. | |
// assert.equal(actual, expected, message_opt); | |
assert.equal = function equal(actual, expected, message) { | |
if (actual != expected) fail(actual, expected, message, '==', assert.equal); | |
}; | |
// 6. The non-equality assertion tests for whether two objects are not equal | |
// with != assert.notEqual(actual, expected, message_opt); | |
assert.notEqual = function notEqual(actual, expected, message) { | |
if (actual == expected) { | |
fail(actual, expected, message, '!=', assert.notEqual); | |
} | |
}; | |
// 7. The equivalence assertion tests a deep equality relation. | |
// assert.deepEqual(actual, expected, message_opt); | |
assert.deepEqual = function deepEqual(actual, expected, message) { | |
if (!_deepEqual(actual, expected)) { | |
fail(actual, expected, message, 'deepEqual', assert.deepEqual); | |
} | |
}; | |
function _deepEqual(actual, expected) { | |
// 7.1. All identical values are equivalent, as determined by ===. | |
if (actual === expected) { | |
return true; | |
} else if (util.isBuffer(actual) && util.isBuffer(expected)) { | |
if (actual.length != expected.length) return false; | |
for (var i = 0; i < actual.length; i++) { | |
if (actual[i] !== expected[i]) return false; | |
} | |
return true; | |
// 7.2. If the expected value is a Date object, the actual value is | |
// equivalent if it is also a Date object that refers to the same time. | |
} else if (util.isDate(actual) && util.isDate(expected)) { | |
return actual.getTime() === expected.getTime(); | |
// 7.3 If the expected value is a RegExp object, the actual value is | |
// equivalent if it is also a RegExp object with the same source and | |
// properties (`global`, `multiline`, `lastIndex`, `ignoreCase`). | |
} else if (util.isRegExp(actual) && util.isRegExp(expected)) { | |
return actual.source === expected.source && | |
actual.global === expected.global && | |
actual.multiline === expected.multiline && | |
actual.lastIndex === expected.lastIndex && | |
actual.ignoreCase === expected.ignoreCase; | |
// 7.4. Other pairs that do not both pass typeof value == 'object', | |
// equivalence is determined by ==. | |
} else if (!util.isObject(actual) && !util.isObject(expected)) { | |
return actual == expected; | |
// 7.5 For all other Object pairs, including Array objects, equivalence is | |
// determined by having the same number of owned properties (as verified | |
// with Object.prototype.hasOwnProperty.call), the same set of keys | |
// (although not necessarily the same order), equivalent values for every | |
// corresponding key, and an identical 'prototype' property. Note: this | |
// accounts for both named and indexed properties on Arrays. | |
} else { | |
return objEquiv(actual, expected); | |
} | |
} | |
function isArguments(object) { | |
return Object.prototype.toString.call(object) == '[object Arguments]'; | |
} | |
function objEquiv(a, b) { | |
if (util.isNullOrUndefined(a) || util.isNullOrUndefined(b)) | |
return false; | |
// an identical 'prototype' property. | |
if (a.prototype !== b.prototype) return false; | |
//~~~I've managed to break Object.keys through screwy arguments passing. | |
// Converting to array solves the problem. | |
if (isArguments(a)) { | |
if (!isArguments(b)) { | |
return false; | |
} | |
a = pSlice.call(a); | |
b = pSlice.call(b); | |
return _deepEqual(a, b); | |
} | |
try { | |
var ka = objectKeys(a), | |
kb = objectKeys(b), | |
key, i; | |
} catch (e) {//happens when one is a string literal and the other isn't | |
return false; | |
} | |
// having the same number of owned properties (keys incorporates | |
// hasOwnProperty) | |
if (ka.length != kb.length) | |
return false; | |
//the same set of keys (although not necessarily the same order), | |
ka.sort(); | |
kb.sort(); | |
//~~~cheap key test | |
for (i = ka.length - 1; i >= 0; i--) { | |
if (ka[i] != kb[i]) | |
return false; | |
} | |
//equivalent values for every corresponding key, and | |
//~~~possibly expensive deep test | |
for (i = ka.length - 1; i >= 0; i--) { | |
key = ka[i]; | |
if (!_deepEqual(a[key], b[key])) return false; | |
} | |
return true; | |
} | |
// 8. The non-equivalence assertion tests for any deep inequality. | |
// assert.notDeepEqual(actual, expected, message_opt); | |
assert.notDeepEqual = function notDeepEqual(actual, expected, message) { | |
if (_deepEqual(actual, expected)) { | |
fail(actual, expected, message, 'notDeepEqual', assert.notDeepEqual); | |
} | |
}; | |
// 9. The strict equality assertion tests strict equality, as determined by ===. | |
// assert.strictEqual(actual, expected, message_opt); | |
assert.strictEqual = function strictEqual(actual, expected, message) { | |
if (actual !== expected) { | |
fail(actual, expected, message, '===', assert.strictEqual); | |
} | |
}; | |
// 10. The strict non-equality assertion tests for strict inequality, as | |
// determined by !==. assert.notStrictEqual(actual, expected, message_opt); | |
assert.notStrictEqual = function notStrictEqual(actual, expected, message) { | |
if (actual === expected) { | |
fail(actual, expected, message, '!==', assert.notStrictEqual); | |
} | |
}; | |
function expectedException(actual, expected) { | |
if (!actual || !expected) { | |
return false; | |
} | |
if (Object.prototype.toString.call(expected) == '[object RegExp]') { | |
return expected.test(actual); | |
} else if (actual instanceof expected) { | |
return true; | |
} else if (expected.call({}, actual) === true) { | |
return true; | |
} | |
return false; | |
} | |
function _throws(shouldThrow, block, expected, message) { | |
var actual; | |
if (util.isString(expected)) { | |
message = expected; | |
expected = null; | |
} | |
try { | |
block(); | |
} catch (e) { | |
actual = e; | |
} | |
message = (expected && expected.name ? ' (' + expected.name + ').' : '.') + | |
(message ? ' ' + message : '.'); | |
if (shouldThrow && !actual) { | |
fail(actual, expected, 'Missing expected exception' + message); | |
} | |
if (!shouldThrow && expectedException(actual, expected)) { | |
fail(actual, expected, 'Got unwanted exception' + message); | |
} | |
if ((shouldThrow && actual && expected && | |
!expectedException(actual, expected)) || (!shouldThrow && actual)) { | |
throw actual; | |
} | |
} | |
// 11. Expected to throw an error: | |
// assert.throws(block, Error_opt, message_opt); | |
assert.throws = function(block, /*optional*/error, /*optional*/message) { | |
_throws.apply(this, [true].concat(pSlice.call(arguments))); | |
}; | |
// EXTENSION! This is annoying to write outside this module. | |
assert.doesNotThrow = function(block, /*optional*/message) { | |
_throws.apply(this, [false].concat(pSlice.call(arguments))); | |
}; | |
assert.ifError = function(err) { if (err) {throw err;}}; | |
var objectKeys = Object.keys || function (obj) { | |
var keys = []; | |
for (var key in obj) { | |
if (hasOwn.call(obj, key)) keys.push(key); | |
} | |
return keys; | |
}; | |
},{"util/":5}],2:[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 canMutationObserver = typeof window !== 'undefined' | |
&& window.MutationObserver; | |
var canPost = typeof window !== 'undefined' | |
&& window.postMessage && window.addEventListener | |
; | |
if (canSetImmediate) { | |
return function (f) { return window.setImmediate(f) }; | |
} | |
var queue = []; | |
if (canMutationObserver) { | |
var hiddenDiv = document.createElement("div"); | |
var observer = new MutationObserver(function () { | |
var queueList = queue.slice(); | |
queue.length = 0; | |
queueList.forEach(function (fn) { | |
fn(); | |
}); | |
}); | |
observer.observe(hiddenDiv, { attributes: true }); | |
return function nextTick(fn) { | |
if (!queue.length) { | |
hiddenDiv.setAttribute('yes', 'no'); | |
} | |
queue.push(fn); | |
}; | |
} | |
if (canPost) { | |
window.addEventListener('message', function (ev) { | |
var source = ev.source; | |
if ((source === window || source === null) && 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 = []; | |
function noop() {} | |
process.on = noop; | |
process.addListener = noop; | |
process.once = noop; | |
process.off = noop; | |
process.removeListener = noop; | |
process.removeAllListeners = noop; | |
process.emit = noop; | |
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'); | |
}; | |
},{}],3:[function(require,module,exports){ | |
if (typeof Object.create === 'function') { | |
// implementation from standard node.js 'util' module | |
module.exports = function inherits(ctor, superCtor) { | |
ctor.super_ = superCtor | |
ctor.prototype = Object.create(superCtor.prototype, { | |
constructor: { | |
value: ctor, | |
enumerable: false, | |
writable: true, | |
configurable: true | |
} | |
}); | |
}; | |
} else { | |
// old school shim for old browsers | |
module.exports = function inherits(ctor, superCtor) { | |
ctor.super_ = superCtor | |
var TempCtor = function () {} | |
TempCtor.prototype = superCtor.prototype | |
ctor.prototype = new TempCtor() | |
ctor.prototype.constructor = ctor | |
} | |
} | |
},{}],4:[function(require,module,exports){ | |
module.exports = function isBuffer(arg) { | |
return arg && typeof arg === 'object' | |
&& typeof arg.copy === 'function' | |
&& typeof arg.fill === 'function' | |
&& typeof arg.readUInt8 === 'function'; | |
} | |
},{}],5:[function(require,module,exports){ | |
(function (process,global){ | |
// Copyright Joyent, Inc. and other Node contributors. | |
// | |
// Permission is hereby granted, free of charge, to any person obtaining a | |
// copy of this software and associated documentation files (the | |
// "Software"), to deal in the Software without restriction, including | |
// without limitation the rights to use, copy, modify, merge, publish, | |
// distribute, sublicense, and/or sell copies of the Software, and to permit | |
// persons to whom the Software is furnished to do so, subject to the | |
// following conditions: | |
// | |
// The above copyright notice and this permission notice shall be included | |
// in all copies or substantial portions of the Software. | |
// | |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | |
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | |
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, | |
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | |
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE | |
// USE OR OTHER DEALINGS IN THE SOFTWARE. | |
var formatRegExp = /%[sdj%]/g; | |
exports.format = function(f) { | |
if (!isString(f)) { | |
var objects = []; | |
for (var i = 0; i < arguments.length; i++) { | |
objects.push(inspect(arguments[i])); | |
} | |
return objects.join(' '); | |
} | |
var i = 1; | |
var args = arguments; | |
var len = args.length; | |
var str = String(f).replace(formatRegExp, function(x) { | |
if (x === '%%') return '%'; | |
if (i >= len) return x; | |
switch (x) { | |
case '%s': return String(args[i++]); | |
case '%d': return Number(args[i++]); | |
case '%j': | |
try { | |
return JSON.stringify(args[i++]); | |
} catch (_) { | |
return '[Circular]'; | |
} | |
default: | |
return x; | |
} | |
}); | |
for (var x = args[i]; i < len; x = args[++i]) { | |
if (isNull(x) || !isObject(x)) { | |
str += ' ' + x; | |
} else { | |
str += ' ' + inspect(x); | |
} | |
} | |
return str; | |
}; | |
// Mark that a method should not be used. | |
// Returns a modified function which warns once by default. | |
// If --no-deprecation is set, then it is a no-op. | |
exports.deprecate = function(fn, msg) { | |
// Allow for deprecating things in the process of starting up. | |
if (isUndefined(global.process)) { | |
return function() { | |
return exports.deprecate(fn, msg).apply(this, arguments); | |
}; | |
} | |
if (process.noDeprecation === true) { | |
return fn; | |
} | |
var warned = false; | |
function deprecated() { | |
if (!warned) { | |
if (process.throwDeprecation) { | |
throw new Error(msg); | |
} else if (process.traceDeprecation) { | |
console.trace(msg); | |
} else { | |
console.error(msg); | |
} | |
warned = true; | |
} | |
return fn.apply(this, arguments); | |
} | |
return deprecated; | |
}; | |
var debugs = {}; | |
var debugEnviron; | |
exports.debuglog = function(set) { | |
if (isUndefined(debugEnviron)) | |
debugEnviron = process.env.NODE_DEBUG || ''; | |
set = set.toUpperCase(); | |
if (!debugs[set]) { | |
if (new RegExp('\\b' + set + '\\b', 'i').test(debugEnviron)) { | |
var pid = process.pid; | |
debugs[set] = function() { | |
var msg = exports.format.apply(exports, arguments); | |
console.error('%s %d: %s', set, pid, msg); | |
}; | |
} else { | |
debugs[set] = function() {}; | |
} | |
} | |
return debugs[set]; | |
}; | |
/** | |
* Echos the value of a value. Trys to print the value out | |
* in the best way possible given the different types. | |
* | |
* @param {Object} obj The object to print out. | |
* @param {Object} opts Optional options object that alters the output. | |
*/ | |
/* legacy: obj, showHidden, depth, colors*/ | |
function inspect(obj, opts) { | |
// default options | |
var ctx = { | |
seen: [], | |
stylize: stylizeNoColor | |
}; | |
// legacy... | |
if (arguments.length >= 3) ctx.depth = arguments[2]; | |
if (arguments.length >= 4) ctx.colors = arguments[3]; | |
if (isBoolean(opts)) { | |
// legacy... | |
ctx.showHidden = opts; | |
} else if (opts) { | |
// got an "options" object | |
exports._extend(ctx, opts); | |
} | |
// set default options | |
if (isUndefined(ctx.showHidden)) ctx.showHidden = false; | |
if (isUndefined(ctx.depth)) ctx.depth = 2; | |
if (isUndefined(ctx.colors)) ctx.colors = false; | |
if (isUndefined(ctx.customInspect)) ctx.customInspect = true; | |
if (ctx.colors) ctx.stylize = stylizeWithColor; | |
return formatValue(ctx, obj, ctx.depth); | |
} | |
exports.inspect = inspect; | |
// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics | |
inspect.colors = { | |
'bold' : [1, 22], | |
'italic' : [3, 23], | |
'underline' : [4, 24], | |
'inverse' : [7, 27], | |
'white' : [37, 39], | |
'grey' : [90, 39], | |
'black' : [30, 39], | |
'blue' : [34, 39], | |
'cyan' : [36, 39], | |
'green' : [32, 39], | |
'magenta' : [35, 39], | |
'red' : [31, 39], | |
'yellow' : [33, 39] | |
}; | |
// Don't use 'blue' not visible on cmd.exe | |
inspect.styles = { | |
'special': 'cyan', | |
'number': 'yellow', | |
'boolean': 'yellow', | |
'undefined': 'grey', | |
'null': 'bold', | |
'string': 'green', | |
'date': 'magenta', | |
// "name": intentionally not styling | |
'regexp': 'red' | |
}; | |
function stylizeWithColor(str, styleType) { | |
var style = inspect.styles[styleType]; | |
if (style) { | |
return '\u001b[' + inspect.colors[style][0] + 'm' + str + | |
'\u001b[' + inspect.colors[style][1] + 'm'; | |
} else { | |
return str; | |
} | |
} | |
function stylizeNoColor(str, styleType) { | |
return str; | |
} | |
function arrayToHash(array) { | |
var hash = {}; | |
array.forEach(function(val, idx) { | |
hash[val] = true; | |
}); | |
return hash; | |
} | |
function formatValue(ctx, value, recurseTimes) { | |
// Provide a hook for user-specified inspect functions. | |
// Check that value is an object with an inspect function on it | |
if (ctx.customInspect && | |
value && | |
isFunction(value.inspect) && | |
// Filter out the util module, it's inspect function is special | |
value.inspect !== exports.inspect && | |
// Also filter out any prototype objects using the circular check. | |
!(value.constructor && value.constructor.prototype === value)) { | |
var ret = value.inspect(recurseTimes, ctx); | |
if (!isString(ret)) { | |
ret = formatValue(ctx, ret, recurseTimes); | |
} | |
return ret; | |
} | |
// Primitive types cannot have properties | |
var primitive = formatPrimitive(ctx, value); | |
if (primitive) { | |
return primitive; | |
} | |
// Look up the keys of the object. | |
var keys = Object.keys(value); | |
var visibleKeys = arrayToHash(keys); | |
if (ctx.showHidden) { | |
keys = Object.getOwnPropertyNames(value); | |
} | |
// IE doesn't make error fields non-enumerable | |
// http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx | |
if (isError(value) | |
&& (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) { | |
return formatError(value); | |
} | |
// Some type of object without properties can be shortcutted. | |
if (keys.length === 0) { | |
if (isFunction(value)) { | |
var name = value.name ? ': ' + value.name : ''; | |
return ctx.stylize('[Function' + name + ']', 'special'); | |
} | |
if (isRegExp(value)) { | |
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); | |
} | |
if (isDate(value)) { | |
return ctx.stylize(Date.prototype.toString.call(value), 'date'); | |
} | |
if (isError(value)) { | |
return formatError(value); | |
} | |
} | |
var base = '', array = false, braces = ['{', '}']; | |
// Make Array say that they are Array | |
if (isArray(value)) { | |
array = true; | |
braces = ['[', ']']; | |
} | |
// Make functions say that they are functions | |
if (isFunction(value)) { | |
var n = value.name ? ': ' + value.name : ''; | |
base = ' [Function' + n + ']'; | |
} | |
// Make RegExps say that they are RegExps | |
if (isRegExp(value)) { | |
base = ' ' + RegExp.prototype.toString.call(value); | |
} | |
// Make dates with properties first say the date | |
if (isDate(value)) { | |
base = ' ' + Date.prototype.toUTCString.call(value); | |
} | |
// Make error with message first say the error | |
if (isError(value)) { | |
base = ' ' + formatError(value); | |
} | |
if (keys.length === 0 && (!array || value.length == 0)) { | |
return braces[0] + base + braces[1]; | |
} | |
if (recurseTimes < 0) { | |
if (isRegExp(value)) { | |
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); | |
} else { | |
return ctx.stylize('[Object]', 'special'); | |
} | |
} | |
ctx.seen.push(value); | |
var output; | |
if (array) { | |
output = formatArray(ctx, value, recurseTimes, visibleKeys, keys); | |
} else { | |
output = keys.map(function(key) { | |
return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array); | |
}); | |
} | |
ctx.seen.pop(); | |
return reduceToSingleString(output, base, braces); | |
} | |
function formatPrimitive(ctx, value) { | |
if (isUndefined(value)) | |
return ctx.stylize('undefined', 'undefined'); | |
if (isString(value)) { | |
var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '') | |
.replace(/'/g, "\\'") | |
.replace(/\\"/g, '"') + '\''; | |
return ctx.stylize(simple, 'string'); | |
} | |
if (isNumber(value)) | |
return ctx.stylize('' + value, 'number'); | |
if (isBoolean(value)) | |
return ctx.stylize('' + value, 'boolean'); | |
// For some reason typeof null is "object", so special case here. | |
if (isNull(value)) | |
return ctx.stylize('null', 'null'); | |
} | |
function formatError(value) { | |
return '[' + Error.prototype.toString.call(value) + ']'; | |
} | |
function formatArray(ctx, value, recurseTimes, visibleKeys, keys) { | |
var output = []; | |
for (var i = 0, l = value.length; i < l; ++i) { | |
if (hasOwnProperty(value, String(i))) { | |
output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, | |
String(i), true)); | |
} else { | |
output.push(''); | |
} | |
} | |
keys.forEach(function(key) { | |
if (!key.match(/^\d+$/)) { | |
output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, | |
key, true)); | |
} | |
}); | |
return output; | |
} | |
function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) { | |
var name, str, desc; | |
desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] }; | |
if (desc.get) { | |
if (desc.set) { | |
str = ctx.stylize('[Getter/Setter]', 'special'); | |
} else { | |
str = ctx.stylize('[Getter]', 'special'); | |
} | |
} else { | |
if (desc.set) { | |
str = ctx.stylize('[Setter]', 'special'); | |
} | |
} | |
if (!hasOwnProperty(visibleKeys, key)) { | |
name = '[' + key + ']'; | |
} | |
if (!str) { | |
if (ctx.seen.indexOf(desc.value) < 0) { | |
if (isNull(recurseTimes)) { | |
str = formatValue(ctx, desc.value, null); | |
} else { | |
str = formatValue(ctx, desc.value, recurseTimes - 1); | |
} | |
if (str.indexOf('\n') > -1) { | |
if (array) { | |
str = str.split('\n').map(function(line) { | |
return ' ' + line; | |
}).join('\n').substr(2); | |
} else { | |
str = '\n' + str.split('\n').map(function(line) { | |
return ' ' + line; | |
}).join('\n'); | |
} | |
} | |
} else { | |
str = ctx.stylize('[Circular]', 'special'); | |
} | |
} | |
if (isUndefined(name)) { | |
if (array && key.match(/^\d+$/)) { | |
return str; | |
} | |
name = JSON.stringify('' + key); | |
if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) { | |
name = name.substr(1, name.length - 2); | |
name = ctx.stylize(name, 'name'); | |
} else { | |
name = name.replace(/'/g, "\\'") | |
.replace(/\\"/g, '"') | |
.replace(/(^"|"$)/g, "'"); | |
name = ctx.stylize(name, 'string'); | |
} | |
} | |
return name + ': ' + str; | |
} | |
function reduceToSingleString(output, base, braces) { | |
var numLinesEst = 0; | |
var length = output.reduce(function(prev, cur) { | |
numLinesEst++; | |
if (cur.indexOf('\n') >= 0) numLinesEst++; | |
return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1; | |
}, 0); | |
if (length > 60) { | |
return braces[0] + | |
(base === '' ? '' : base + '\n ') + | |
' ' + | |
output.join(',\n ') + | |
' ' + | |
braces[1]; | |
} | |
return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1]; | |
} | |
// NOTE: These type checking functions intentionally don't use `instanceof` | |
// because it is fragile and can be easily faked with `Object.create()`. | |
function isArray(ar) { | |
return Array.isArray(ar); | |
} | |
exports.isArray = isArray; | |
function isBoolean(arg) { | |
return typeof arg === 'boolean'; | |
} | |
exports.isBoolean = isBoolean; | |
function isNull(arg) { | |
return arg === null; | |
} | |
exports.isNull = isNull; | |
function isNullOrUndefined(arg) { | |
return arg == null; | |
} | |
exports.isNullOrUndefined = isNullOrUndefined; | |
function isNumber(arg) { | |
return typeof arg === 'number'; | |
} | |
exports.isNumber = isNumber; | |
function isString(arg) { | |
return typeof arg === 'string'; | |
} | |
exports.isString = isString; | |
function isSymbol(arg) { | |
return typeof arg === 'symbol'; | |
} | |
exports.isSymbol = isSymbol; | |
function isUndefined(arg) { | |
return arg === void 0; | |
} | |
exports.isUndefined = isUndefined; | |
function isRegExp(re) { | |
return isObject(re) && objectToString(re) === '[object RegExp]'; | |
} | |
exports.isRegExp = isRegExp; | |
function isObject(arg) { | |
return typeof arg === 'object' && arg !== null; | |
} | |
exports.isObject = isObject; | |
function isDate(d) { | |
return isObject(d) && objectToString(d) === '[object Date]'; | |
} | |
exports.isDate = isDate; | |
function isError(e) { | |
return isObject(e) && | |
(objectToString(e) === '[object Error]' || e instanceof Error); | |
} | |
exports.isError = isError; | |
function isFunction(arg) { | |
return typeof arg === 'function'; | |
} | |
exports.isFunction = isFunction; | |
function isPrimitive(arg) { | |
return arg === null || | |
typeof arg === 'boolean' || | |
typeof arg === 'number' || | |
typeof arg === 'string' || | |
typeof arg === 'symbol' || // ES6 symbol | |
typeof arg === 'undefined'; | |
} | |
exports.isPrimitive = isPrimitive; | |
exports.isBuffer = require('./support/isBuffer'); | |
function objectToString(o) { | |
return Object.prototype.toString.call(o); | |
} | |
function pad(n) { | |
return n < 10 ? '0' + n.toString(10) : n.toString(10); | |
} | |
var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', | |
'Oct', 'Nov', 'Dec']; | |
// 26 Feb 16:19:34 | |
function timestamp() { | |
var d = new Date(); | |
var time = [pad(d.getHours()), | |
pad(d.getMinutes()), | |
pad(d.getSeconds())].join(':'); | |
return [d.getDate(), months[d.getMonth()], time].join(' '); | |
} | |
// log is just a thin wrapper to console.log that prepends a timestamp | |
exports.log = function() { | |
console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments)); | |
}; | |
/** | |
* Inherit the prototype methods from one constructor into another. | |
* | |
* The Function.prototype.inherits from lang.js rewritten as a standalone | |
* function (not on Function.prototype). NOTE: If this file is to be loaded | |
* during bootstrapping this function needs to be rewritten using some native | |
* functions as prototype setup using normal JavaScript does not work as | |
* expected during bootstrapping (see mirror.js in r114903). | |
* | |
* @param {function} ctor Constructor function which needs to inherit the | |
* prototype. | |
* @param {function} superCtor Constructor function to inherit prototype from. | |
*/ | |
exports.inherits = require('inherits'); | |
exports._extend = function(origin, add) { | |
// Don't do anything if add isn't an object | |
if (!add || !isObject(add)) return origin; | |
var keys = Object.keys(add); | |
var i = keys.length; | |
while (i--) { | |
origin[keys[i]] = add[keys[i]]; | |
} | |
return origin; | |
}; | |
function hasOwnProperty(obj, prop) { | |
return Object.prototype.hasOwnProperty.call(obj, prop); | |
} | |
}).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) | |
//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/util/util.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"]} | |
},{"./support/isBuffer":4,"_process":2,"inherits":3}],6:[function(require,module,exports){ | |
const assert = require('assert'); | |
const barracks = require('barracks'); | |
const duetLocation = require('duet-location'); | |
const duetVirtualDOM = require('duet-virtual-dom'); | |
const sheetRouter = require('sheet-router'); | |
module.exports = choo; | |
// framework for creating sturdy web applications | |
// null -> fn | |
function choo (opts) { | |
opts = opts || {}; | |
const _store = start._store = barracks(); | |
var _router = start._router = null; | |
var _defaultRoute = null; | |
var _update = null | |
var _routes = null; | |
var _frame = null; | |
_store.use({ onStateChange: render }); | |
_store.use(opts); | |
start.router = router; | |
start.model = model; | |
start.start = start; | |
start.use = use; | |
return start; | |
// start the application | |
// (str, obj?) -> null | |
function start (selector, startOpts) { | |
assert.equal(typeof selector, 'string', 'choo.start: selector should be an string'); | |
startOpts = startOpts || {}; | |
startOpts.vdom = startOpts.vdom || {}; | |
appInit(function (locationModel) { | |
_store.model(locationModel); | |
const createSend = _store.start(startOpts); | |
_router = start._router = createRouter(_defaultRoute, _routes, createSend); | |
const state = _store.state({state: {}}); | |
_update = duetVirtualDOM(selector, startOpts.vdom); | |
_update(_router(state.location.pathname, state)); | |
}, startOpts); | |
} | |
// initial application state model | |
// (fn, obj) -> null | |
function appInit (cb, opts) { | |
var _send; | |
var _done; | |
const subs = { | |
getRefs: function (send, done) { | |
_send = send; | |
_done = done; | |
} | |
}; | |
const reducers = { | |
setLocation: function setLocation (data, state) { | |
return { pathname: data.location }; | |
} | |
}; | |
duetLocation(function (pathname) { | |
if (_send != null) { | |
return _send('location:setLocation', { location: pathname }, _done); | |
} | |
cb({ | |
namespace: 'location', | |
subscriptions: subs, | |
reducers: reducers, | |
state: { | |
pathname: pathname | |
} | |
}); | |
_done(null); | |
}, opts.hash === true); | |
} | |
// update the DOM after every state mutation | |
// (obj, obj, obj, str, fn) -> null | |
function render (data, state, prev, name, createSend) { | |
_update(_router(state.location.pathname, state, prev)); | |
} | |
// register all routes on the router | |
// (str?, [fn|[fn]]) -> obj | |
function router (defaultRoute, routes) { | |
_defaultRoute = defaultRoute; | |
_routes = routes; | |
} | |
// create a new model | |
// (str?, obj) -> null | |
function model (model) { | |
_store.model(model); | |
} | |
// register a plugin | |
// (obj) -> null | |
function use (hooks) { | |
assert.equal(typeof hooks, 'object', 'choo.use: hooks should be an object'); | |
_store.use(hooks); | |
} | |
// create a new router with a custom `createRoute()` function | |
// (str?, obj, fn?) -> null | |
function createRouter (defaultRoute, routes, createSend) { | |
var prev = { params: {} }; | |
return sheetRouter(defaultRoute, routes, createRoute); | |
function createRoute (routeFn) { | |
return function (route, inline, child) { | |
if (typeof inline === 'function') { | |
inline = wrap(inline, route); | |
} | |
return routeFn(route, inline, child); | |
}; | |
function wrap (child, route) { | |
const send = createSend('view: ' + route, true); | |
return function chooWrap (params, state) { | |
const nwPrev = prev; | |
const nwState = prev = Object.assign({}, state, { params: params }); | |
if (opts.freeze !== false) { | |
Object.freeze(nwState); | |
} | |
return child(nwState, nwPrev, send); | |
}; | |
} | |
} | |
} | |
} | |
},{"assert":1,"barracks":8,"duet-location":12,"duet-virtual-dom":18,"sheet-router":47}],7:[function(require,module,exports){ | |
module.exports = applyHook | |
// apply arguments onto an array of functions, useful for hooks | |
// (arr, any?, any?, any?, any?, any?) -> null | |
function applyHook (arr, arg1, arg2, arg3, arg4, arg5) { | |
arr.forEach(function (fn) { | |
fn(arg1, arg2, arg3, arg4, arg5) | |
}) | |
} | |
},{}],8:[function(require,module,exports){ | |
const mutate = require('xtend/mutable') | |
const assert = require('assert') | |
const xtend = require('xtend') | |
const applyHook = require('./apply-hook') | |
module.exports = dispatcher | |
// initialize a new barracks instance | |
// obj -> obj | |
function dispatcher (hooks) { | |
hooks = hooks || {} | |
assert.equal(typeof hooks, 'object', 'barracks: hooks should be undefined or an object') | |
const onStateChangeHooks = [] | |
const onActionHooks = [] | |
const onErrorHooks = [] | |
const subscriptionWraps = [] | |
const initialStateWraps = [] | |
const reducerWraps = [] | |
const effectWraps = [] | |
use(hooks) | |
var reducersCalled = false | |
var effectsCalled = false | |
var stateCalled = false | |
var subsCalled = false | |
const subscriptions = start._subscriptions = {} | |
const reducers = start._reducers = {} | |
const effects = start._effects = {} | |
const models = start._models = [] | |
var _state = {} | |
start.model = setModel | |
start.state = getState | |
start.start = start | |
start.use = use | |
return start | |
// push an object of hooks onto an array | |
// obj -> null | |
function use (hooks) { | |
assert.equal(typeof hooks, 'object', 'barracks.use: hooks should be an object') | |
assert.ok(!hooks.onError || typeof hooks.onError === 'function', 'barracks.use: onError should be undefined or a function') | |
assert.ok(!hooks.onAction || typeof hooks.onAction === 'function', 'barracks.use: onAction should be undefined or a function') | |
assert.ok(!hooks.onStateChange || typeof hooks.onStateChange === 'function', 'barracks.use: onStateChange should be undefined or a function') | |
if (hooks.onStateChange) onStateChangeHooks.push(hooks.onStateChange) | |
if (hooks.onError) onErrorHooks.push(wrapOnError(hooks.onError)) | |
if (hooks.onAction) onActionHooks.push(hooks.onAction) | |
if (hooks.wrapSubscriptions) subscriptionWraps.push(hooks.wrapSubscriptions) | |
if (hooks.wrapInitialState) initialStateWraps.push(hooks.wrapInitialState) | |
if (hooks.wrapReducers) reducerWraps.push(hooks.wrapReducers) | |
if (hooks.wrapEffects) effectWraps.push(hooks.wrapEffects) | |
} | |
// push a model to be initiated | |
// obj -> null | |
function setModel (model) { | |
assert.equal(typeof model, 'object', 'barracks.store.model: model should be an object') | |
models.push(model) | |
} | |
// get the current state from the store | |
// obj? -> obj | |
function getState (opts) { | |
opts = opts || {} | |
assert.equal(typeof opts, 'object', 'barracks.store.state: opts should be an object') | |
const state = opts.state | |
if (!opts.state && opts.freeze === false) return xtend(_state) | |
else if (!opts.state) return Object.freeze(xtend(_state)) | |
assert.equal(typeof state, 'object', 'barracks.store.state: state should be an object') | |
const namespaces = [] | |
const newState = {} | |
// apply all fields from the model, and namespaced fields from the passed | |
// in state | |
models.forEach(function (model) { | |
const ns = model.namespace | |
namespaces.push(ns) | |
const modelState = model.state || {} | |
if (ns) { | |
newState[ns] = newState[ns] || {} | |
apply(ns, modelState, newState) | |
newState[ns] = xtend(newState[ns], state[ns]) | |
} else { | |
mutate(newState, modelState) | |
} | |
}) | |
// now apply all fields that weren't namespaced from the passed in state | |
Object.keys(state).forEach(function (key) { | |
if (namespaces.indexOf(key) !== -1) return | |
newState[key] = state[key] | |
}) | |
const tmpState = xtend(_state, xtend(state, newState)) | |
const wrappedState = wrapHook(tmpState, initialStateWraps) | |
return (opts.freeze === false) | |
? wrappedState | |
: Object.freeze(wrappedState) | |
} | |
// initialize the store hooks, get the send() function | |
// obj? -> fn | |
function start (opts) { | |
opts = opts || {} | |
assert.equal(typeof opts, 'object', 'barracks.store.start: opts should be undefined or an object') | |
// register values from the models | |
models.forEach(function (model) { | |
const ns = model.namespace | |
if (!stateCalled && model.state && opts.state !== false) { | |
const modelState = model.state || {} | |
if (ns) { | |
_state[ns] = _state[ns] || {} | |
apply(ns, modelState, _state) | |
} else { | |
mutate(_state, modelState) | |
} | |
} | |
if (!reducersCalled && model.reducers && opts.reducers !== false) { | |
apply(ns, model.reducers, reducers, function (cb) { | |
return wrapHook(cb, reducerWraps) | |
}) | |
} | |
if (!effectsCalled && model.effects && opts.effects !== false) { | |
apply(ns, model.effects, effects, function (cb) { | |
return wrapHook(cb, effectWraps) | |
}) | |
} | |
if (!subsCalled && model.subscriptions && opts.subscriptions !== false) { | |
apply(ns, model.subscriptions, subscriptions, function (cb, key) { | |
const send = createSend('subscription: ' + (ns ? ns + ':' + key : key)) | |
cb = wrapHook(cb, subscriptionWraps) | |
cb(send, function (err) { | |
applyHook(onErrorHooks, err, _state, createSend) | |
}) | |
return cb | |
}) | |
} | |
}) | |
// the state wrap is special because we want to operate on the full | |
// state rather than indvidual chunks, so we apply it outside the loop | |
if (!stateCalled && opts.state !== false) { | |
_state = wrapHook(_state, initialStateWraps) | |
} | |
if (!opts.noSubscriptions) subsCalled = true | |
if (!opts.noReducers) reducersCalled = true | |
if (!opts.noEffects) effectsCalled = true | |
if (!opts.noState) stateCalled = true | |
if (!onErrorHooks.length) onErrorHooks.push(wrapOnError(defaultOnError)) | |
return createSend | |
// call an action from a view | |
// (str, bool?) -> (str, any?, fn?) -> null | |
function createSend (selfName, callOnError) { | |
assert.equal(typeof selfName, 'string', 'barracks.store.start.createSend: selfName should be a string') | |
assert.ok(!callOnError || typeof callOnError === 'boolean', 'barracks.store.start.send: callOnError should be undefined or a boolean') | |
return function send (name, data, cb) { | |
if (!cb && !callOnError) { | |
cb = data | |
data = null | |
} | |
data = (typeof data === 'undefined' ? null : data) | |
assert.equal(typeof name, 'string', 'barracks.store.start.send: name should be a string') | |
assert.ok(!cb || typeof cb === 'function', 'barracks.store.start.send: cb should be a function') | |
const done = callOnError ? onErrorCallback : cb | |
_send(name, data, selfName, done) | |
function onErrorCallback (err) { | |
err = err || null | |
if (err) { | |
applyHook(onErrorHooks, err, _state, function createSend (selfName) { | |
return function send (name, data) { | |
assert.equal(typeof name, 'string', 'barracks.store.start.send: name should be a string') | |
data = (typeof data === 'undefined' ? null : data) | |
_send(name, data, selfName, done) | |
} | |
}) | |
} | |
} | |
} | |
} | |
// call an action | |
// (str, str, any, fn) -> null | |
function _send (name, data, caller, cb) { | |
assert.equal(typeof name, 'string', 'barracks._send: name should be a string') | |
assert.equal(typeof caller, 'string', 'barracks._send: caller should be a string') | |
assert.equal(typeof cb, 'function', 'barracks._send: cb should be a function') | |
setTimeout(function () { | |
var reducersCalled = false | |
var effectsCalled = false | |
const newState = xtend(_state) | |
if (onActionHooks.length) { | |
applyHook(onActionHooks, data, _state, name, caller, createSend) | |
} | |
// validate if a namespace exists. Namespaces are delimited by ':'. | |
var actionName = name | |
if (/:/.test(name)) { | |
const arr = name.split(':') | |
var ns = arr.shift() | |
actionName = arr.join(':') | |
} | |
const _reducers = ns ? reducers[ns] : reducers | |
if (_reducers && _reducers[actionName]) { | |
if (ns) { | |
const reducedState = _reducers[actionName](data, _state[ns]) | |
newState[ns] = xtend(_state[ns], reducedState) | |
} else { | |
mutate(newState, reducers[actionName](data, _state)) | |
} | |
reducersCalled = true | |
if (onStateChangeHooks.length) { | |
applyHook(onStateChangeHooks, data, newState, _state, actionName, createSend) | |
} | |
_state = newState | |
cb(null, newState) | |
} | |
const _effects = ns ? effects[ns] : effects | |
if (!reducersCalled && _effects && _effects[actionName]) { | |
const send = createSend('effect: ' + name) | |
if (ns) _effects[actionName](data, _state[ns], send, cb) | |
else _effects[actionName](data, _state, send, cb) | |
effectsCalled = true | |
} | |
if (!reducersCalled && !effectsCalled) { | |
throw new Error('Could not find action ' + actionName) | |
} | |
}, 0) | |
} | |
} | |
} | |
// compose an object conditionally | |
// optionally contains a namespace | |
// which is used to nest properties. | |
// (str, obj, obj, fn?) -> null | |
function apply (ns, source, target, wrap) { | |
if (ns && !target[ns]) target[ns] = {} | |
Object.keys(source).forEach(function (key) { | |
const cb = wrap ? wrap(source[key], key) : source[key] | |
if (ns) target[ns][key] = cb | |
else target[key] = cb | |
}) | |
} | |
// handle errors all the way at the top of the trace | |
// err? -> null | |
function defaultOnError (err) { | |
throw err | |
} | |
function wrapOnError (onError) { | |
return function onErrorWrap (err, state, createSend) { | |
if (err) onError(err, state, createSend) | |
} | |
} | |
// take a apply an array of transforms onto a value. The new value | |
// must be returned synchronously from the transform | |
// (any, [fn]) -> any | |
function wrapHook (value, transforms) { | |
transforms.forEach(function (transform) { | |
value = transform(value) | |
}) | |
return value | |
} | |
},{"./apply-hook":7,"assert":1,"xtend":9,"xtend/mutable":10}],9:[function(require,module,exports){ | |
module.exports = extend | |
var hasOwnProperty = Object.prototype.hasOwnProperty; | |
function extend() { | |
var target = {} | |
for (var i = 0; i < arguments.length; i++) { | |
var source = arguments[i] | |
for (var key in source) { | |
if (hasOwnProperty.call(source, key)) { | |
target[key] = source[key] | |
} | |
} | |
} | |
return target | |
} | |
},{}],10:[function(require,module,exports){ | |
module.exports = extend | |
var hasOwnProperty = Object.prototype.hasOwnProperty; | |
function extend(target) { | |
for (var i = 1; i < arguments.length; i++) { | |
var source = arguments[i] | |
for (var key in source) { | |
if (hasOwnProperty.call(source, key)) { | |
target[key] = source[key] | |
} | |
} | |
} | |
return target | |
} | |
},{}],11:[function(require,module,exports){ | |
var duetChannel = require('duet-channel'); | |
function onclick(event) { | |
if (event.target.localName !== 'a' || | |
event.target.href === undefined || | |
window.location.host !== event.target.host) { | |
return; | |
} | |
event.preventDefault(); | |
channel.postMessageToWorker({ | |
type: 'CHANGE', | |
data: event.target.href | |
}); | |
window.history.pushState({}, null, event.target.href) | |
} | |
function onpopstate() { | |
channel.postMessageToWorker({ | |
type: 'CHANGE', | |
data: document.location.href | |
}); | |
} | |
function connected(counterpartName) { | |
if (counterpartName !== 'main') { | |
return; | |
} | |
window.onclick = onclick; | |
window.onpopstate = onpopstate; | |
} | |
var channel = duetChannel('LOCATION', connected); | |
module.exports = channel; | |
},{"duet-channel":13}],12:[function(require,module,exports){ | |
var hashMatch = require('hash-match'); | |
var pathnameMatch = require('pathname-match'); | |
var channel = require('./channel'); | |
var subscribers = []; | |
function subscribe(callback, isHashSubscriber) { | |
if (typeof callback !== 'function') { | |
return; | |
} | |
subscribers.push({ | |
callback: callback, | |
isHashSubscriber: !!isHashSubscriber | |
}) | |
channel.postMessageToMain({ | |
type: 'SUBSCRIBER', | |
data: subscribers.length - 1 | |
}); | |
} | |
function parseLocation(href) { | |
var path, hash, splitHREF; | |
path = pathnameMatch(href); | |
if (!path.length) { | |
path = '/'; | |
} | |
hash = ''; | |
splitHREF = href.split('#'); | |
if (splitHREF.length > 1) { | |
hash = hashMatch('#'.concat(splitHREF.slice(1).join('#'))); | |
} | |
return { | |
path: path, | |
hash: hash | |
} | |
} | |
function notify(subscriber, location) { | |
if (!subscriber.isHashSubscriber) { | |
subscriber.callback(location.path); | |
} else if (location.hash) { | |
subscriber.callback(location.hash); | |
} | |
} | |
function notifyAll(location) { | |
subscribers.forEach(function (subscriber) { | |
notify(subscriber, location); | |
}); | |
} | |
function onSubscriber(data) { | |
channel.postMessageToWorker({ | |
type: 'INITIAL', | |
data: { | |
subscriberKey: data, | |
href: document.location.href | |
} | |
}); | |
} | |
function onInitial(data) { | |
notify(subscribers[data.subscriberKey], parseLocation(data.href)); | |
} | |
function onChange(data) { | |
if (subscribers.length > 0) { | |
notifyAll(parseLocation(data)); | |
} | |
} | |
channel.on('SUBSCRIBER', onSubscriber); | |
channel.on('INITIAL', onInitial); | |
channel.on('CHANGE', onChange); | |
module.exports = subscribe; | |
},{"./channel":11,"hash-match":14,"pathname-match":15}],13:[function(require,module,exports){ | |
module.exports = function duetChannel(namespace, callback) { | |
var _postMessageToMain = null; | |
var _postMessageToWorker = null; | |
var mainQueue = []; | |
var workerQueue = []; | |
var messageHandlers = {}; | |
function connectMain(postMessage) { | |
_postMessageToWorker = postMessage; | |
if (typeof callback === 'function') { | |
callback('main'); | |
} | |
while (workerQueue.length) { | |
_postMessageToWorker(workerQueue.shift()); | |
} | |
workerQueue = null; | |
} | |
function connectWorker(postMessage) { | |
_postMessageToMain = postMessage; | |
if (typeof callback === 'function') { | |
callback('worker'); | |
} | |
while (mainQueue.length) { | |
_postMessageToMain(mainQueue.shift()); | |
} | |
mainQueue = null; | |
} | |
function postMessageToMain(message) { | |
if (typeof _postMessageToMain === 'function') { | |
return _postMessageToMain(message); | |
} | |
mainQueue.push(message); | |
} | |
function postMessageToWorker(message) { | |
if (typeof _postMessageToWorker === 'function') { | |
return _postMessageToWorker(message); | |
} | |
workerQueue.push(message); | |
} | |
function handleMessage(type, data) { | |
var messageHandler = messageHandlers[type]; | |
if (messageHandler != null) { | |
messageHandler(data); | |
} | |
} | |
function on(type, messageHandler) { | |
messageHandlers[type] = messageHandler; | |
} | |
return { | |
// Used by duet | |
namespace: namespace, | |
connectMain: connectMain, | |
connectWorker: connectWorker, | |
handleMessage: handleMessage, | |
// Used by plugin | |
postMessageToMain: postMessageToMain, | |
postMessageToWorker: postMessageToWorker, | |
on: on | |
}; | |
}; | |
},{}],14:[function(require,module,exports){ | |
module.exports = function hashMatch (hash, prefix) { | |
var pre = prefix || '/'; | |
if (hash.length === 0) return pre; | |
hash = hash.replace('#', ''); | |
hash = hash.replace(/\/$/, '') | |
if (hash.indexOf('/') != 0) hash = '/' + hash; | |
if (pre == '/') return hash; | |
else return hash.replace(pre, ''); | |
} | |
},{}],15:[function(require,module,exports){ | |
const assert = require('assert') | |
module.exports = match | |
// get url path section from a url | |
// strip querystrings / hashes | |
// strip protocol | |
// strip hostname and port (both ip and route) | |
// str -> str | |
function match (route) { | |
assert.equal(typeof route, 'string') | |
return route.trim() | |
.replace(/[\?|#].*$/, '') | |
.replace(/^(?:https?\:)\/\//, '') | |
.replace(/^.*?(\/.*)/, '$1') | |
.replace(/\/$/, '') | |
} | |
},{"assert":1}],16:[function(require,module,exports){ | |
module.exports = require('duet-channel')('VIRTUAL_DOM'); | |
},{"duet-channel":19}],17:[function(require,module,exports){ | |
// https://developer.mozilla.org/en-US/docs/Web/Events | |
module.exports = [ | |
// CSSOM | |
'animationend', | |
'animationiteration', | |
'animationstart', | |
'transitionend', | |
// DOM | |
'abort', | |
'beforeinput', | |
'blur', | |
'click', | |
'compositionend', | |
'compositionstart', | |
'compositionupdate', | |
'dblclick', | |
'error', | |
'focus', | |
'focusin', | |
'focusout', | |
'input', | |
'keydown', | |
'keyup', | |
'load', | |
'mousedown', | |
'mouseenter', | |
'mouseleave', | |
'mousemove', | |
'mouseout', | |
'mouseover', | |
'mouseup', | |
'resize', | |
'scroll', | |
'select', | |
'unload', | |
'wheel', | |
// HTML DOM | |
'DOMContentLoaded', | |
// 'abort', | |
'afterprint', | |
'afterscriptexecute', | |
'autocomplete', | |
'autocompleteerror', | |
'beforeprint', | |
'beforescriptexecute', | |
'beforeunload', | |
// 'blur', | |
'cancel', | |
'canplay', | |
'canplaythrough', | |
'change', | |
// 'click', | |
'close', | |
'connect', | |
'contextmenu', | |
'durationchange', | |
'emptied', | |
'error', | |
// 'focus', | |
'hashchange', | |
// 'input', | |
'invalid', | |
'languagechange', | |
// 'load', | |
'loadeddata', | |
'loadedmetadata', | |
'loadend', | |
'loadstart', | |
'message', | |
'offline', | |
'online', | |
'open', | |
'pagehide', | |
'pageshow', | |
'play', | |
'playing', | |
'popstate', | |
'progress', | |
'readystatechange', | |
'reset', | |
'seeked', | |
'seeking', | |
'select', | |
'show', | |
'sort', | |
'stalled', | |
'storage', | |
'submit', | |
'suspend', | |
'timeupdate', | |
'toggle', | |
// 'unload', | |
'volumechange', | |
'waiting', | |
// HTML Drag and Drop API | |
'drag', | |
'dragend', | |
'dragenter', | |
'dragexit', | |
'dragleave', | |
'dragover', | |
'dragstart', | |
'drop', | |
// Pointer | |
'gotpointercapture', | |
'lostpointercapture', | |
'pointercancel', | |
'pointerdown', | |
'pointerenter', | |
'pointerleave', | |
'pointermove', | |
'pointerout', | |
'pointerover', | |
'pointerup', | |
// Selection | |
'selectionchange', | |
'selectstart', | |
// Touch | |
'touchcancel', | |
'touchend', | |
'touchmove', | |
'touchstart' | |
]; | |
},{}],18:[function(require,module,exports){ | |
var walk = require('tree-walk'); | |
var VirtualNode = require('virtual-dom/vnode/vnode'); | |
var diff = require('virtual-dom/diff'); | |
var serialize = require('vdom-serialized-patch/serialize'); | |
var patch = require('vdom-serialized-patch/patch'); | |
var getFormData = require('form-data-set/element'); | |
var channel = require('./channel'); | |
var eventNames = require('./eventNames'); | |
var concat = Array.prototype.concat; | |
var nextStoreKey = 0; | |
var store = {}; | |
function vdom(selector, options) { | |
var key = nextStoreKey++; | |
options = typeof options === 'object' ? options : {}; | |
store[key] = { | |
tree: new VirtualNode('div'), | |
eventHandlers: [] | |
}; | |
channel.postMessageToMain({ | |
type: 'CREATE', | |
data: { | |
key: key, | |
selector: selector, | |
isTarget: !!options.isTarget | |
} | |
}); | |
if (options.tree) { | |
update(key, options.tree); | |
} | |
return update.bind(null, key); | |
} | |
function update(key, tree) { | |
var stored, serializedDiff; | |
stored = store[key]; | |
stored.eventHandlers.length = 0; | |
walk.preorder(tree, function (value, key, parent) { | |
if (eventNames.indexOf(key) > -1) { | |
parent[key] = stored.eventHandlers.length; | |
stored.eventHandlers.push(value); | |
} | |
}); | |
serializedDiff = serialize(diff(stored.tree, tree)); | |
stored.tree = tree; | |
channel.postMessageToMain({ | |
type: 'PATCH', | |
data: { | |
key: key, | |
diff: serializedDiff | |
} | |
}); | |
} | |
function primitivePropsReducer(obj, atObj, props, key) { | |
var value; | |
try { | |
value = obj[key]; | |
} catch (e) { | |
return props; | |
} | |
if (key.charAt(0) === key.charAt(0).toLowerCase() && ( | |
typeof value === 'number' || | |
typeof value === 'string' || | |
typeof value === 'boolean')) { | |
props[key] = value; | |
} | |
return props; | |
} | |
function getPrimitiveProps(obj, atObj) { | |
var props = {}; | |
if (atObj) { | |
return Object.keys(atObj).reduce(primitivePropsReducer.bind(null, obj, atObj), props); | |
} | |
for (key in obj) { | |
props = primitivePropsReducer(obj, obj, props, key); | |
} | |
return props; | |
} | |
function eventListener(key, eventName, event) { | |
var target, handlerKey, eventData, valueData; | |
target = event.target; | |
while ((handlerKey = target.dataset[eventName]) == null && target !== document.documentElement) { | |
target = target.parentElement; | |
} | |
if (typeof handlerKey === 'string') { | |
setTimeout(function () { | |
eventData = getPrimitiveProps(event, event.constructor.prototype); | |
eventData.target = getPrimitiveProps(target, Element); | |
valueData = getFormData(target); | |
if (!(new RegExp('\\b' + eventName + '\\b')).test(target.dataset.preventDefault)) { | |
event.preventDefault(); | |
} | |
channel.postMessageToWorker({ | |
type: 'EVENT', | |
data: { | |
key: key, | |
handlerKey: handlerKey, | |
eventData: eventData, | |
valueData: valueData | |
} | |
}); | |
}, 0); | |
} | |
} | |
function updateDom(data) { | |
var stored, activeEventNames, activeElement; | |
function updateActiveEventsForDataAttributes(el) { | |
Object.keys(el.dataset) | |
.forEach(updateActiveEventsForDataAttribute); | |
} | |
function updateActiveEventsForDataAttribute(propName) { | |
if (eventNames.indexOf(propName) > -1 && activeEventNames.indexOf(propName) < 0) { | |
activeEventNames.push(propName); | |
} | |
} | |
function listenTo(eventName) { | |
stored.eventListeners[eventName] = eventListener.bind(null, data.key, eventName); | |
stored.target.addEventListener(eventName, stored.eventListeners[eventName]); | |
} | |
function unlistenTo(eventName) { | |
stored.target.removeEventListener(eventName, stored.eventListeners[eventName]); | |
delete stored.eventListeners[eventName]; | |
} | |
function updateEventBinding(eventName) { | |
if (activeEventNames.indexOf(eventName) > -1 && stored.eventListeners[eventName] == null) { | |
listenTo(eventName); | |
} else if (activeEventNames.indexOf(eventName) < 0 && stored.eventListeners[eventName] != null) { | |
unlistenTo(eventName); | |
} | |
} | |
stored = store[data.key]; | |
// 1) Patch DOM | |
stored.target = patch(stored.target, data.diff); | |
// 2) Update DOM event bindings | |
activeEventNames = []; | |
concat.apply(stored.target, stored.target.getElementsByTagName('*')) | |
.forEach(updateActiveEventsForDataAttributes); | |
eventNames.forEach(updateEventBinding); | |
// 3) Focus element if needed | |
activeElement = stored.target.querySelector('[autofocus]'); | |
if (activeElement != null && document.activeElement !== activeElement) { | |
activeElement.focus(); | |
} | |
} | |
function onCreate(data) { | |
var target, stored; | |
target = document.querySelector(data.selector); | |
if (target == null) { | |
throw new Error('selector did not match an element'); | |
} | |
stored = store[data.key]; | |
// When not single threaded | |
if (stored == null) { | |
store[data.key] = {}; | |
stored = store[data.key]; | |
} | |
if (!!data.isTarget) { | |
stored.target = target; | |
} else { | |
stored.target = document.createElement('div'); | |
target.insertBefore(stored.target, target.firstChild); | |
} | |
stored.eventListeners = {}; | |
} | |
function onPatch(data) { | |
window.requestAnimationFrame(updateDom.bind(null, data)); | |
} | |
function onEvent(data) { | |
var handler = store[data.key].eventHandlers[data.handlerKey]; | |
if (handler != null) { | |
handler(data.eventData, data.valueData); | |
} | |
} | |
channel.on('CREATE', onCreate); | |
channel.on('PATCH', onPatch); | |
channel.on('EVENT', onEvent); | |
module.exports = vdom; | |
},{"./channel":16,"./eventNames":17,"form-data-set/element":20,"tree-walk":23,"vdom-serialized-patch/patch":42,"vdom-serialized-patch/serialize":43,"virtual-dom/diff":53,"virtual-dom/vnode/vnode":64}],19:[function(require,module,exports){ | |
arguments[4][13][0].apply(exports,arguments) | |
},{"dup":13}],20:[function(require,module,exports){ | |
var walk = require('dom-walk') | |
var FormData = require('./index.js') | |
module.exports = getFormData | |
function buildElems(rootElem) { | |
var hash = {} | |
if (rootElem.name) { | |
hash[rootElem.name] = rootElem | |
} | |
walk(rootElem, function (child) { | |
if (child.name) { | |
hash[child.name] = child | |
} | |
}) | |
return hash | |
} | |
function getFormData(rootElem) { | |
var elements = buildElems(rootElem) | |
return FormData(elements) | |
} | |
},{"./index.js":21,"dom-walk":22}],21:[function(require,module,exports){ | |
/*jshint maxcomplexity: 10*/ | |
module.exports = FormData | |
//TODO: Massive spec: http://www.whatwg.org/specs/web-apps/current-work/multipage/association-of-controls-and-forms.html#constructing-form-data-set | |
function FormData(elements) { | |
return Object.keys(elements).reduce(function (acc, key) { | |
var elem = elements[key] | |
acc[key] = valueOfElement(elem) | |
return acc | |
}, {}) | |
} | |
function valueOfElement(elem) { | |
if (typeof elem === "function") { | |
return elem() | |
} else if (containsRadio(elem)) { | |
var elems = toList(elem) | |
var checked = elems.filter(function (elem) { | |
return elem.checked | |
})[0] || null | |
return checked ? checked.value : null | |
} else if (Array.isArray(elem)) { | |
return elem.map(valueOfElement).filter(filterNull) | |
} else if (elem.tagName === undefined && elem.nodeType === undefined) { | |
return FormData(elem) | |
} else if (elem.tagName === "INPUT" && isChecked(elem)) { | |
if (elem.hasAttribute("value")) { | |
return elem.checked ? elem.value : null | |
} else { | |
return elem.checked | |
} | |
} else if (elem.tagName === "INPUT") { | |
return elem.value | |
} else if (elem.tagName === "TEXTAREA") { | |
return elem.value | |
} else if (elem.tagName === "SELECT") { | |
return elem.value | |
} | |
} | |
function isChecked(elem) { | |
return elem.type === "checkbox" || elem.type === "radio" | |
} | |
function containsRadio(value) { | |
if (value.tagName || value.nodeType) { | |
return false | |
} | |
var elems = toList(value) | |
return elems.some(function (elem) { | |
return elem.tagName === "INPUT" && elem.type === "radio" | |
}) | |
} | |
function toList(value) { | |
if (Array.isArray(value)) { | |
return value | |
} | |
return Object.keys(value).map(prop, value) | |
} | |
function prop(x) { | |
return this[x] | |
} | |
function filterNull(val) { | |
return val !== null | |
} | |
},{}],22:[function(require,module,exports){ | |
var slice = Array.prototype.slice | |
module.exports = iterativelyWalk | |
function iterativelyWalk(nodes, cb) { | |
if (!('length' in nodes)) { | |
nodes = [nodes] | |
} | |
nodes = slice.call(nodes) | |
while(nodes.length) { | |
var node = nodes.shift(), | |
ret = cb(node) | |
if (ret) { | |
return ret | |
} | |
if (node.childNodes && node.childNodes.length) { | |
nodes = slice.call(node.childNodes).concat(nodes) | |
} | |
} | |
} | |
},{}],23:[function(require,module,exports){ | |
// Copyright (c) 2014 Patrick Dubroy <[email protected]> | |
// This software is distributed under the terms of the MIT License. | |
'use strict'; | |
var extend = require('util-extend'), | |
WeakMap = require('./third_party/WeakMap'); // eslint-disable-line no-undef,no-native-reassign | |
// An internal object that can be returned from a visitor function to | |
// prevent a top-down walk from walking subtrees of a node. | |
var stopRecursion = {}; | |
// An internal object that can be returned from a visitor function to | |
// cause the walk to immediately stop. | |
var stopWalk = {}; | |
var hasOwnProp = Object.prototype.hasOwnProperty; | |
// Helpers | |
// ------- | |
function isElement(obj) { | |
return !!(obj && obj.nodeType === 1); | |
} | |
function isObject(obj) { | |
var type = typeof obj; | |
return type === 'function' || type === 'object' && !!obj; | |
} | |
function isString(obj) { | |
return Object.prototype.toString.call(obj) === '[object String]'; | |
} | |
function each(obj, predicate) { | |
for (var k in obj) { | |
if (obj.hasOwnProperty(k)) { | |
if (predicate(obj[k], k, obj)) | |
return false; | |
} | |
} | |
return true; | |
} | |
// Returns a copy of `obj` containing only the properties given by `keys`. | |
function pick(obj, keys) { | |
var result = {}; | |
for (var i = 0, length = keys.length; i < length; i++) { | |
var key = keys[i]; | |
if (key in obj) result[key] = obj[key]; | |
} | |
return result; | |
} | |
// Makes a shallow copy of `arr`, and adds `obj` to the end of the copy. | |
function copyAndPush(arr, obj) { | |
var result = arr.slice(); | |
result.push(obj); | |
return result; | |
} | |
// Implements the default traversal strategy: if `obj` is a DOM node, walk | |
// its DOM children; otherwise, walk all the objects it references. | |
function defaultTraversal(obj) { | |
return isElement(obj) ? obj.children : obj; | |
} | |
// Walk the tree recursively beginning with `root`, calling `beforeFunc` | |
// before visiting an objects descendents, and `afterFunc` afterwards. | |
// If `collectResults` is true, the last argument to `afterFunc` will be a | |
// collection of the results of walking the node's subtrees. | |
function walkImpl(root, traversalStrategy, beforeFunc, afterFunc, context, collectResults) { | |
return (function _walk(stack, value, key, parent) { | |
if (isObject(value) && stack.indexOf(value) >= 0) | |
throw new TypeError('A cycle was detected at ' + value); | |
if (beforeFunc) { | |
var result = beforeFunc.call(context, value, key, parent); | |
if (result === stopWalk) return stopWalk; | |
if (result === stopRecursion) return; // eslint-disable-line consistent-return | |
} | |
var subResults; | |
var target = traversalStrategy(value); | |
if (isObject(target) && Object.keys(target).length > 0) { | |
// Collect results from subtrees in the same shape as the target. | |
if (collectResults) subResults = Array.isArray(target) ? [] : {}; | |
var ok = each(target, function(obj, key) { | |
var result = _walk(copyAndPush(stack, value), obj, key, value); | |
if (result === stopWalk) return false; | |
if (subResults) subResults[key] = result; | |
}); | |
if (!ok) return stopWalk; | |
} | |
if (afterFunc) return afterFunc.call(context, value, key, parent, subResults); | |
})([], root); | |
} | |
// Internal helper providing the implementation for `pluck` and `pluckRec`. | |
function pluck(obj, propertyName, recursive) { | |
var results = []; | |
this.preorder(obj, function(value, key) { | |
if (!recursive && key === propertyName) | |
return stopRecursion; | |
if (hasOwnProp.call(value, propertyName)) | |
results[results.length] = value[propertyName]; | |
}); | |
return results; | |
} | |
function defineEnumerableProperty(obj, propName, getterFn) { | |
Object.defineProperty(obj, propName, { | |
enumerable: true, | |
get: getterFn | |
}); | |
} | |
// Returns an object containing the walk functions. If `traversalStrategy` | |
// is specified, it is a function determining how objects should be | |
// traversed. Given an object, it returns the object to be recursively | |
// walked. The default strategy is equivalent to `_.identity` for regular | |
// objects, and for DOM nodes it returns the node's DOM children. | |
function Walker(traversalStrategy) { | |
if (!(this instanceof Walker)) | |
return new Walker(traversalStrategy); | |
// There are two different strategy shorthands: if a single string is | |
// specified, treat the value of that property as the traversal target. | |
// If an array is specified, the traversal target is the node itself, but | |
// only the properties contained in the array will be traversed. | |
if (isString(traversalStrategy)) { | |
var prop = traversalStrategy; | |
traversalStrategy = function(node) { | |
if (isObject(node) && prop in node) return node[prop]; | |
}; | |
} else if (Array.isArray(traversalStrategy)) { | |
var props = traversalStrategy; | |
traversalStrategy = function(node) { | |
if (isObject(node)) return pick(node, props); | |
}; | |
} | |
this._traversalStrategy = traversalStrategy || defaultTraversal; | |
} | |
extend(Walker.prototype, { | |
STOP_RECURSION: stopRecursion, | |
// Performs a preorder traversal of `obj` and returns the first value | |
// which passes a truth test. | |
find: function(obj, visitor, context) { | |
var result; | |
this.preorder(obj, function(value, key, parent) { | |
if (visitor.call(context, value, key, parent)) { | |
result = value; | |
return stopWalk; | |
} | |
}, context); | |
return result; | |
}, | |
// Recursively traverses `obj` and returns all the elements that pass a | |
// truth test. `strategy` is the traversal function to use, e.g. `preorder` | |
// or `postorder`. | |
filter: function(obj, strategy, visitor, context) { | |
var results = []; | |
if (obj === null) return results; | |
strategy(obj, function(value, key, parent) { | |
if (visitor.call(context, value, key, parent)) results.push(value); | |
}, null, this._traversalStrategy); | |
return results; | |
}, | |
// Recursively traverses `obj` and returns all the elements for which a | |
// truth test fails. | |
reject: function(obj, strategy, visitor, context) { | |
return this.filter(obj, strategy, function(value, key, parent) { | |
return !visitor.call(context, value, key, parent); | |
}); | |
}, | |
// Produces a new array of values by recursively traversing `obj` and | |
// mapping each value through the transformation function `visitor`. | |
// `strategy` is the traversal function to use, e.g. `preorder` or | |
// `postorder`. | |
map: function(obj, strategy, visitor, context) { | |
var results = []; | |
strategy(obj, function(value, key, parent) { | |
results[results.length] = visitor.call(context, value, key, parent); | |
}, null, this._traversalStrategy); | |
return results; | |
}, | |
// Return the value of properties named `propertyName` reachable from the | |
// tree rooted at `obj`. Results are not recursively searched; use | |
// `pluckRec` for that. | |
pluck: function(obj, propertyName) { | |
return pluck.call(this, obj, propertyName, false); | |
}, | |
// Version of `pluck` which recursively searches results for nested objects | |
// with a property named `propertyName`. | |
pluckRec: function(obj, propertyName) { | |
return pluck.call(this, obj, propertyName, true); | |
}, | |
// Recursively traverses `obj` in a depth-first fashion, invoking the | |
// `visitor` function for each object only after traversing its children. | |
// `traversalStrategy` is intended for internal callers, and is not part | |
// of the public API. | |
postorder: function(obj, visitor, context, traversalStrategy) { | |
traversalStrategy = traversalStrategy || this._traversalStrategy; | |
walkImpl(obj, traversalStrategy, null, visitor, context); | |
}, | |
// Recursively traverses `obj` in a depth-first fashion, invoking the | |
// `visitor` function for each object before traversing its children. | |
// `traversalStrategy` is intended for internal callers, and is not part | |
// of the public API. | |
preorder: function(obj, visitor, context, traversalStrategy) { | |
traversalStrategy = traversalStrategy || this._traversalStrategy; | |
walkImpl(obj, traversalStrategy, visitor, null, context); | |
}, | |
// Builds up a single value by doing a post-order traversal of `obj` and | |
// calling the `visitor` function on each object in the tree. For leaf | |
// objects, the `memo` argument to `visitor` is the value of the `leafMemo` | |
// argument to `reduce`. For non-leaf objects, `memo` is a collection of | |
// the results of calling `reduce` on the object's children. | |
reduce: function(obj, visitor, leafMemo, context) { | |
var reducer = function(value, key, parent, subResults) { | |
return visitor(subResults || leafMemo, value, key, parent); | |
}; | |
return walkImpl(obj, this._traversalStrategy, null, reducer, context, true); | |
}, | |
// An 'attribute' is a value that is calculated by invoking a visitor | |
// function on a node. The first argument of the visitor is a collection | |
// of the attribute values for the node's children. These are calculated | |
// lazily -- in this way the visitor can decide in what order to visit the | |
// subtrees. | |
createAttribute: function(visitor, defaultValue, context) { | |
var self = this; | |
var memo = new WeakMap(); | |
function _visit(stack, value, key, parent) { | |
if (isObject(value) && stack.indexOf(value) >= 0) | |
throw new TypeError('A cycle was detected at ' + value); | |
if (memo.has(value)) | |
return memo.get(value); | |
var subResults; | |
var target = self._traversalStrategy(value); | |
if (isObject(target) && Object.keys(target).length > 0) { | |
subResults = {}; | |
each(target, function(child, k) { | |
defineEnumerableProperty(subResults, k, function() { | |
return _visit(copyAndPush(stack, value), child, k, value); | |
}); | |
}); | |
} | |
var result = visitor.call(context, subResults, value, key, parent); | |
memo.set(value, result); | |
return result; | |
} | |
return function(obj) { return _visit([], obj); }; | |
} | |
}); | |
var WalkerProto = Walker.prototype; | |
// Set up a few convenient aliases. | |
WalkerProto.each = WalkerProto.preorder; | |
WalkerProto.collect = WalkerProto.map; | |
WalkerProto.detect = WalkerProto.find; | |
WalkerProto.select = WalkerProto.filter; | |
// Export the walker constructor, but make it behave like an instance. | |
Walker._traversalStrategy = defaultTraversal; | |
module.exports = extend(Walker, WalkerProto); | |
},{"./third_party/WeakMap":25,"util-extend":24}],24:[function(require,module,exports){ | |
// Copyright Joyent, Inc. and other Node contributors. | |
// | |
// Permission is hereby granted, free of charge, to any person obtaining a | |
// copy of this software and associated documentation files (the | |
// "Software"), to deal in the Software without restriction, including | |
// without limitation the rights to use, copy, modify, merge, publish, | |
// distribute, sublicense, and/or sell copies of the Software, and to permit | |
// persons to whom the Software is furnished to do so, subject to the | |
// following conditions: | |
// | |
// The above copyright notice and this permission notice shall be included | |
// in all copies or substantial portions of the Software. | |
// | |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | |
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | |
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, | |
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | |
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE | |
// USE OR OTHER DEALINGS IN THE SOFTWARE. | |
module.exports = extend; | |
function extend(origin, add) { | |
// Don't do anything if add isn't an object | |
if (!add || typeof add !== 'object') return origin; | |
var keys = Object.keys(add); | |
var i = keys.length; | |
while (i--) { | |
origin[keys[i]] = add[keys[i]]; | |
} | |
return origin; | |
} | |
},{}],25:[function(require,module,exports){ | |
/* | |
* Copyright 2012 The Polymer Authors. All rights reserved. | |
* Use of this source code is governed by a BSD-style | |
* license that can be found in the LICENSE file. | |
*/ | |
if (typeof WeakMap === 'undefined') { | |
(function() { | |
var defineProperty = Object.defineProperty; | |
var counter = Date.now() % 1e9; | |
var WeakMap = function() { | |
this.name = '__st' + (Math.random() * 1e9 >>> 0) + (counter++ + '__'); | |
}; | |
WeakMap.prototype = { | |
set: function(key, value) { | |
var entry = key[this.name]; | |
if (entry && entry[0] === key) | |
entry[1] = value; | |
else | |
defineProperty(key, this.name, {value: [key, value], writable: true}); | |
return this; | |
}, | |
get: function(key) { | |
var entry; | |
return (entry = key[this.name]) && entry[0] === key ? | |
entry[1] : undefined; | |
}, | |
delete: function(key) { | |
var entry = key[this.name]; | |
if (!entry || entry[0] !== key) return false; | |
entry[0] = entry[1] = undefined; | |
return true; | |
}, | |
has: function(key) { | |
var entry = key[this.name]; | |
if (!entry) return false; | |
return entry[0] === key; | |
} | |
}; | |
module.exports = WeakMap; | |
})(); | |
} else { | |
module.exports = WeakMap; | |
} | |
},{}],26:[function(require,module,exports){ | |
var isObject = require('./isObject'); | |
var isSoftSetHook = require('./isSoftSetHook'); | |
module.exports = applyProperties; | |
function applyProperties(node, props, previous) { | |
for (var propName in props) { | |
var propValue = props[propName] | |
if (propValue === undefined) { | |
removeProperty(node, propName, previous); | |
} else if (isSoftSetHook(propValue)) { | |
removeProperty(node, propName, propValue, previous) | |
node[propName] = propValue.value | |
} else { | |
if (isObject(propValue)) { | |
patchObject(node, props, previous, propName, propValue); | |
} else { | |
node[propName] = propValue | |
} | |
} | |
} | |
} | |
function removeProperty(node, propName, previous) { | |
if (!previous) { | |
return | |
} | |
var previousValue = previous[propName] | |
if (propName === "attributes") { | |
for (var attrName in previousValue) { | |
node.removeAttribute(attrName) | |
} | |
} else if (propName === "style") { | |
for (var i in previousValue) { | |
node.style[i] = "" | |
} | |
} else if (typeof previousValue === "string") { | |
node[propName] = "" | |
} else { | |
node[propName] = null | |
} | |
} | |
function patchObject(node, props, previous, propName, propValue) { | |
var previousValue = previous ? previous[propName] : undefined | |
// Set attributes | |
if (propName === "attributes") { | |
for (var attrName in propValue) { | |
var attrValue = propValue[attrName] | |
if (attrValue === undefined) { | |
node.removeAttribute(attrName) | |
} else { | |
node.setAttribute(attrName, attrValue) | |
} | |
} | |
return | |
} | |
if (previousValue && isObject(previousValue) && | |
getPrototype(previousValue) !== getPrototype(propValue)) { | |
node[propName] = propValue | |
return | |
} | |
if (!isObject(node[propName])) { | |
node[propName] = {} | |
} | |
var replacer = propName === "style" ? "" : undefined | |
for (var k in propValue) { | |
var value = propValue[k] | |
node[propName][k] = (value === undefined) ? replacer : value | |
} | |
} | |
function getPrototype(value) { | |
// getPrototypeOf shim for older browsers | |
/* istanbul ignore else */ | |
if (Object.getPrototypeOf) { | |
return Object.getPrototypeOf(value) | |
} else { | |
return value.__proto__ || value.constructor.prototype; | |
} | |
} | |
},{"./isObject":30,"./isSoftSetHook":31}],27:[function(require,module,exports){ | |
var applyProperties = require("./applyProperties") | |
var isVText = require('./isVText'); | |
var isVNode = require('./isVNode'); | |
module.exports = createElement; | |
function createElement(vnode) { | |
var doc = document; | |
if (isVText(vnode)) { | |
return doc.createTextNode(vnode.x) // 'x' means 'text' | |
} else if (!isVNode(vnode)) { | |
return null | |
} | |
var node = (!vnode.n) ? // 'n' === 'namespace' | |
doc.createElement(vnode.tn) : // 'tn' === 'tagName' | |
doc.createElementNS(vnode.n, vnode.tn) | |
var props = vnode.p // 'p' === 'properties' | |
applyProperties(node, props) | |
var children = vnode.c // 'c' === 'children' | |
if (children) { | |
for (var i = 0; i < children.length; i++) { | |
var childNode = createElement(children[i]) | |
if (childNode) { | |
node.appendChild(childNode) | |
} | |
} | |
} | |
return node | |
} | |
},{"./applyProperties":26,"./isVNode":32,"./isVText":33}],28:[function(require,module,exports){ | |
// Maps a virtual DOM tree onto a real DOM tree in an efficient manner. | |
// We don't want to read all of the DOM nodes in the tree so we use | |
// the in-order tree indexing to eliminate recursion down certain branches. | |
// We only recurse into a DOM node if we know that it contains a child of | |
// interest. | |
var noChild = {} | |
module.exports = domIndex | |
function domIndex(rootNode, tree, indices, nodes) { | |
if (!indices || indices.length === 0) { | |
return {} | |
} else { | |
indices.sort(ascending) | |
return recurse(rootNode, tree, indices, nodes, 0) | |
} | |
} | |
function recurse(rootNode, tree, indices, nodes, rootIndex) { | |
nodes = nodes || {} | |
if (rootNode) { | |
if (indexInRange(indices, rootIndex, rootIndex)) { | |
nodes[rootIndex] = rootNode | |
} | |
var treeChildren = tree[0]; | |
if (treeChildren) { | |
var childNodes = rootNode.childNodes | |
for (var i = 0; i < treeChildren.length; i++) { | |
rootIndex += 1 | |
var vChild = treeChildren[i] || noChild | |
var nextIndex = rootIndex + (vChild[1] || 0) | |
// skip recursion down the tree if there are no nodes down here | |
if (indexInRange(indices, rootIndex, nextIndex)) { | |
recurse(childNodes[i], vChild, indices, nodes, rootIndex) | |
} | |
rootIndex = nextIndex | |
} | |
} | |
} | |
return nodes | |
} | |
// Binary search for an index in the interval [left, right] | |
function indexInRange(indices, left, right) { | |
if (indices.length === 0) { | |
return false | |
} | |
var minIndex = 0 | |
var maxIndex = indices.length - 1 | |
var currentIndex | |
var currentItem | |
while (minIndex <= maxIndex) { | |
currentIndex = ((maxIndex + minIndex) / 2) >> 0 | |
currentItem = indices[currentIndex] | |
if (minIndex === maxIndex) { | |
return currentItem >= left && currentItem <= right | |
} else if (currentItem < left) { | |
minIndex = currentIndex + 1 | |
} else if (currentItem > right) { | |
maxIndex = currentIndex - 1 | |
} else { | |
return true | |
} | |
} | |
return false; | |
} | |
function ascending(a, b) { | |
return a > b ? 1 : -1 | |
} | |
},{}],29:[function(require,module,exports){ | |
var patchRecursive = require('./patchRecursive'); | |
function patch(rootNode, patches) { | |
return patchRecursive(rootNode, patches); | |
} | |
module.exports = patch; | |
},{"./patchRecursive":35}],30:[function(require,module,exports){ | |
'use strict'; | |
module.exports = function isObject(x) { | |
return typeof x === "object" && x !== null; | |
}; | |
},{}],31:[function(require,module,exports){ | |
module.exports = isSoftSetHook | |
function isSoftSetHook(x) { | |
return x && typeof x === 'object' && typeof x.value !== 'undefined'; | |
} | |
},{}],32:[function(require,module,exports){ | |
module.exports = isVirtualNode | |
var types = require('./types'); | |
function isVirtualNode(x) { | |
return x && x.t === types.VirtualNode | |
} | |
},{"./types":36}],33:[function(require,module,exports){ | |
module.exports = isVirtualText | |
var types = require('./types'); | |
function isVirtualText(x) { | |
return x && x.t === types.VirtualTree; | |
} | |
},{"./types":36}],34:[function(require,module,exports){ | |
var applyProperties = require("./applyProperties"); | |
var patchTypes = require("../patchTypes"); | |
var render = require('./createElement'); | |
module.exports = applyPatch | |
function applyPatch(vpatch, domNode, patchRecursive) { | |
var type = vpatch[0] | |
var patch = vpatch[1] | |
var vNode = vpatch[2] | |
switch (type) { | |
case patchTypes.REMOVE: | |
return removeNode(domNode) | |
case patchTypes.INSERT: | |
return insertNode(domNode, patch) | |
case patchTypes.VTEXT: | |
return stringPatch(domNode, patch) | |
case patchTypes.VNODE: | |
return vNodePatch(domNode, patch) | |
case patchTypes.ORDER: | |
reorderChildren(domNode, patch) | |
return domNode | |
case patchTypes.PROPS: | |
applyProperties(domNode, patch, vNode.p) // 'p' === 'properties' | |
return domNode | |
case patchTypes.THUNK: | |
return replaceRoot(domNode, | |
patchRecursive(domNode, patch)) | |
default: | |
return domNode | |
} | |
} | |
function removeNode(domNode) { | |
var parentNode = domNode.parentNode | |
if (parentNode) { | |
parentNode.removeChild(domNode) | |
} | |
return null | |
} | |
function insertNode(parentNode, vNode) { | |
var newNode = render(vNode) | |
if (parentNode) { | |
parentNode.appendChild(newNode) | |
} | |
return parentNode | |
} | |
function stringPatch(domNode, vText) { | |
var newNode | |
if (domNode.nodeType === 3) { | |
domNode.replaceData(0, domNode.length, vText.x) // 'x' means 'text' | |
newNode = domNode | |
} else { | |
var parentNode = domNode.parentNode | |
newNode = render(vText) | |
if (parentNode && newNode !== domNode) { | |
parentNode.replaceChild(newNode, domNode) | |
} | |
} | |
return newNode | |
} | |
function vNodePatch(domNode, vNode) { | |
var parentNode = domNode.parentNode | |
var newNode = render(vNode) | |
if (parentNode && newNode !== domNode) { | |
parentNode.replaceChild(newNode, domNode) | |
} | |
return newNode | |
} | |
function reorderChildren(domNode, moves) { | |
var childNodes = domNode.childNodes | |
var keyMap = {} | |
var node | |
var remove | |
var insert | |
for (var i = 0; i < moves.removes.length; i++) { | |
remove = moves.removes[i] | |
node = childNodes[remove.from] | |
if (remove.key) { | |
keyMap[remove.key] = node | |
} | |
domNode.removeChild(node) | |
} | |
var length = childNodes.length | |
for (var j = 0; j < moves.inserts.length; j++) { | |
insert = moves.inserts[j] | |
node = keyMap[insert.key] | |
// this is the weirdest bug i've ever seen in webkit | |
domNode.insertBefore(node, insert.to >= length++ ? null : childNodes[insert.to]) | |
} | |
} | |
function replaceRoot(oldRoot, newRoot) { | |
if (oldRoot && newRoot && oldRoot !== newRoot && oldRoot.parentNode) { | |
oldRoot.parentNode.replaceChild(newRoot, oldRoot) | |
} | |
return newRoot; | |
} | |
},{"../patchTypes":37,"./applyProperties":26,"./createElement":27}],35:[function(require,module,exports){ | |
var domIndex = require("./domIndex") | |
var patchOp = require("./patchOp") | |
function patchRecursive(rootNode, patches) { | |
var indices = patchIndices(patches) | |
if (indices.length === 0) { | |
return rootNode | |
} | |
var index = domIndex(rootNode, patches.a, indices) | |
for (var i = 0; i < indices.length; i++) { | |
var nodeIndex = indices[i] | |
rootNode = applyPatch(rootNode, | |
index[nodeIndex], | |
patches[nodeIndex]) | |
} | |
return rootNode | |
} | |
function applyPatch(rootNode, domNode, patchList) { | |
if (!domNode) { | |
return rootNode | |
} | |
var newNode | |
for (var i = 0; i < patchList.length; i++) { | |
newNode = patchOp(patchList[i], domNode, patchRecursive) | |
if (domNode === rootNode) { | |
rootNode = newNode | |
} | |
} | |
return rootNode | |
} | |
function patchIndices(patches) { | |
var indices = [] | |
for (var key in patches) { | |
if (key !== "a") { | |
indices.push(Number(key)) | |
} | |
} | |
return indices | |
} | |
module.exports = patchRecursive; | |
},{"./domIndex":28,"./patchOp":34}],36:[function(require,module,exports){ | |
// copied from vdom-as-json/types.js | |
module.exports = { | |
VirtualTree: 1, | |
VirtualPatch: 2, | |
VirtualNode: 3, | |
SoftSetHook: 4 | |
}; | |
},{}],37:[function(require,module,exports){ | |
// original this was is-vpatch.js | |
module.exports = { | |
NONE: 0, | |
VTEXT: 1, | |
VNODE: 2, | |
WIDGET: 3, | |
PROPS: 4, | |
ORDER: 5, | |
INSERT: 6, | |
REMOVE: 7, | |
THUNK: 8 | |
}; | |
},{}],38:[function(require,module,exports){ | |
var patchTypes = require('../patchTypes'); | |
var toJson = require('vdom-as-json/toJson'); | |
// traverse the thing that the original patch structure called "a', | |
// i.e. the virtual tree representing the current node structure. | |
// this thing only really needs two properties - "children" and "count", | |
// so trim out everything else | |
function serializeCurrentNode(currentNode) { | |
var children = currentNode.children; | |
if (!children) { | |
return null; | |
} | |
var len = children.length; | |
var arr = new Array(len); | |
var i = -1; | |
while (++i < len) { | |
arr[i] = serializeCurrentNode(children[i]); | |
} | |
if (currentNode.count) { | |
return [arr, currentNode.count]; | |
} else { | |
return [arr]; | |
} | |
} | |
function serializeVirtualPatchOrPatches(vPatch) { | |
if (Array.isArray(vPatch)) { | |
var len = vPatch.length; | |
var res = new Array(len); | |
var i = -1; | |
while (++i < len) { | |
res[i] = serializeVirtualPatch(vPatch[i]); | |
} | |
return res; | |
} | |
return [serializeVirtualPatch(vPatch)]; | |
} | |
function serializeVirtualPatch(vPatch) { | |
var type = vPatch.type; | |
var res = [ | |
type, | |
vPatch.patch && vPatch.patch.a ? toJson(serializeRootPatch(vPatch.patch)) : toJson(vPatch.patch) | |
]; | |
if (type === patchTypes.PROPS) { | |
// this is the only time the vNode is needed | |
res.push({p: vPatch.vNode.properties}); // 'p' === 'properties' | |
} | |
return res; | |
} | |
function serializeRootPatch(patch) { | |
var outputRootNode = serializeCurrentNode(patch.a); | |
var res = { | |
a: outputRootNode | |
}; | |
for (var key in patch) { | |
if (key !== 'a') { | |
res[key] = serializeVirtualPatchOrPatches(patch[key]); | |
} | |
} | |
return res; | |
}; | |
module.exports = serializeRootPatch; | |
},{"../patchTypes":37,"vdom-as-json/toJson":41}],39:[function(require,module,exports){ | |
'use strict'; | |
var types = require('./types'); | |
var SoftSetHook = | |
require('virtual-dom/virtual-hyperscript/hooks/soft-set-hook'); | |
function arrayToJson(arr) { | |
var len = arr.length; | |
var i = -1; | |
var res = new Array(len); | |
while (++i < len) { | |
res[i] = toJson(arr[i]); | |
} | |
return res; | |
} | |
function plainObjectToJson(obj) { | |
var res = {}; | |
/* jshint -W089 */ | |
/* this is fine; these objects are always plain */ | |
for (var key in obj) { | |
var val = obj[key]; | |
res[key] = typeof val !== 'undefined' ? toJson(val) : val; | |
} | |
return res; | |
} | |
function virtualNodeToJson(obj) { | |
var res = { | |
// type | |
t: types.VirtualNode, | |
tn: obj.tagName | |
}; | |
if (Object.keys(obj.properties).length) { | |
res.p = plainObjectToJson(obj.properties); | |
} | |
if (obj.children.length) { | |
res.c = arrayToJson(obj.children); | |
} | |
if (obj.key) { | |
res.k = obj.key; | |
} | |
if (obj.namespace) { | |
res.n = obj.namespace; | |
} | |
return res; | |
} | |
function virtualTextToJson(obj) { | |
return { | |
// type | |
t: types.VirtualTree, | |
// text | |
x: obj.text | |
}; | |
} | |
function virtualPatchToJson(obj) { | |
var res = { | |
// type | |
t: types.VirtualPatch, | |
// patch type | |
pt: obj.type | |
}; | |
if (obj.vNode) { | |
res.v = toJson(obj.vNode); | |
} | |
if (obj.patch) { | |
res.p = toJson(obj.patch); | |
} | |
return res; | |
} | |
function softSetHookToJson(obj) { | |
return { | |
// type | |
t: types.SoftSetHook, | |
value: obj.value | |
}; | |
} | |
function objectToJson(obj) { | |
if ('patch' in obj && typeof obj.type === 'number') { | |
return virtualPatchToJson(obj); | |
} | |
if (obj.type === 'VirtualNode') { | |
return virtualNodeToJson(obj); | |
} | |
if (obj.type === 'VirtualText') { | |
return virtualTextToJson(obj); | |
} | |
if (obj instanceof SoftSetHook) { | |
return softSetHookToJson(obj); | |
} | |
// plain object | |
return plainObjectToJson(obj); | |
} | |
function toJson(obj) { | |
var type = typeof obj; | |
switch (type) { | |
case 'string': | |
case 'boolean': | |
case 'number': | |
return obj; | |
} | |
// type === 'object' | |
if (Array.isArray(obj)) { | |
return arrayToJson(obj); | |
} | |
if (!obj) { // null | |
return null; | |
} | |
return objectToJson(obj); | |
} | |
module.exports = toJson; | |
},{"./types":40,"virtual-dom/virtual-hyperscript/hooks/soft-set-hook":56}],40:[function(require,module,exports){ | |
module.exports = { | |
VirtualTree: 1, | |
VirtualPatch: 2, | |
VirtualNode: 3, | |
SoftSetHook: 4 | |
}; | |
},{}],41:[function(require,module,exports){ | |
'use strict'; | |
module.exports = require('./lib/toJson'); | |
},{"./lib/toJson":39}],42:[function(require,module,exports){ | |
module.exports = require('./lib/patch'); | |
},{"./lib/patch":29}],43:[function(require,module,exports){ | |
module.exports = require('./lib/serialize'); | |
},{"./lib/serialize":38}],44:[function(require,module,exports){ | |
function delegator(counterpart, channels, callback, options) { | |
var connectFnName, messageHandlers; | |
function postMessage(namespace, message) { | |
if (typeof message.type !== 'string') { | |
return; | |
} | |
message.type = namespace + '::' + message.type; | |
counterpart.postMessage(message); | |
} | |
function connectChannel(channel) { | |
if (typeof channel.namespace === 'string' && | |
typeof channel.handleMessage === 'function') { | |
messageHandlers[channel.namespace] = channel.handleMessage; | |
} | |
if (typeof channel[connectFnName] === 'function') { | |
channel[connectFnName](postMessage.bind(null, channel.namespace)); | |
} | |
} | |
function handleMessage(type, data) { | |
var namespaced = type.split('::'); | |
if (namespaced.length !== 2) { | |
return; | |
} | |
if (messageHandlers[namespaced[0]] != null) { | |
messageHandlers[namespaced[0]](namespaced[1], data); | |
} | |
} | |
function onmessage(event) { | |
if (typeof options.logger === 'function') { | |
options.logger(event.data.type, event.data.data); | |
} | |
return handleMessage(event.data.type, event.data.data); | |
} | |
connectFnName = (typeof callback === 'function') ? 'connectWorker' : 'connectMain'; | |
messageHandlers = {}; | |
channels.forEach(connectChannel); | |
counterpart.onmessage = onmessage; | |
if (typeof callback === 'function') { | |
callback(); | |
} | |
} | |
module.exports = delegator; | |
},{}],45:[function(require,module,exports){ | |
(function (global){ | |
var delegator = require('./delegator'); | |
var shim = require('./shim'); | |
var WORKER_ENABLED = !!(global === global.window && global.URL && global.Worker); | |
var IN_WORKER_CONTEXT = !!(global === global.self && global.location); | |
var PATHNAME = WORKER_ENABLED && (function getPathname() { | |
var scripts = global.document.getElementsByTagName('script'); | |
return new global.URL(scripts[scripts.length - 1].src).pathname; | |
})(); | |
function duet(channels, callback, options) { | |
var shimmed; | |
if (typeof callback !== 'function') { | |
throw new Error('duet callback is not a function'); | |
} | |
channels = (Array.isArray(channels) && channels) || []; | |
options = (typeof options == 'object' && options !== null && options) || {}; | |
if (!options.forceShim) { | |
if (WORKER_ENABLED) { | |
return delegator(new global.Worker(PATHNAME), channels, null, options); | |
} | |
if (IN_WORKER_CONTEXT) { | |
return delegator(global.self, channels, callback, options); | |
} | |
} | |
shimmed = shim(); | |
delegator(shimmed.worker, channels, null, options); | |
delegator(shimmed.self, channels, callback, options); | |
} | |
module.exports = duet; | |
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) | |
//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9kdWV0L2xpYi9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsidmFyIGRlbGVnYXRvciA9IHJlcXVpcmUoJy4vZGVsZWdhdG9yJyk7XG52YXIgc2hpbSA9IHJlcXVpcmUoJy4vc2hpbScpO1xuXG52YXIgV09SS0VSX0VOQUJMRUQgPSAhIShnbG9iYWwgPT09IGdsb2JhbC53aW5kb3cgJiYgZ2xvYmFsLlVSTCAmJiBnbG9iYWwuV29ya2VyKTtcbnZhciBJTl9XT1JLRVJfQ09OVEVYVCA9ICEhKGdsb2JhbCA9PT0gZ2xvYmFsLnNlbGYgJiYgZ2xvYmFsLmxvY2F0aW9uKTtcbnZhciBQQVRITkFNRSA9IFdPUktFUl9FTkFCTEVEICYmIChmdW5jdGlvbiBnZXRQYXRobmFtZSgpIHtcbiAgICB2YXIgc2NyaXB0cyA9IGdsb2JhbC5kb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgnc2NyaXB0Jyk7XG4gICAgcmV0dXJuIG5ldyBnbG9iYWwuVVJMKHNjcmlwdHNbc2NyaXB0cy5sZW5ndGggLSAxXS5zcmMpLnBhdGhuYW1lO1xufSkoKTtcblxuZnVuY3Rpb24gZHVldChjaGFubmVscywgY2FsbGJhY2ssIG9wdGlvbnMpIHtcbiAgICB2YXIgc2hpbW1lZDtcblxuICAgIGlmICh0eXBlb2YgY2FsbGJhY2sgIT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdkdWV0IGNhbGxiYWNrIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gICAgfVxuXG4gICAgY2hhbm5lbHMgPSAoQXJyYXkuaXNBcnJheShjaGFubmVscykgJiYgY2hhbm5lbHMpIHx8IFtdO1xuXG4gICAgb3B0aW9ucyA9ICh0eXBlb2Ygb3B0aW9ucyA9PSAnb2JqZWN0JyAmJiBvcHRpb25zICE9PSBudWxsICYmIG9wdGlvbnMpIHx8IHt9O1xuXG4gICAgaWYgKCFvcHRpb25zLmZvcmNlU2hpbSkge1xuXG4gICAgICAgIGlmIChXT1JLRVJfRU5BQkxFRCkge1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRvcihuZXcgZ2xvYmFsLldvcmtlcihQQVRITkFNRSksIGNoYW5uZWxzLCBudWxsLCBvcHRpb25zKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChJTl9XT1JLRVJfQ09OVEVYVCkge1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRvcihnbG9iYWwuc2VsZiwgY2hhbm5lbHMsIGNhbGxiYWNrLCBvcHRpb25zKTtcbiAgICAgICAgfVxuXG4gICAgfVxuXG4gICAgc2hpbW1lZCA9IHNoaW0oKTtcblxuICAgIGRlbGVnYXRvcihzaGltbWVkLndvcmtlciwgY2hhbm5lbHMsIG51bGwsIG9wdGlvbnMpO1xuICAgIGRlbGVnYXRvcihzaGltbWVkLnNlbGYsIGNoYW5uZWxzLCBjYWxsYmFjaywgb3B0aW9ucyk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gZHVldDtcbiJdfQ== | |
},{"./delegator":44,"./shim":46}],46:[function(require,module,exports){ | |
function shim() { | |
var shimmed = { worker: {} }; | |
shimmed.self = {postMessage: messenger(shimmed.worker)}; | |
shimmed.worker.postMessage = messenger(shimmed.self); | |
return shimmed; | |
} | |
function messenger(destination) { | |
return function postMessage(data) { | |
setTimeout(function onTick() { | |
if (typeof destination.onmessage === 'function') { | |
destination.onmessage({data: data}); | |
} | |
}, 0); | |
} | |
} | |
module.exports = shim; | |
},{}],47:[function(require,module,exports){ | |
const pathname = require('pathname-match') | |
const wayfarer = require('wayfarer') | |
const assert = require('assert') | |
module.exports = sheetRouter | |
// Fast, modular client router | |
// fn(str, any[..], fn?) -> fn(str, any[..]) | |
function sheetRouter (dft, createTree, createRoute) { | |
createRoute = (createRoute ? createRoute(_createRoute) : _createRoute) | |
if (!createTree) { | |
createTree = dft | |
dft = '' | |
} | |
assert.equal(typeof dft, 'string', 'sheet-router: dft must be a string') | |
assert.equal(typeof createTree, 'function', 'sheet-router: createTree must be a function') | |
assert.equal(typeof createRoute, 'function', 'sheet-router: createRoute must be a function') | |
const router = wayfarer(dft) | |
const tree = createTree(createRoute) | |
// register tree in router | |
;(function walk (tree, route) { | |
if (Array.isArray(tree[0])) { | |
// walk over all routes at the root of the tree | |
tree.forEach(function (node) { | |
walk(node, route) | |
}) | |
} else if (tree[1]) { | |
// handle inline functions as args | |
const innerRoute = tree[0] | |
? route.concat(tree[0]).join('/') | |
: route.length ? route.join('/') : tree[0] | |
router.on(innerRoute, tree[1]) | |
walk(tree[2], route.concat(tree[0])) | |
} else if (Array.isArray(tree[2])) { | |
// traverse and append route | |
walk(tree[2], route.concat(tree[0])) | |
} else { | |
// register path in router | |
const nwRoute = tree[0] | |
? route.concat(tree[0]).join('/') | |
: route.length ? route.join('/') : tree[0] | |
router.on(nwRoute, tree[2]) | |
} | |
})(tree, []) | |
// match a route on the router | |
return function match (route) { | |
assert.equal(typeof route, 'string', 'route must be a string') | |
const args = [].slice.call(arguments) | |
args[0] = pathname(args[0]) | |
return router.apply(null, args) | |
} | |
} | |
// register regular route | |
function _createRoute (route, inline, child) { | |
if (!child) { | |
child = inline | |
inline = null | |
} | |
assert.equal(typeof route, 'string', 'route must be a string') | |
assert.ok(child, 'child exists') | |
route = route.replace(/^\//, '') | |
return [ route, inline, child ] | |
} | |
},{"assert":1,"pathname-match":48,"wayfarer":49}],48:[function(require,module,exports){ | |
arguments[4][15][0].apply(exports,arguments) | |
},{"assert":1,"dup":15}],49:[function(require,module,exports){ | |
const assert = require('assert') | |
const trie = require('./trie') | |
module.exports = Wayfarer | |
// create a router | |
// str -> obj | |
function Wayfarer (dft) { | |
if (!(this instanceof Wayfarer)) return new Wayfarer(dft) | |
const _default = (dft || '').replace(/^\//, '') | |
const _trie = trie() | |
emit._trie = _trie | |
emit.emit = emit | |
emit.on = on | |
emit._wayfarer = true | |
return emit | |
// define a route | |
// (str, fn) -> obj | |
function on (route, cb) { | |
assert.equal(typeof route, 'string') | |
assert.equal(typeof cb, 'function') | |
route = route || '/' | |
if (cb && cb._wayfarer && cb._trie) { | |
_trie.mount(route, cb._trie.trie) | |
} else { | |
const node = _trie.create(route) | |
node.cb = cb | |
} | |
return emit | |
} | |
// match and call a route | |
// (str, obj?) -> null | |
function emit (route) { | |
assert.notEqual(route, undefined, "'route' must be defined") | |
const args = new Array(arguments.length) | |
for (var i = 1; i < args.length; i++) { | |
args[i] = arguments[i] | |
} | |
const node = _trie.match(route) | |
if (node && node.cb) { | |
args[0] = node.params | |
return node.cb.apply(null, args) | |
} | |
const dft = _trie.match(_default) | |
if (dft && dft.cb) { | |
args[0] = dft.params | |
return dft.cb.apply(null, args) | |
} | |
throw new Error("route '" + route + "' did not match") | |
} | |
} | |
},{"./trie":52,"assert":1}],50:[function(require,module,exports){ | |
arguments[4][9][0].apply(exports,arguments) | |
},{"dup":9}],51:[function(require,module,exports){ | |
arguments[4][10][0].apply(exports,arguments) | |
},{"dup":10}],52:[function(require,module,exports){ | |
const mutate = require('xtend/mutable') | |
const assert = require('assert') | |
const xtend = require('xtend') | |
module.exports = Trie | |
// create a new trie | |
// null -> obj | |
function Trie () { | |
if (!(this instanceof Trie)) return new Trie() | |
this.trie = { nodes: {} } | |
} | |
// create a node on the trie at route | |
// and return a node | |
// str -> null | |
Trie.prototype.create = function (route) { | |
assert.equal(typeof route, 'string', 'route should be a string') | |
// strip leading '/' and split routes | |
const routes = route.replace(/^\//, '').split('/') | |
return (function createNode (index, trie, routes) { | |
const route = routes[index] | |
if (route === undefined) return trie | |
var node = null | |
if (/^:/.test(route)) { | |
// if node is a name match, set name and append to ':' node | |
if (!trie.nodes['$$']) { | |
node = { nodes: {} } | |
trie.nodes['$$'] = node | |
} else { | |
node = trie.nodes['$$'] | |
} | |
trie.name = route.replace(/^:/, '') | |
} else if (!trie.nodes[route]) { | |
node = { nodes: {} } | |
trie.nodes[route] = node | |
} else { | |
node = trie.nodes[route] | |
} | |
// we must recurse deeper | |
return createNode(index + 1, node, routes) | |
})(0, this.trie, routes) | |
} | |
// match a route on the trie | |
// and return the node | |
// str -> obj | |
Trie.prototype.match = function (route) { | |
assert.equal(typeof route, 'string', 'route should be a string') | |
const routes = route.replace(/^\//, '').split('/') | |
const params = {} | |
var node = (function search (index, trie) { | |
// either there's no match, or we're done searching | |
if (trie === undefined) return undefined | |
const route = routes[index] | |
if (route === undefined) return trie | |
if (trie.nodes[route]) { | |
// match regular routes first | |
return search(index + 1, trie.nodes[route]) | |
} else if (trie.name) { | |
// match named routes | |
params[trie.name] = route | |
return search(index + 1, trie.nodes['$$']) | |
} else { | |
// no matches found | |
return search(index + 1) | |
} | |
})(0, this.trie) | |
if (!node) return undefined | |
node = xtend(node) | |
node.params = params | |
return node | |
} | |
// mount a trie onto a node at route | |
// (str, obj) -> null | |
Trie.prototype.mount = function (route, trie) { | |
assert.equal(typeof route, 'string', 'route should be a string') | |
assert.equal(typeof trie, 'object', 'trie should be a object') | |
const split = route.replace(/^\//, '').split('/') | |
var node = null | |
var key = null | |
if (split.length === 1) { | |
key = split[0] | |
node = this.create(key) | |
} else { | |
const headArr = split.splice(0, split.length - 1) | |
const head = headArr.join('/') | |
key = split[0] | |
node = this.create(head) | |
} | |
mutate(node.nodes, trie.nodes) | |
if (trie.name) node.name = trie.name | |
// delegate properties from '/' to the new node | |
// '/' cannot be reached once mounted | |
if (node.nodes['']) { | |
Object.keys(node.nodes['']).forEach(function (key) { | |
if (key === 'nodes') return | |
node[key] = node.nodes[''][key] | |
}) | |
mutate(node.nodes, node.nodes[''].nodes) | |
delete node.nodes[''].nodes | |
} | |
} | |
},{"assert":1,"xtend":50,"xtend/mutable":51}],53:[function(require,module,exports){ | |
var diff = require("./vtree/diff.js") | |
module.exports = diff | |
},{"./vtree/diff.js":67}],54:[function(require,module,exports){ | |
"use strict"; | |
module.exports = function isObject(x) { | |
return typeof x === "object" && x !== null; | |
}; | |
},{}],55:[function(require,module,exports){ | |
var nativeIsArray = Array.isArray | |
var toString = Object.prototype.toString | |
module.exports = nativeIsArray || isArray | |
function isArray(obj) { | |
return toString.call(obj) === "[object Array]" | |
} | |
},{}],56:[function(require,module,exports){ | |
'use strict'; | |
module.exports = SoftSetHook; | |
function SoftSetHook(value) { | |
if (!(this instanceof SoftSetHook)) { | |
return new SoftSetHook(value); | |
} | |
this.value = value; | |
} | |
SoftSetHook.prototype.hook = function (node, propertyName) { | |
if (node[propertyName] !== this.value) { | |
node[propertyName] = this.value; | |
} | |
}; | |
},{}],57:[function(require,module,exports){ | |
var isVNode = require("./is-vnode") | |
var isVText = require("./is-vtext") | |
var isWidget = require("./is-widget") | |
var isThunk = require("./is-thunk") | |
module.exports = handleThunk | |
function handleThunk(a, b) { | |
var renderedA = a | |
var renderedB = b | |
if (isThunk(b)) { | |
renderedB = renderThunk(b, a) | |
} | |
if (isThunk(a)) { | |
renderedA = renderThunk(a, null) | |
} | |
return { | |
a: renderedA, | |
b: renderedB | |
} | |
} | |
function renderThunk(thunk, previous) { | |
var renderedThunk = thunk.vnode | |
if (!renderedThunk) { | |
renderedThunk = thunk.vnode = thunk.render(previous) | |
} | |
if (!(isVNode(renderedThunk) || | |
isVText(renderedThunk) || | |
isWidget(renderedThunk))) { | |
throw new Error("thunk did not return a valid node"); | |
} | |
return renderedThunk | |
} | |
},{"./is-thunk":58,"./is-vnode":60,"./is-vtext":61,"./is-widget":62}],58:[function(require,module,exports){ | |
module.exports = isThunk | |
function isThunk(t) { | |
return t && t.type === "Thunk" | |
} | |
},{}],59:[function(require,module,exports){ | |
module.exports = isHook | |
function isHook(hook) { | |
return hook && | |
(typeof hook.hook === "function" && !hook.hasOwnProperty("hook") || | |
typeof hook.unhook === "function" && !hook.hasOwnProperty("unhook")) | |
} | |
},{}],60:[function(require,module,exports){ | |
var version = require("./version") | |
module.exports = isVirtualNode | |
function isVirtualNode(x) { | |
return x && x.type === "VirtualNode" && x.version === version | |
} | |
},{"./version":63}],61:[function(require,module,exports){ | |
var version = require("./version") | |
module.exports = isVirtualText | |
function isVirtualText(x) { | |
return x && x.type === "VirtualText" && x.version === version | |
} | |
},{"./version":63}],62:[function(require,module,exports){ | |
module.exports = isWidget | |
function isWidget(w) { | |
return w && w.type === "Widget" | |
} | |
},{}],63:[function(require,module,exports){ | |
module.exports = "2" | |
},{}],64:[function(require,module,exports){ | |
var version = require("./version") | |
var isVNode = require("./is-vnode") | |
var isWidget = require("./is-widget") | |
var isThunk = require("./is-thunk") | |
var isVHook = require("./is-vhook") | |
module.exports = VirtualNode | |
var noProperties = {} | |
var noChildren = [] | |
function VirtualNode(tagName, properties, children, key, namespace) { | |
this.tagName = tagName | |
this.properties = properties || noProperties | |
this.children = children || noChildren | |
this.key = key != null ? String(key) : undefined | |
this.namespace = (typeof namespace === "string") ? namespace : null | |
var count = (children && children.length) || 0 | |
var descendants = 0 | |
var hasWidgets = false | |
var hasThunks = false | |
var descendantHooks = false | |
var hooks | |
for (var propName in properties) { | |
if (properties.hasOwnProperty(propName)) { | |
var property = properties[propName] | |
if (isVHook(property) && property.unhook) { | |
if (!hooks) { | |
hooks = {} | |
} | |
hooks[propName] = property | |
} | |
} | |
} | |
for (var i = 0; i < count; i++) { | |
var child = children[i] | |
if (isVNode(child)) { | |
descendants += child.count || 0 | |
if (!hasWidgets && child.hasWidgets) { | |
hasWidgets = true | |
} | |
if (!hasThunks && child.hasThunks) { | |
hasThunks = true | |
} | |
if (!descendantHooks && (child.hooks || child.descendantHooks)) { | |
descendantHooks = true | |
} | |
} else if (!hasWidgets && isWidget(child)) { | |
if (typeof child.destroy === "function") { | |
hasWidgets = true | |
} | |
} else if (!hasThunks && isThunk(child)) { | |
hasThunks = true; | |
} | |
} | |
this.count = count + descendants | |
this.hasWidgets = hasWidgets | |
this.hasThunks = hasThunks | |
this.hooks = hooks | |
this.descendantHooks = descendantHooks | |
} | |
VirtualNode.prototype.version = version | |
VirtualNode.prototype.type = "VirtualNode" | |
},{"./is-thunk":58,"./is-vhook":59,"./is-vnode":60,"./is-widget":62,"./version":63}],65:[function(require,module,exports){ | |
var version = require("./version") | |
VirtualPatch.NONE = 0 | |
VirtualPatch.VTEXT = 1 | |
VirtualPatch.VNODE = 2 | |
VirtualPatch.WIDGET = 3 | |
VirtualPatch.PROPS = 4 | |
VirtualPatch.ORDER = 5 | |
VirtualPatch.INSERT = 6 | |
VirtualPatch.REMOVE = 7 | |
VirtualPatch.THUNK = 8 | |
module.exports = VirtualPatch | |
function VirtualPatch(type, vNode, patch) { | |
this.type = Number(type) | |
this.vNode = vNode | |
this.patch = patch | |
} | |
VirtualPatch.prototype.version = version | |
VirtualPatch.prototype.type = "VirtualPatch" | |
},{"./version":63}],66:[function(require,module,exports){ | |
var isObject = require("is-object") | |
var isHook = require("../vnode/is-vhook") | |
module.exports = diffProps | |
function diffProps(a, b) { | |
var diff | |
for (var aKey in a) { | |
if (!(aKey in b)) { | |
diff = diff || {} | |
diff[aKey] = undefined | |
} | |
var aValue = a[aKey] | |
var bValue = b[aKey] | |
if (aValue === bValue) { | |
continue | |
} else if (isObject(aValue) && isObject(bValue)) { | |
if (getPrototype(bValue) !== getPrototype(aValue)) { | |
diff = diff || {} | |
diff[aKey] = bValue | |
} else if (isHook(bValue)) { | |
diff = diff || {} | |
diff[aKey] = bValue | |
} else { | |
var objectDiff = diffProps(aValue, bValue) | |
if (objectDiff) { | |
diff = diff || {} | |
diff[aKey] = objectDiff | |
} | |
} | |
} else { | |
diff = diff || {} | |
diff[aKey] = bValue | |
} | |
} | |
for (var bKey in b) { | |
if (!(bKey in a)) { | |
diff = diff || {} | |
diff[bKey] = b[bKey] | |
} | |
} | |
return diff | |
} | |
function getPrototype(value) { | |
if (Object.getPrototypeOf) { | |
return Object.getPrototypeOf(value) | |
} else if (value.__proto__) { | |
return value.__proto__ | |
} else if (value.constructor) { | |
return value.constructor.prototype | |
} | |
} | |
},{"../vnode/is-vhook":59,"is-object":54}],67:[function(require,module,exports){ | |
var isArray = require("x-is-array") | |
var VPatch = require("../vnode/vpatch") | |
var isVNode = require("../vnode/is-vnode") | |
var isVText = require("../vnode/is-vtext") | |
var isWidget = require("../vnode/is-widget") | |
var isThunk = require("../vnode/is-thunk") | |
var handleThunk = require("../vnode/handle-thunk") | |
var diffProps = require("./diff-props") | |
module.exports = diff | |
function diff(a, b) { | |
var patch = { a: a } | |
walk(a, b, patch, 0) | |
return patch | |
} | |
function walk(a, b, patch, index) { | |
if (a === b) { | |
return | |
} | |
var apply = patch[index] | |
var applyClear = false | |
if (isThunk(a) || isThunk(b)) { | |
thunks(a, b, patch, index) | |
} else if (b == null) { | |
// If a is a widget we will add a remove patch for it | |
// Otherwise any child widgets/hooks must be destroyed. | |
// This prevents adding two remove patches for a widget. | |
if (!isWidget(a)) { | |
clearState(a, patch, index) | |
apply = patch[index] | |
} | |
apply = appendPatch(apply, new VPatch(VPatch.REMOVE, a, b)) | |
} else if (isVNode(b)) { | |
if (isVNode(a)) { | |
if (a.tagName === b.tagName && | |
a.namespace === b.namespace && | |
a.key === b.key) { | |
var propsPatch = diffProps(a.properties, b.properties) | |
if (propsPatch) { | |
apply = appendPatch(apply, | |
new VPatch(VPatch.PROPS, a, propsPatch)) | |
} | |
apply = diffChildren(a, b, patch, apply, index) | |
} else { | |
apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b)) | |
applyClear = true | |
} | |
} else { | |
apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b)) | |
applyClear = true | |
} | |
} else if (isVText(b)) { | |
if (!isVText(a)) { | |
apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b)) | |
applyClear = true | |
} else if (a.text !== b.text) { | |
apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b)) | |
} | |
} else if (isWidget(b)) { | |
if (!isWidget(a)) { | |
applyClear = true | |
} | |
apply = appendPatch(apply, new VPatch(VPatch.WIDGET, a, b)) | |
} | |
if (apply) { | |
patch[index] = apply | |
} | |
if (applyClear) { | |
clearState(a, patch, index) | |
} | |
} | |
function diffChildren(a, b, patch, apply, index) { | |
var aChildren = a.children | |
var orderedSet = reorder(aChildren, b.children) | |
var bChildren = orderedSet.children | |
var aLen = aChildren.length | |
var bLen = bChildren.length | |
var len = aLen > bLen ? aLen : bLen | |
for (var i = 0; i < len; i++) { | |
var leftNode = aChildren[i] | |
var rightNode = bChildren[i] | |
index += 1 | |
if (!leftNode) { | |
if (rightNode) { | |
// Excess nodes in b need to be added | |
apply = appendPatch(apply, | |
new VPatch(VPatch.INSERT, null, rightNode)) | |
} | |
} else { | |
walk(leftNode, rightNode, patch, index) | |
} | |
if (isVNode(leftNode) && leftNode.count) { | |
index += leftNode.count | |
} | |
} | |
if (orderedSet.moves) { | |
// Reorder nodes last | |
apply = appendPatch(apply, new VPatch( | |
VPatch.ORDER, | |
a, | |
orderedSet.moves | |
)) | |
} | |
return apply | |
} | |
function clearState(vNode, patch, index) { | |
// TODO: Make this a single walk, not two | |
unhook(vNode, patch, index) | |
destroyWidgets(vNode, patch, index) | |
} | |
// Patch records for all destroyed widgets must be added because we need | |
// a DOM node reference for the destroy function | |
function destroyWidgets(vNode, patch, index) { | |
if (isWidget(vNode)) { | |
if (typeof vNode.destroy === "function") { | |
patch[index] = appendPatch( | |
patch[index], | |
new VPatch(VPatch.REMOVE, vNode, null) | |
) | |
} | |
} else if (isVNode(vNode) && (vNode.hasWidgets || vNode.hasThunks)) { | |
var children = vNode.children | |
var len = children.length | |
for (var i = 0; i < len; i++) { | |
var child = children[i] | |
index += 1 | |
destroyWidgets(child, patch, index) | |
if (isVNode(child) && child.count) { | |
index += child.count | |
} | |
} | |
} else if (isThunk(vNode)) { | |
thunks(vNode, null, patch, index) | |
} | |
} | |
// Create a sub-patch for thunks | |
function thunks(a, b, patch, index) { | |
var nodes = handleThunk(a, b) | |
var thunkPatch = diff(nodes.a, nodes.b) | |
if (hasPatches(thunkPatch)) { | |
patch[index] = new VPatch(VPatch.THUNK, null, thunkPatch) | |
} | |
} | |
function hasPatches(patch) { | |
for (var index in patch) { | |
if (index !== "a") { | |
return true | |
} | |
} | |
return false | |
} | |
// Execute hooks when two nodes are identical | |
function unhook(vNode, patch, index) { | |
if (isVNode(vNode)) { | |
if (vNode.hooks) { | |
patch[index] = appendPatch( | |
patch[index], | |
new VPatch( | |
VPatch.PROPS, | |
vNode, | |
undefinedKeys(vNode.hooks) | |
) | |
) | |
} | |
if (vNode.descendantHooks || vNode.hasThunks) { | |
var children = vNode.children | |
var len = children.length | |
for (var i = 0; i < len; i++) { | |
var child = children[i] | |
index += 1 | |
unhook(child, patch, index) | |
if (isVNode(child) && child.count) { | |
index += child.count | |
} | |
} | |
} | |
} else if (isThunk(vNode)) { | |
thunks(vNode, null, patch, index) | |
} | |
} | |
function undefinedKeys(obj) { | |
var result = {} | |
for (var key in obj) { | |
result[key] = undefined | |
} | |
return result | |
} | |
// List diff, naive left to right reordering | |
function reorder(aChildren, bChildren) { | |
// O(M) time, O(M) memory | |
var bChildIndex = keyIndex(bChildren) | |
var bKeys = bChildIndex.keys | |
var bFree = bChildIndex.free | |
if (bFree.length === bChildren.length) { | |
return { | |
children: bChildren, | |
moves: null | |
} | |
} | |
// O(N) time, O(N) memory | |
var aChildIndex = keyIndex(aChildren) | |
var aKeys = aChildIndex.keys | |
var aFree = aChildIndex.free | |
if (aFree.length === aChildren.length) { | |
return { | |
children: bChildren, | |
moves: null | |
} | |
} | |
// O(MAX(N, M)) memory | |
var newChildren = [] | |
var freeIndex = 0 | |
var freeCount = bFree.length | |
var deletedItems = 0 | |
// Iterate through a and match a node in b | |
// O(N) time, | |
for (var i = 0 ; i < aChildren.length; i++) { | |
var aItem = aChildren[i] | |
var itemIndex | |
if (aItem.key) { | |
if (bKeys.hasOwnProperty(aItem.key)) { | |
// Match up the old keys | |
itemIndex = bKeys[aItem.key] | |
newChildren.push(bChildren[itemIndex]) | |
} else { | |
// Remove old keyed items | |
itemIndex = i - deletedItems++ | |
newChildren.push(null) | |
} | |
} else { | |
// Match the item in a with the next free item in b | |
if (freeIndex < freeCount) { | |
itemIndex = bFree[freeIndex++] | |
newChildren.push(bChildren[itemIndex]) | |
} else { | |
// There are no free items in b to match with | |
// the free items in a, so the extra free nodes | |
// are deleted. | |
itemIndex = i - deletedItems++ | |
newChildren.push(null) | |
} | |
} | |
} | |
var lastFreeIndex = freeIndex >= bFree.length ? | |
bChildren.length : | |
bFree[freeIndex] | |
// Iterate through b and append any new keys | |
// O(M) time | |
for (var j = 0; j < bChildren.length; j++) { | |
var newItem = bChildren[j] | |
if (newItem.key) { | |
if (!aKeys.hasOwnProperty(newItem.key)) { | |
// Add any new keyed items | |
// We are adding new items to the end and then sorting them | |
// in place. In future we should insert new items in place. | |
newChildren.push(newItem) | |
} | |
} else if (j >= lastFreeIndex) { | |
// Add any leftover non-keyed items | |
newChildren.push(newItem) | |
} | |
} | |
var simulate = newChildren.slice() | |
var simulateIndex = 0 | |
var removes = [] | |
var inserts = [] | |
var simulateItem | |
for (var k = 0; k < bChildren.length;) { | |
var wantedItem = bChildren[k] | |
simulateItem = simulate[simulateIndex] | |
// remove items | |
while (simulateItem === null && simulate.length) { | |
removes.push(remove(simulate, simulateIndex, null)) | |
simulateItem = simulate[simulateIndex] | |
} | |
if (!simulateItem || simulateItem.key !== wantedItem.key) { | |
// if we need a key in this position... | |
if (wantedItem.key) { | |
if (simulateItem && simulateItem.key) { | |
// if an insert doesn't put this key in place, it needs to move | |
if (bKeys[simulateItem.key] !== k + 1) { | |
removes.push(remove(simulate, simulateIndex, simulateItem.key)) | |
simulateItem = simulate[simulateIndex] | |
// if the remove didn't put the wanted item in place, we need to insert it | |
if (!simulateItem || simulateItem.key !== wantedItem.key) { | |
inserts.push({key: wantedItem.key, to: k}) | |
} | |
// items are matching, so skip ahead | |
else { | |
simulateIndex++ | |
} | |
} | |
else { | |
inserts.push({key: wantedItem.key, to: k}) | |
} | |
} | |
else { | |
inserts.push({key: wantedItem.key, to: k}) | |
} | |
k++ | |
} | |
// a key in simulate has no matching wanted key, remove it | |
else if (simulateItem && simulateItem.key) { | |
removes.push(remove(simulate, simulateIndex, simulateItem.key)) | |
} | |
} | |
else { | |
simulateIndex++ | |
k++ | |
} | |
} | |
// remove all the remaining nodes from simulate | |
while(simulateIndex < simulate.length) { | |
simulateItem = simulate[simulateIndex] | |
removes.push(remove(simulate, simulateIndex, simulateItem && simulateItem.key)) | |
} | |
// If the only moves we have are deletes then we can just | |
// let the delete patch remove these items. | |
if (removes.length === deletedItems && !inserts.length) { | |
return { | |
children: newChildren, | |
moves: null | |
} | |
} | |
return { | |
children: newChildren, | |
moves: { | |
removes: removes, | |
inserts: inserts | |
} | |
} | |
} | |
function remove(arr, index, key) { | |
arr.splice(index, 1) | |
return { | |
from: index, | |
key: key | |
} | |
} | |
function keyIndex(children) { | |
var keys = {} | |
var free = [] | |
var length = children.length | |
for (var i = 0; i < length; i++) { | |
var child = children[i] | |
if (child.key) { | |
keys[child.key] = i | |
} else { | |
free.push(i) | |
} | |
} | |
return { | |
keys: keys, // A hash of key name to index | |
free: free // An array of unkeyed item indices | |
} | |
} | |
function appendPatch(apply, patch) { | |
if (apply) { | |
if (isArray(apply)) { | |
apply.push(patch) | |
} else { | |
apply = [apply, patch] | |
} | |
return apply | |
} else { | |
return patch | |
} | |
} | |
},{"../vnode/handle-thunk":57,"../vnode/is-thunk":58,"../vnode/is-vnode":60,"../vnode/is-vtext":61,"../vnode/is-widget":62,"../vnode/vpatch":65,"./diff-props":66,"x-is-array":55}],"chooet":[function(require,module,exports){ | |
const choo = require('./choo'); | |
const duet = require('duet'); | |
const duetLocationChannel = require('duet-location/channel'); | |
const duetVirtualDOMChannel = require('duet-virtual-dom/channel'); | |
module.exports = chooet; | |
function chooet (cb, opts) { | |
opts = typeof opts === 'object' ? opts : {}; | |
opts.channels = Array.isArray(opts.channels) ? opts.channels : []; | |
const channels = opts.channels.concat(duetLocationChannel, duetVirtualDOMChannel); | |
delete opts.channels; | |
duet(channels, cb.bind(null, choo), opts); | |
} | |
},{"./choo":6,"duet":45,"duet-location/channel":11,"duet-virtual-dom/channel":16}]},{},[]) | |
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/browser-pack/_prelude.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/assert/assert.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/process/browser.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/util/node_modules/inherits/inherits_browser.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/util/support/isBufferBrowser.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/util/util.js","choo.js","node_modules/barracks/apply-hook.js","node_modules/barracks/index.js","node_modules/barracks/node_modules/xtend/immutable.js","node_modules/barracks/node_modules/xtend/mutable.js","node_modules/duet-location/channel.js","node_modules/duet-location/index.js","node_modules/duet-location/node_modules/duet-channel/index.js","node_modules/duet-location/node_modules/hash-match/index.js","node_modules/duet-location/node_modules/pathname-match/index.js","node_modules/duet-virtual-dom/channel.js","node_modules/duet-virtual-dom/eventNames.js","node_modules/duet-virtual-dom/index.js","node_modules/duet-virtual-dom/node_modules/form-data-set/element.js","node_modules/duet-virtual-dom/node_modules/form-data-set/index.js","node_modules/duet-virtual-dom/node_modules/form-data-set/node_modules/dom-walk/index.js","node_modules/duet-virtual-dom/node_modules/tree-walk/index.js","node_modules/duet-virtual-dom/node_modules/tree-walk/node_modules/util-extend/extend.js","node_modules/duet-virtual-dom/node_modules/tree-walk/third_party/WeakMap/index.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/applyProperties.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/createElement.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/domIndex.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/index.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/isObject.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/isSoftSetHook.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/isVNode.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/isVText.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/patchOp.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/patchRecursive.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patch/types.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/patchTypes.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/lib/serialize/index.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/node_modules/vdom-as-json/lib/toJson.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/node_modules/vdom-as-json/lib/types.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/node_modules/vdom-as-json/toJson.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/patch.js","node_modules/duet-virtual-dom/node_modules/vdom-serialized-patch/serialize.js","node_modules/duet/lib/delegator.js","node_modules/duet/lib/index.js","node_modules/duet/lib/shim.js","node_modules/sheet-router/index.js","node_modules/sheet-router/node_modules/wayfarer/index.js","node_modules/sheet-router/node_modules/wayfarer/trie.js","node_modules/virtual-dom/diff.js","node_modules/virtual-dom/node_modules/is-object/index.js","node_modules/virtual-dom/node_modules/x-is-array/index.js","node_modules/virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js","node_modules/virtual-dom/vnode/handle-thunk.js","node_modules/virtual-dom/vnode/is-thunk.js","node_modules/virtual-dom/vnode/is-vhook.js","node_modules/virtual-dom/vnode/is-vnode.js","node_modules/virtual-dom/vnode/is-vtext.js","node_modules/virtual-dom/vnode/is-widget.js","node_modules/virtual-dom/vnode/version.js","node_modules/virtual-dom/vnode/vnode.js","node_modules/virtual-dom/vnode/vpatch.js","node_modules/virtual-dom/vtree/diff-props.js","node_modules/virtual-dom/vtree/diff.js","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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;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;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;ACNA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;;ACFA;AACA;;ACDA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;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;;ACxCA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// http://wiki.commonjs.org/wiki/Unit_Testing/1.0\n//\n// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!\n//\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// when used in node, this will actually load the util module we depend on\n// versus loading the builtin util module as happens otherwise\n// this is a bug in node module loading as far as I am concerned\nvar util = require('util/');\n\nvar pSlice = Array.prototype.slice;\nvar hasOwn = Object.prototype.hasOwnProperty;\n\n// 1. The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\n\n// 2. The AssertionError is defined in assert.\n// new assert.AssertionError({ message: message,\n//                             actual: actual,\n//                             expected: expected })\n\nassert.AssertionError = function AssertionError(options) {\n  this.name = 'AssertionError';\n  this.actual = options.actual;\n  this.expected = options.expected;\n  this.operator = options.operator;\n  if (options.message) {\n    this.message = options.message;\n    this.generatedMessage = false;\n  } else {\n    this.message = getMessage(this);\n    this.generatedMessage = true;\n  }\n  var stackStartFunction = options.stackStartFunction || fail;\n\n  if (Error.captureStackTrace) {\n    Error.captureStackTrace(this, stackStartFunction);\n  }\n  else {\n    // non v8 browsers so we can have a stacktrace\n    var err = new Error();\n    if (err.stack) {\n      var out = err.stack;\n\n      // try to strip useless frames\n      var fn_name = stackStartFunction.name;\n      var idx = out.indexOf('\\n' + fn_name);\n      if (idx >= 0) {\n        // once we have located the function frame\n        // we need to strip out everything before it (and its line)\n        var next_line = out.indexOf('\\n', idx + 1);\n        out = out.substring(next_line + 1);\n      }\n\n      this.stack = out;\n    }\n  }\n};\n\n// assert.AssertionError instanceof Error\nutil.inherits(assert.AssertionError, Error);\n\nfunction replacer(key, value) {\n  if (util.isUndefined(value)) {\n    return '' + value;\n  }\n  if (util.isNumber(value) && (isNaN(value) || !isFinite(value))) {\n    return value.toString();\n  }\n  if (util.isFunction(value) || util.isRegExp(value)) {\n    return value.toString();\n  }\n  return value;\n}\n\nfunction truncate(s, n) {\n  if (util.isString(s)) {\n    return s.length < n ? s : s.slice(0, n);\n  } else {\n    return s;\n  }\n}\n\nfunction getMessage(self) {\n  return truncate(JSON.stringify(self.actual, replacer), 128) + ' ' +\n         self.operator + ' ' +\n         truncate(JSON.stringify(self.expected, replacer), 128);\n}\n\n// At present only the three keys mentioned above are used and\n// understood by the spec. Implementations or sub modules can pass\n// other keys to the AssertionError's constructor - they will be\n// ignored.\n\n// 3. All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided.  All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction fail(actual, expected, message, operator, stackStartFunction) {\n  throw new assert.AssertionError({\n    message: message,\n    actual: actual,\n    expected: expected,\n    operator: operator,\n    stackStartFunction: stackStartFunction\n  });\n}\n\n// EXTENSION! allows for well behaved errors defined elsewhere.\nassert.fail = fail;\n\n// 4. Pure assertion tests whether a value is truthy, as determined\n// by !!guard.\n// assert.ok(guard, message_opt);\n// This statement is equivalent to assert.equal(true, !!guard,\n// message_opt);. To test strictly for the value true, use\n// assert.strictEqual(true, guard, message_opt);.\n\nfunction ok(value, message) {\n  if (!value) fail(value, true, message, '==', assert.ok);\n}\nassert.ok = ok;\n\n// 5. The equality assertion tests shallow, coercive equality with\n// ==.\n// assert.equal(actual, expected, message_opt);\n\nassert.equal = function equal(actual, expected, message) {\n  if (actual != expected) fail(actual, expected, message, '==', assert.equal);\n};\n\n// 6. The non-equality assertion tests for whether two objects are not equal\n// with != assert.notEqual(actual, expected, message_opt);\n\nassert.notEqual = function notEqual(actual, expected, message) {\n  if (actual == expected) {\n    fail(actual, expected, message, '!=', assert.notEqual);\n  }\n};\n\n// 7. The equivalence assertion tests a deep equality relation.\n// assert.deepEqual(actual, expected, message_opt);\n\nassert.deepEqual = function deepEqual(actual, expected, message) {\n  if (!_deepEqual(actual, expected)) {\n    fail(actual, expected, message, 'deepEqual', assert.deepEqual);\n  }\n};\n\nfunction _deepEqual(actual, expected) {\n  // 7.1. All identical values are equivalent, as determined by ===.\n  if (actual === expected) {\n    return true;\n\n  } else if (util.isBuffer(actual) && util.isBuffer(expected)) {\n    if (actual.length != expected.length) return false;\n\n    for (var i = 0; i < actual.length; i++) {\n      if (actual[i] !== expected[i]) return false;\n    }\n\n    return true;\n\n  // 7.2. If the expected value is a Date object, the actual value is\n  // equivalent if it is also a Date object that refers to the same time.\n  } else if (util.isDate(actual) && util.isDate(expected)) {\n    return actual.getTime() === expected.getTime();\n\n  // 7.3 If the expected value is a RegExp object, the actual value is\n  // equivalent if it is also a RegExp object with the same source and\n  // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).\n  } else if (util.isRegExp(actual) && util.isRegExp(expected)) {\n    return actual.source === expected.source &&\n           actual.global === expected.global &&\n           actual.multiline === expected.multiline &&\n           actual.lastIndex === expected.lastIndex &&\n           actual.ignoreCase === expected.ignoreCase;\n\n  // 7.4. Other pairs that do not both pass typeof value == 'object',\n  // equivalence is determined by ==.\n  } else if (!util.isObject(actual) && !util.isObject(expected)) {\n    return actual == expected;\n\n  // 7.5 For all other Object pairs, including Array objects, equivalence is\n  // determined by having the same number of owned properties (as verified\n  // with Object.prototype.hasOwnProperty.call), the same set of keys\n  // (although not necessarily the same order), equivalent values for every\n  // corresponding key, and an identical 'prototype' property. Note: this\n  // accounts for both named and indexed properties on Arrays.\n  } else {\n    return objEquiv(actual, expected);\n  }\n}\n\nfunction isArguments(object) {\n  return Object.prototype.toString.call(object) == '[object Arguments]';\n}\n\nfunction objEquiv(a, b) {\n  if (util.isNullOrUndefined(a) || util.isNullOrUndefined(b))\n    return false;\n  // an identical 'prototype' property.\n  if (a.prototype !== b.prototype) return false;\n  //~~~I've managed to break Object.keys through screwy arguments passing.\n  //   Converting to array solves the problem.\n  if (isArguments(a)) {\n    if (!isArguments(b)) {\n      return false;\n    }\n    a = pSlice.call(a);\n    b = pSlice.call(b);\n    return _deepEqual(a, b);\n  }\n  try {\n    var ka = objectKeys(a),\n        kb = objectKeys(b),\n        key, i;\n  } catch (e) {//happens when one is a string literal and the other isn't\n    return false;\n  }\n  // having the same number of owned properties (keys incorporates\n  // hasOwnProperty)\n  if (ka.length != kb.length)\n    return false;\n  //the same set of keys (although not necessarily the same order),\n  ka.sort();\n  kb.sort();\n  //~~~cheap key test\n  for (i = ka.length - 1; i >= 0; i--) {\n    if (ka[i] != kb[i])\n      return false;\n  }\n  //equivalent values for every corresponding key, and\n  //~~~possibly expensive deep test\n  for (i = ka.length - 1; i >= 0; i--) {\n    key = ka[i];\n    if (!_deepEqual(a[key], b[key])) return false;\n  }\n  return true;\n}\n\n// 8. The non-equivalence assertion tests for any deep inequality.\n// assert.notDeepEqual(actual, expected, message_opt);\n\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n  if (_deepEqual(actual, expected)) {\n    fail(actual, expected, message, 'notDeepEqual', assert.notDeepEqual);\n  }\n};\n\n// 9. The strict equality assertion tests strict equality, as determined by ===.\n// assert.strictEqual(actual, expected, message_opt);\n\nassert.strictEqual = function strictEqual(actual, expected, message) {\n  if (actual !== expected) {\n    fail(actual, expected, message, '===', assert.strictEqual);\n  }\n};\n\n// 10. The strict non-equality assertion tests for strict inequality, as\n// determined by !==.  assert.notStrictEqual(actual, expected, message_opt);\n\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n  if (actual === expected) {\n    fail(actual, expected, message, '!==', assert.notStrictEqual);\n  }\n};\n\nfunction expectedException(actual, expected) {\n  if (!actual || !expected) {\n    return false;\n  }\n\n  if (Object.prototype.toString.call(expected) == '[object RegExp]') {\n    return expected.test(actual);\n  } else if (actual instanceof expected) {\n    return true;\n  } else if (expected.call({}, actual) === true) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction _throws(shouldThrow, block, expected, message) {\n  var actual;\n\n  if (util.isString(expected)) {\n    message = expected;\n    expected = null;\n  }\n\n  try {\n    block();\n  } catch (e) {\n    actual = e;\n  }\n\n  message = (expected && expected.name ? ' (' + expected.name + ').' : '.') +\n            (message ? ' ' + message : '.');\n\n  if (shouldThrow && !actual) {\n    fail(actual, expected, 'Missing expected exception' + message);\n  }\n\n  if (!shouldThrow && expectedException(actual, expected)) {\n    fail(actual, expected, 'Got unwanted exception' + message);\n  }\n\n  if ((shouldThrow && actual && expected &&\n      !expectedException(actual, expected)) || (!shouldThrow && actual)) {\n    throw actual;\n  }\n}\n\n// 11. Expected to throw an error:\n// assert.throws(block, Error_opt, message_opt);\n\nassert.throws = function(block, /*optional*/error, /*optional*/message) {\n  _throws.apply(this, [true].concat(pSlice.call(arguments)));\n};\n\n// EXTENSION! This is annoying to write outside this module.\nassert.doesNotThrow = function(block, /*optional*/message) {\n  _throws.apply(this, [false].concat(pSlice.call(arguments)));\n};\n\nassert.ifError = function(err) { if (err) {throw err;}};\n\nvar objectKeys = Object.keys || function (obj) {\n  var keys = [];\n  for (var key in obj) {\n    if (hasOwn.call(obj, key)) keys.push(key);\n  }\n  return keys;\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 canMutationObserver = typeof window !== 'undefined'\n    && window.MutationObserver;\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    var queue = [];\n\n    if (canMutationObserver) {\n        var hiddenDiv = document.createElement(\"div\");\n        var observer = new MutationObserver(function () {\n            var queueList = queue.slice();\n            queue.length = 0;\n            queueList.forEach(function (fn) {\n                fn();\n            });\n        });\n\n        observer.observe(hiddenDiv, { attributes: true });\n\n        return function nextTick(fn) {\n            if (!queue.length) {\n                hiddenDiv.setAttribute('yes', 'no');\n            }\n            queue.push(fn);\n        };\n    }\n\n    if (canPost) {\n        window.addEventListener('message', function (ev) {\n            var source = ev.source;\n            if ((source === window || source === null) && 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\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\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","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","module.exports = function isBuffer(arg) {\n  return arg && typeof arg === 'object'\n    && typeof arg.copy === 'function'\n    && typeof arg.fill === 'function'\n    && typeof arg.readUInt8 === 'function';\n}","(function (process,global){\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\n}).call(this,require('_process'),typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/util/util.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"]}","const assert = require('assert');\nconst barracks = require('barracks');\nconst duetLocation = require('duet-location');\nconst duetVirtualDOM = require('duet-virtual-dom');\nconst sheetRouter = require('sheet-router');\n\nmodule.exports = choo;\n\n// framework for creating sturdy web applications\n// null -> fn\nfunction choo (opts) {\n  opts = opts || {};\n\n  const _store = start._store = barracks();\n  var _router = start._router = null;\n  var _defaultRoute = null;\n  var _update = null\n  var _routes = null;\n  var _frame = null;\n\n  _store.use({ onStateChange: render });\n  _store.use(opts);\n\n  start.router = router;\n  start.model = model;\n  start.start = start;\n  start.use = use;\n\n  return start;\n\n  // start the application\n  // (str, obj?) -> null\n  function start (selector, startOpts) {\n    assert.equal(typeof selector, 'string', 'choo.start: selector should be an string');\n    startOpts = startOpts || {};\n    startOpts.vdom = startOpts.vdom || {};\n\n    appInit(function (locationModel) {\n      _store.model(locationModel);\n      const createSend = _store.start(startOpts);\n      _router = start._router = createRouter(_defaultRoute, _routes, createSend);\n      const state = _store.state({state: {}});\n      _update = duetVirtualDOM(selector, startOpts.vdom);\n      _update(_router(state.location.pathname, state));\n    }, startOpts);\n  }\n\n  // initial application state model\n  // (fn, obj) -> null\n  function appInit (cb, opts) {\n    var _send;\n    var _done;\n\n    const subs = {\n      getRefs: function (send, done) {\n        _send = send;\n        _done = done;\n      }\n    };\n\n    const reducers = {\n      setLocation: function setLocation (data, state) {\n        return { pathname: data.location };\n      }\n    };\n\n    duetLocation(function (pathname) {\n      if (_send != null) {\n        return _send('location:setLocation', { location: pathname }, _done);\n      }\n\n      cb({\n        namespace: 'location',\n        subscriptions: subs,\n        reducers: reducers,\n        state: {\n          pathname: pathname\n        }\n      });\n\n      _done(null);\n    }, opts.hash === true);\n  }\n\n  // update the DOM after every state mutation\n  // (obj, obj, obj, str, fn) -> null\n  function render (data, state, prev, name, createSend) {\n    _update(_router(state.location.pathname, state, prev));\n  }\n\n  // register all routes on the router\n  // (str?, [fn|[fn]]) -> obj\n  function router (defaultRoute, routes) {\n    _defaultRoute = defaultRoute;\n    _routes = routes;\n  }\n\n  // create a new model\n  // (str?, obj) -> null\n  function model (model) {\n    _store.model(model);\n  }\n\n  // register a plugin\n  // (obj) -> null\n  function use (hooks) {\n    assert.equal(typeof hooks, 'object', 'choo.use: hooks should be an object');\n    _store.use(hooks);\n  }\n\n  // create a new router with a custom `createRoute()` function\n  // (str?, obj, fn?) -> null\n  function createRouter (defaultRoute, routes, createSend) {\n    var prev = { params: {} };\n    return sheetRouter(defaultRoute, routes, createRoute);\n\n    function createRoute (routeFn) {\n      return function (route, inline, child) {\n        if (typeof inline === 'function') {\n          inline = wrap(inline, route);\n        }\n        return routeFn(route, inline, child);\n      };\n\n      function wrap (child, route) {\n        const send = createSend('view: ' + route, true);\n        return function chooWrap (params, state) {\n          const nwPrev = prev;\n          const nwState = prev = Object.assign({}, state, { params: params });\n          if (opts.freeze !== false) {\n            Object.freeze(nwState);\n          }\n          return child(nwState, nwPrev, send);\n        };\n      }\n    }\n  }\n}\n","module.exports = applyHook\n\n// apply arguments onto an array of functions, useful for hooks\n// (arr, any?, any?, any?, any?, any?) -> null\nfunction applyHook (arr, arg1, arg2, arg3, arg4, arg5) {\n  arr.forEach(function (fn) {\n    fn(arg1, arg2, arg3, arg4, arg5)\n  })\n}\n","const mutate = require('xtend/mutable')\nconst assert = require('assert')\nconst xtend = require('xtend')\n\nconst applyHook = require('./apply-hook')\n\nmodule.exports = dispatcher\n\n// initialize a new barracks instance\n// obj -> obj\nfunction dispatcher (hooks) {\n  hooks = hooks || {}\n  assert.equal(typeof hooks, 'object', 'barracks: hooks should be undefined or an object')\n\n  const onStateChangeHooks = []\n  const onActionHooks = []\n  const onErrorHooks = []\n\n  const subscriptionWraps = []\n  const initialStateWraps = []\n  const reducerWraps = []\n  const effectWraps = []\n\n  use(hooks)\n\n  var reducersCalled = false\n  var effectsCalled = false\n  var stateCalled = false\n  var subsCalled = false\n\n  const subscriptions = start._subscriptions = {}\n  const reducers = start._reducers = {}\n  const effects = start._effects = {}\n  const models = start._models = []\n  var _state = {}\n\n  start.model = setModel\n  start.state = getState\n  start.start = start\n  start.use = use\n  return start\n\n  // push an object of hooks onto an array\n  // obj -> null\n  function use (hooks) {\n    assert.equal(typeof hooks, 'object', 'barracks.use: hooks should be an object')\n    assert.ok(!hooks.onError || typeof hooks.onError === 'function', 'barracks.use: onError should be undefined or a function')\n    assert.ok(!hooks.onAction || typeof hooks.onAction === 'function', 'barracks.use: onAction should be undefined or a function')\n    assert.ok(!hooks.onStateChange || typeof hooks.onStateChange === 'function', 'barracks.use: onStateChange should be undefined or a function')\n\n    if (hooks.onStateChange) onStateChangeHooks.push(hooks.onStateChange)\n    if (hooks.onError) onErrorHooks.push(wrapOnError(hooks.onError))\n    if (hooks.onAction) onActionHooks.push(hooks.onAction)\n    if (hooks.wrapSubscriptions) subscriptionWraps.push(hooks.wrapSubscriptions)\n    if (hooks.wrapInitialState) initialStateWraps.push(hooks.wrapInitialState)\n    if (hooks.wrapReducers) reducerWraps.push(hooks.wrapReducers)\n    if (hooks.wrapEffects) effectWraps.push(hooks.wrapEffects)\n  }\n\n  // push a model to be initiated\n  // obj -> null\n  function setModel (model) {\n    assert.equal(typeof model, 'object', 'barracks.store.model: model should be an object')\n    models.push(model)\n  }\n\n  // get the current state from the store\n  // obj? -> obj\n  function getState (opts) {\n    opts = opts || {}\n    assert.equal(typeof opts, 'object', 'barracks.store.state: opts should be an object')\n\n    const state = opts.state\n    if (!opts.state && opts.freeze === false) return xtend(_state)\n    else if (!opts.state) return Object.freeze(xtend(_state))\n    assert.equal(typeof state, 'object', 'barracks.store.state: state should be an object')\n\n    const namespaces = []\n    const newState = {}\n\n    // apply all fields from the model, and namespaced fields from the passed\n    // in state\n    models.forEach(function (model) {\n      const ns = model.namespace\n      namespaces.push(ns)\n      const modelState = model.state || {}\n      if (ns) {\n        newState[ns] = newState[ns] || {}\n        apply(ns, modelState, newState)\n        newState[ns] = xtend(newState[ns], state[ns])\n      } else {\n        mutate(newState, modelState)\n      }\n    })\n\n    // now apply all fields that weren't namespaced from the passed in state\n    Object.keys(state).forEach(function (key) {\n      if (namespaces.indexOf(key) !== -1) return\n      newState[key] = state[key]\n    })\n\n    const tmpState = xtend(_state, xtend(state, newState))\n    const wrappedState = wrapHook(tmpState, initialStateWraps)\n\n    return (opts.freeze === false)\n      ? wrappedState\n      : Object.freeze(wrappedState)\n  }\n\n  // initialize the store hooks, get the send() function\n  // obj? -> fn\n  function start (opts) {\n    opts = opts || {}\n    assert.equal(typeof opts, 'object', 'barracks.store.start: opts should be undefined or an object')\n\n    // register values from the models\n    models.forEach(function (model) {\n      const ns = model.namespace\n      if (!stateCalled && model.state && opts.state !== false) {\n        const modelState = model.state || {}\n        if (ns) {\n          _state[ns] = _state[ns] || {}\n          apply(ns, modelState, _state)\n        } else {\n          mutate(_state, modelState)\n        }\n      }\n      if (!reducersCalled && model.reducers && opts.reducers !== false) {\n        apply(ns, model.reducers, reducers, function (cb) {\n          return wrapHook(cb, reducerWraps)\n        })\n      }\n      if (!effectsCalled && model.effects && opts.effects !== false) {\n        apply(ns, model.effects, effects, function (cb) {\n          return wrapHook(cb, effectWraps)\n        })\n      }\n      if (!subsCalled && model.subscriptions && opts.subscriptions !== false) {\n        apply(ns, model.subscriptions, subscriptions, function (cb, key) {\n          const send = createSend('subscription: ' + (ns ? ns + ':' + key : key))\n          cb = wrapHook(cb, subscriptionWraps)\n          cb(send, function (err) {\n            applyHook(onErrorHooks, err, _state, createSend)\n          })\n          return cb\n        })\n      }\n    })\n\n    // the state wrap is special because we want to operate on the full\n    // state rather than indvidual chunks, so we apply it outside the loop\n    if (!stateCalled && opts.state !== false) {\n      _state = wrapHook(_state, initialStateWraps)\n    }\n\n    if (!opts.noSubscriptions) subsCalled = true\n    if (!opts.noReducers) reducersCalled = true\n    if (!opts.noEffects) effectsCalled = true\n    if (!opts.noState) stateCalled = true\n\n    if (!onErrorHooks.length) onErrorHooks.push(wrapOnError(defaultOnError))\n\n    return createSend\n\n    // call an action from a view\n    // (str, bool?) -> (str, any?, fn?) -> null\n    function createSend (selfName, callOnError) {\n      assert.equal(typeof selfName, 'string', 'barracks.store.start.createSend: selfName should be a string')\n      assert.ok(!callOnError || typeof callOnError === 'boolean', 'barracks.store.start.send: callOnError should be undefined or a boolean')\n\n      return function send (name, data, cb) {\n        if (!cb && !callOnError) {\n          cb = data\n          data = null\n        }\n        data = (typeof data === 'undefined' ? null : data)\n\n        assert.equal(typeof name, 'string', 'barracks.store.start.send: name should be a string')\n        assert.ok(!cb || typeof cb === 'function', 'barracks.store.start.send: cb should be a function')\n\n        const done = callOnError ? onErrorCallback : cb\n        _send(name, data, selfName, done)\n\n        function onErrorCallback (err) {\n          err = err || null\n          if (err) {\n            applyHook(onErrorHooks, err, _state, function createSend (selfName) {\n              return function send (name, data) {\n                assert.equal(typeof name, 'string', 'barracks.store.start.send: name should be a string')\n                data = (typeof data === 'undefined' ? null : data)\n                _send(name, data, selfName, done)\n              }\n            })\n          }\n        }\n      }\n    }\n\n    // call an action\n    // (str, str, any, fn) -> null\n    function _send (name, data, caller, cb) {\n      assert.equal(typeof name, 'string', 'barracks._send: name should be a string')\n      assert.equal(typeof caller, 'string', 'barracks._send: caller should be a string')\n      assert.equal(typeof cb, 'function', 'barracks._send: cb should be a function')\n\n      setTimeout(function () {\n        var reducersCalled = false\n        var effectsCalled = false\n        const newState = xtend(_state)\n\n        if (onActionHooks.length) {\n          applyHook(onActionHooks, data, _state, name, caller, createSend)\n        }\n\n        // validate if a namespace exists. Namespaces are delimited by ':'.\n        var actionName = name\n        if (/:/.test(name)) {\n          const arr = name.split(':')\n          var ns = arr.shift()\n          actionName = arr.join(':')\n        }\n\n        const _reducers = ns ? reducers[ns] : reducers\n        if (_reducers && _reducers[actionName]) {\n          if (ns) {\n            const reducedState = _reducers[actionName](data, _state[ns])\n            newState[ns] = xtend(_state[ns], reducedState)\n          } else {\n            mutate(newState, reducers[actionName](data, _state))\n          }\n          reducersCalled = true\n          if (onStateChangeHooks.length) {\n            applyHook(onStateChangeHooks, data, newState, _state, actionName, createSend)\n          }\n          _state = newState\n          cb(null, newState)\n        }\n\n        const _effects = ns ? effects[ns] : effects\n        if (!reducersCalled && _effects && _effects[actionName]) {\n          const send = createSend('effect: ' + name)\n          if (ns) _effects[actionName](data, _state[ns], send, cb)\n          else _effects[actionName](data, _state, send, cb)\n          effectsCalled = true\n        }\n\n        if (!reducersCalled && !effectsCalled) {\n          throw new Error('Could not find action ' + actionName)\n        }\n      }, 0)\n    }\n  }\n}\n\n// compose an object conditionally\n// optionally contains a namespace\n// which is used to nest properties.\n// (str, obj, obj, fn?) -> null\nfunction apply (ns, source, target, wrap) {\n  if (ns && !target[ns]) target[ns] = {}\n  Object.keys(source).forEach(function (key) {\n    const cb = wrap ? wrap(source[key], key) : source[key]\n    if (ns) target[ns][key] = cb\n    else target[key] = cb\n  })\n}\n\n// handle errors all the way at the top of the trace\n// err? -> null\nfunction defaultOnError (err) {\n  throw err\n}\n\nfunction wrapOnError (onError) {\n  return function onErrorWrap (err, state, createSend) {\n    if (err) onError(err, state, createSend)\n  }\n}\n\n// take a apply an array of transforms onto a value. The new value\n// must be returned synchronously from the transform\n// (any, [fn]) -> any\nfunction wrapHook (value, transforms) {\n  transforms.forEach(function (transform) {\n    value = transform(value)\n  })\n  return value\n}\n","module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n    var target = {}\n\n    for (var i = 0; i < arguments.length; i++) {\n        var source = arguments[i]\n\n        for (var key in source) {\n            if (hasOwnProperty.call(source, key)) {\n                target[key] = source[key]\n            }\n        }\n    }\n\n    return target\n}\n","module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend(target) {\n    for (var i = 1; i < arguments.length; i++) {\n        var source = arguments[i]\n\n        for (var key in source) {\n            if (hasOwnProperty.call(source, key)) {\n                target[key] = source[key]\n            }\n        }\n    }\n\n    return target\n}\n","var duetChannel = require('duet-channel');\n\nfunction onclick(event) {\n    if (event.target.localName !== 'a' ||\n        event.target.href === undefined ||\n        window.location.host !== event.target.host) {\n        return;\n    }\n\n    event.preventDefault();\n\n    channel.postMessageToWorker({\n        type: 'CHANGE',\n        data: event.target.href\n    });\n\n    window.history.pushState({}, null, event.target.href)\n}\n\nfunction onpopstate() {\n    channel.postMessageToWorker({\n        type: 'CHANGE',\n        data: document.location.href\n    });\n}\n\nfunction connected(counterpartName) {\n    if (counterpartName !== 'main') {\n        return;\n    }\n\n    window.onclick = onclick;\n    window.onpopstate = onpopstate;\n}\n\nvar channel = duetChannel('LOCATION', connected);\n\nmodule.exports = channel;\n","var hashMatch     = require('hash-match');\nvar pathnameMatch = require('pathname-match');\nvar channel       = require('./channel');\n\nvar subscribers = [];\n\nfunction subscribe(callback, isHashSubscriber) {\n    if (typeof callback !== 'function') {\n        return;\n    }\n\n    subscribers.push({\n        callback: callback,\n        isHashSubscriber: !!isHashSubscriber\n    })\n\n    channel.postMessageToMain({\n        type: 'SUBSCRIBER',\n        data: subscribers.length - 1\n    });\n}\n\nfunction parseLocation(href) {\n    var path, hash, splitHREF;\n\n    path = pathnameMatch(href);\n\n    if (!path.length) {\n        path = '/';\n    }\n\n    hash = '';\n    splitHREF = href.split('#');\n\n    if (splitHREF.length > 1) {\n        hash = hashMatch('#'.concat(splitHREF.slice(1).join('#')));\n    }\n\n    return {\n        path: path,\n        hash: hash\n    }\n}\n\nfunction notify(subscriber, location) {\n    if (!subscriber.isHashSubscriber) {\n        subscriber.callback(location.path);\n    } else if (location.hash) {\n        subscriber.callback(location.hash);\n    }\n}\n\nfunction notifyAll(location) {\n    subscribers.forEach(function (subscriber) {\n        notify(subscriber, location);\n    });\n}\n\nfunction onSubscriber(data) {\n    channel.postMessageToWorker({\n        type: 'INITIAL',\n        data: {\n            subscriberKey: data,\n            href: document.location.href\n        }\n    });\n}\n\nfunction onInitial(data) {\n    notify(subscribers[data.subscriberKey], parseLocation(data.href));\n}\n\nfunction onChange(data) {\n    if (subscribers.length > 0) {\n        notifyAll(parseLocation(data));\n    }\n}\n\nchannel.on('SUBSCRIBER', onSubscriber);\nchannel.on('INITIAL', onInitial);\nchannel.on('CHANGE', onChange);\n\nmodule.exports = subscribe;\n","module.exports = function duetChannel(namespace, callback) {\n    var _postMessageToMain = null;\n    var _postMessageToWorker = null;\n    var mainQueue = [];\n    var workerQueue = [];\n    var messageHandlers = {};\n\n    function connectMain(postMessage) {\n        _postMessageToWorker = postMessage;\n\n        if (typeof callback === 'function') {\n            callback('main');\n        }\n\n        while (workerQueue.length) {\n            _postMessageToWorker(workerQueue.shift());\n        }\n\n        workerQueue = null;\n    }\n\n    function connectWorker(postMessage) {\n        _postMessageToMain = postMessage;\n\n        if (typeof callback === 'function') {\n            callback('worker');\n        }\n\n        while (mainQueue.length) {\n            _postMessageToMain(mainQueue.shift());\n        }\n\n        mainQueue = null;\n    }\n\n    function postMessageToMain(message) {\n        if (typeof _postMessageToMain === 'function') {\n            return _postMessageToMain(message);\n        }\n\n        mainQueue.push(message);\n    }\n\n    function postMessageToWorker(message) {\n        if (typeof _postMessageToWorker === 'function') {\n            return _postMessageToWorker(message);\n        }\n\n        workerQueue.push(message);\n    }\n\n    function handleMessage(type, data) {\n        var messageHandler = messageHandlers[type];\n\n        if (messageHandler != null) {\n            messageHandler(data);\n        }\n    }\n\n    function on(type, messageHandler) {\n        messageHandlers[type] = messageHandler;\n    }\n\n    return {\n        // Used by duet\n        namespace: namespace,\n        connectMain: connectMain,\n        connectWorker: connectWorker,\n        handleMessage: handleMessage,\n\n        // Used by plugin\n        postMessageToMain: postMessageToMain,\n        postMessageToWorker: postMessageToWorker,\n        on: on\n    };\n};\n","module.exports = function hashMatch (hash, prefix) {\n  var pre = prefix || '/';\n  if (hash.length === 0) return pre;\n  hash = hash.replace('#', '');\n  hash = hash.replace(/\\/$/, '')\n  if (hash.indexOf('/') != 0) hash = '/' + hash;\n  if (pre == '/') return hash;\n  else return hash.replace(pre, '');\n}\n","const assert = require('assert')\n\nmodule.exports = match\n\n// get url path section from a url\n// strip querystrings / hashes\n// strip protocol\n// strip hostname and port (both ip and route)\n// str -> str\nfunction match (route) {\n  assert.equal(typeof route, 'string')\n\n  return route.trim()\n    .replace(/[\\?|#].*$/, '')\n    .replace(/^(?:https?\\:)\\/\\//, '')\n    .replace(/^.*?(\\/.*)/, '$1')\n    .replace(/\\/$/, '')\n}\n","module.exports = require('duet-channel')('VIRTUAL_DOM');\n","// https://developer.mozilla.org/en-US/docs/Web/Events\n\nmodule.exports = [\n\n    // CSSOM\n    'animationend',\n\t'animationiteration',\n\t'animationstart',\n\t'transitionend',\n\n    // DOM\n\t'abort',\n\t'beforeinput',\n\t'blur',\n\t'click',\n\t'compositionend',\n\t'compositionstart',\n\t'compositionupdate',\n\t'dblclick',\n\t'error',\n\t'focus',\n\t'focusin',\n\t'focusout',\n\t'input',\n\t'keydown',\n\t'keyup',\n\t'load',\n\t'mousedown',\n\t'mouseenter',\n\t'mouseleave',\n\t'mousemove',\n\t'mouseout',\n\t'mouseover',\n\t'mouseup',\n\t'resize',\n\t'scroll',\n\t'select',\n\t'unload',\n\t'wheel',\n\n    // HTML DOM\n\t'DOMContentLoaded',\n\t// 'abort',\n\t'afterprint',\n\t'afterscriptexecute',\n\t'autocomplete',\n\t'autocompleteerror',\n\t'beforeprint',\n\t'beforescriptexecute',\n\t'beforeunload',\n\t// 'blur',\n\t'cancel',\n\t'canplay',\n\t'canplaythrough',\n\t'change',\n\t// 'click',\n\t'close',\n\t'connect',\n\t'contextmenu',\n\t'durationchange',\n\t'emptied',\n\t'error',\n\t// 'focus',\n\t'hashchange',\n\t// 'input',\n\t'invalid',\n\t'languagechange',\n\t// 'load',\n\t'loadeddata',\n\t'loadedmetadata',\n\t'loadend',\n\t'loadstart',\n\t'message',\n\t'offline',\n\t'online',\n\t'open',\n\t'pagehide',\n\t'pageshow',\n\t'play',\n\t'playing',\n\t'popstate',\n\t'progress',\n\t'readystatechange',\n\t'reset',\n\t'seeked',\n\t'seeking',\n\t'select',\n\t'show',\n\t'sort',\n\t'stalled',\n\t'storage',\n\t'submit',\n\t'suspend',\n\t'timeupdate',\n\t'toggle',\n\t// 'unload',\n\t'volumechange',\n\t'waiting',\n\n    // HTML Drag and Drop API\n    'drag',\n\t'dragend',\n\t'dragenter',\n\t'dragexit',\n\t'dragleave',\n\t'dragover',\n\t'dragstart',\n\t'drop',\n\n    // Pointer\n\t'gotpointercapture',\n\t'lostpointercapture',\n\t'pointercancel',\n\t'pointerdown',\n\t'pointerenter',\n\t'pointerleave',\n\t'pointermove',\n\t'pointerout',\n\t'pointerover',\n\t'pointerup',\n\n    // Selection\n\t'selectionchange',\n\t'selectstart',\n\n    // Touch\n\t'touchcancel',\n\t'touchend',\n\t'touchmove',\n\t'touchstart'\n\n];\n","var walk        = require('tree-walk');\nvar VirtualNode = require('virtual-dom/vnode/vnode');\nvar diff        = require('virtual-dom/diff');\nvar serialize   = require('vdom-serialized-patch/serialize');\nvar patch       = require('vdom-serialized-patch/patch');\nvar getFormData = require('form-data-set/element');\nvar channel     = require('./channel');\nvar eventNames  = require('./eventNames');\nvar concat      = Array.prototype.concat;\n\nvar nextStoreKey = 0;\nvar store = {};\n\nfunction vdom(selector, options) {\n    var key = nextStoreKey++;\n\n    options = typeof options === 'object' ? options : {};\n\n    store[key] = {\n        tree: new VirtualNode('div'),\n        eventHandlers: []\n    };\n\n    channel.postMessageToMain({\n        type: 'CREATE',\n        data: {\n            key: key,\n            selector: selector,\n            isTarget: !!options.isTarget\n        }\n    });\n\n    if (options.tree) {\n        update(key, options.tree);\n    }\n\n    return update.bind(null, key);\n}\n\nfunction update(key, tree) {\n    var stored, serializedDiff;\n\n    stored = store[key];\n\n    stored.eventHandlers.length = 0;\n\n    walk.preorder(tree, function (value, key, parent) {\n        if (eventNames.indexOf(key) > -1) {\n            parent[key] = stored.eventHandlers.length;\n            stored.eventHandlers.push(value);\n        }\n    });\n\n    serializedDiff = serialize(diff(stored.tree, tree));\n\n    stored.tree = tree;\n\n    channel.postMessageToMain({\n        type: 'PATCH',\n        data: {\n            key: key,\n            diff: serializedDiff\n        }\n    });\n\n}\n\nfunction primitivePropsReducer(obj, atObj, props, key) {\n    var value;\n\n    try {\n        value = obj[key];\n    } catch (e) {\n        return props;\n    }\n\n    if (key.charAt(0) === key.charAt(0).toLowerCase() && (\n        typeof value === 'number' ||\n        typeof value === 'string' ||\n        typeof value === 'boolean')) {\n\n        props[key] = value;\n    }\n\n    return props;\n}\n\nfunction getPrimitiveProps(obj, atObj) {\n    var props = {};\n\n    if (atObj) {\n        return Object.keys(atObj).reduce(primitivePropsReducer.bind(null, obj, atObj), props);\n    }\n\n    for (key in obj) {\n        props = primitivePropsReducer(obj, obj, props, key);\n    }\n\n    return props;\n}\n\nfunction eventListener(key, eventName, event) {\n    var target, handlerKey, eventData, valueData;\n\n    target = event.target;\n\n    while ((handlerKey = target.dataset[eventName]) == null && target !== document.documentElement) {\n        target = target.parentElement;\n    }\n\n    if (typeof handlerKey === 'string') {\n\n        setTimeout(function () {\n            eventData = getPrimitiveProps(event, event.constructor.prototype);\n            eventData.target = getPrimitiveProps(target, Element);\n            valueData = getFormData(target);\n\n            if (!(new RegExp('\\\\b' + eventName + '\\\\b')).test(target.dataset.preventDefault)) {\n                event.preventDefault();\n            }\n\n            channel.postMessageToWorker({\n                type: 'EVENT',\n                data: {\n                    key: key,\n                    handlerKey: handlerKey,\n                    eventData: eventData,\n                    valueData: valueData\n                }\n            });\n        }, 0);\n\n    }\n}\n\nfunction updateDom(data) {\n    var stored, activeEventNames, activeElement;\n\n    function updateActiveEventsForDataAttributes(el) {\n        Object.keys(el.dataset)\n        .forEach(updateActiveEventsForDataAttribute);\n    }\n\n    function updateActiveEventsForDataAttribute(propName) {\n        if (eventNames.indexOf(propName) > -1 && activeEventNames.indexOf(propName) < 0) {\n            activeEventNames.push(propName);\n        }\n    }\n\n    function listenTo(eventName) {\n        stored.eventListeners[eventName] = eventListener.bind(null, data.key, eventName);\n        stored.target.addEventListener(eventName, stored.eventListeners[eventName]);\n    }\n\n    function unlistenTo(eventName) {\n        stored.target.removeEventListener(eventName, stored.eventListeners[eventName]);\n        delete stored.eventListeners[eventName];\n    }\n\n    function updateEventBinding(eventName) {\n        if (activeEventNames.indexOf(eventName) > -1 && stored.eventListeners[eventName] == null) {\n            listenTo(eventName);\n        } else if (activeEventNames.indexOf(eventName) < 0 && stored.eventListeners[eventName] != null) {\n            unlistenTo(eventName);\n        }\n    }\n\n    stored = store[data.key];\n\n    // 1) Patch DOM\n\n    stored.target = patch(stored.target, data.diff);\n\n    // 2) Update DOM event bindings\n\n    activeEventNames = [];\n\n    concat.apply(stored.target, stored.target.getElementsByTagName('*'))\n    .forEach(updateActiveEventsForDataAttributes);\n\n    eventNames.forEach(updateEventBinding);\n\n    // 3) Focus element if needed\n\n    activeElement = stored.target.querySelector('[autofocus]');\n\n    if (activeElement != null && document.activeElement !== activeElement) {\n        activeElement.focus();\n    }\n}\n\nfunction onCreate(data) {\n    var target, stored;\n\n    target = document.querySelector(data.selector);\n\n    if (target == null) {\n        throw new Error('selector did not match an element');\n    }\n\n    stored = store[data.key];\n\n    // When not single threaded\n    if (stored == null) {\n        store[data.key] = {};\n        stored = store[data.key];\n    }\n\n    if (!!data.isTarget) {\n        stored.target = target;\n    } else {\n        stored.target = document.createElement('div');\n        target.insertBefore(stored.target, target.firstChild);\n    }\n\n    stored.eventListeners = {};\n}\n\nfunction onPatch(data) {\n    window.requestAnimationFrame(updateDom.bind(null, data));\n}\n\nfunction onEvent(data) {\n    var handler = store[data.key].eventHandlers[data.handlerKey];\n\n    if (handler != null) {\n        handler(data.eventData, data.valueData);\n    }\n}\n\nchannel.on('CREATE', onCreate);\nchannel.on('PATCH', onPatch);\nchannel.on('EVENT', onEvent);\n\nmodule.exports = vdom;\n","var walk = require('dom-walk')\n\nvar FormData = require('./index.js')\n\nmodule.exports = getFormData\n\nfunction buildElems(rootElem) {\n    var hash = {}\n    if (rootElem.name) {\n    \thash[rootElem.name] = rootElem\n    }\n\n    walk(rootElem, function (child) {\n        if (child.name) {\n            hash[child.name] = child\n        }\n    })\n\n\n    return hash\n}\n\nfunction getFormData(rootElem) {\n    var elements = buildElems(rootElem)\n\n    return FormData(elements)\n}\n","/*jshint maxcomplexity: 10*/\n\nmodule.exports = FormData\n\n//TODO: Massive spec: http://www.whatwg.org/specs/web-apps/current-work/multipage/association-of-controls-and-forms.html#constructing-form-data-set\nfunction FormData(elements) {\n    return Object.keys(elements).reduce(function (acc, key) {\n        var elem = elements[key]\n\n        acc[key] = valueOfElement(elem)\n\n        return acc\n    }, {})\n}\n\nfunction valueOfElement(elem) {\n    if (typeof elem === \"function\") {\n        return elem()\n    } else if (containsRadio(elem)) {\n        var elems = toList(elem)\n        var checked = elems.filter(function (elem) {\n            return elem.checked\n        })[0] || null\n\n        return checked ? checked.value : null\n    } else if (Array.isArray(elem)) {\n        return elem.map(valueOfElement).filter(filterNull)\n    } else if (elem.tagName === undefined && elem.nodeType === undefined) {\n        return FormData(elem)\n    } else if (elem.tagName === \"INPUT\" && isChecked(elem)) {\n        if (elem.hasAttribute(\"value\")) {\n            return elem.checked ? elem.value : null\n        } else {\n            return elem.checked\n        }\n    } else if (elem.tagName === \"INPUT\") {\n        return elem.value\n    } else if (elem.tagName === \"TEXTAREA\") {\n        return elem.value\n    } else if (elem.tagName === \"SELECT\") {\n        return elem.value\n    }\n}\n\nfunction isChecked(elem) {\n    return elem.type === \"checkbox\" || elem.type === \"radio\"\n}\n\nfunction containsRadio(value) {\n    if (value.tagName || value.nodeType) {\n        return false\n    }\n\n    var elems = toList(value)\n\n    return elems.some(function (elem) {\n        return elem.tagName === \"INPUT\" && elem.type === \"radio\"\n    })\n}\n\nfunction toList(value) {\n    if (Array.isArray(value)) {\n        return value\n    }\n\n    return Object.keys(value).map(prop, value)\n}\n\nfunction prop(x) {\n    return this[x]\n}\n\nfunction filterNull(val) {\n    return val !== null\n}\n","var slice = Array.prototype.slice\n\nmodule.exports = iterativelyWalk\n\nfunction iterativelyWalk(nodes, cb) {\n    if (!('length' in nodes)) {\n        nodes = [nodes]\n    }\n    \n    nodes = slice.call(nodes)\n\n    while(nodes.length) {\n        var node = nodes.shift(),\n            ret = cb(node)\n\n        if (ret) {\n            return ret\n        }\n\n        if (node.childNodes && node.childNodes.length) {\n            nodes = slice.call(node.childNodes).concat(nodes)\n        }\n    }\n}\n","// Copyright (c) 2014 Patrick Dubroy <pdubroy@gmail.com>\n// This software is distributed under the terms of the MIT License.\n\n'use strict';\n\nvar extend = require('util-extend'),\n    WeakMap = require('./third_party/WeakMap');  // eslint-disable-line no-undef,no-native-reassign\n\n// An internal object that can be returned from a visitor function to\n// prevent a top-down walk from walking subtrees of a node.\nvar stopRecursion = {};\n\n// An internal object that can be returned from a visitor function to\n// cause the walk to immediately stop.\nvar stopWalk = {};\n\nvar hasOwnProp = Object.prototype.hasOwnProperty;\n\n// Helpers\n// -------\n\nfunction isElement(obj) {\n  return !!(obj && obj.nodeType === 1);\n}\n\nfunction isObject(obj) {\n  var type = typeof obj;\n  return type === 'function' || type === 'object' && !!obj;\n}\n\nfunction isString(obj) {\n  return Object.prototype.toString.call(obj) === '[object String]';\n}\n\nfunction each(obj, predicate) {\n  for (var k in obj) {\n    if (obj.hasOwnProperty(k)) {\n      if (predicate(obj[k], k, obj))\n        return false;\n    }\n  }\n  return true;\n}\n\n// Returns a copy of `obj` containing only the properties given by `keys`.\nfunction pick(obj, keys) {\n  var result = {};\n  for (var i = 0, length = keys.length; i < length; i++) {\n    var key = keys[i];\n    if (key in obj) result[key] = obj[key];\n  }\n  return result;\n}\n\n// Makes a shallow copy of `arr`, and adds `obj` to the end of the copy.\nfunction copyAndPush(arr, obj) {\n  var result = arr.slice();\n  result.push(obj);\n  return result;\n}\n\n// Implements the default traversal strategy: if `obj` is a DOM node, walk\n// its DOM children; otherwise, walk all the objects it references.\nfunction defaultTraversal(obj) {\n  return isElement(obj) ? obj.children : obj;\n}\n\n// Walk the tree recursively beginning with `root`, calling `beforeFunc`\n// before visiting an objects descendents, and `afterFunc` afterwards.\n// If `collectResults` is true, the last argument to `afterFunc` will be a\n// collection of the results of walking the node's subtrees.\nfunction walkImpl(root, traversalStrategy, beforeFunc, afterFunc, context, collectResults) {\n  return (function _walk(stack, value, key, parent) {\n    if (isObject(value) && stack.indexOf(value) >= 0)\n      throw new TypeError('A cycle was detected at ' + value);\n\n    if (beforeFunc) {\n      var result = beforeFunc.call(context, value, key, parent);\n      if (result === stopWalk) return stopWalk;\n      if (result === stopRecursion) return;  // eslint-disable-line consistent-return\n    }\n\n    var subResults;\n    var target = traversalStrategy(value);\n\n    if (isObject(target) && Object.keys(target).length > 0) {\n      // Collect results from subtrees in the same shape as the target.\n      if (collectResults) subResults = Array.isArray(target) ? [] : {};\n\n      var ok = each(target, function(obj, key) {\n        var result = _walk(copyAndPush(stack, value), obj, key, value);\n        if (result === stopWalk) return false;\n        if (subResults) subResults[key] = result;\n      });\n      if (!ok) return stopWalk;\n    }\n    if (afterFunc) return afterFunc.call(context, value, key, parent, subResults);\n  })([], root);\n}\n\n// Internal helper providing the implementation for `pluck` and `pluckRec`.\nfunction pluck(obj, propertyName, recursive) {\n  var results = [];\n  this.preorder(obj, function(value, key) {\n    if (!recursive && key === propertyName)\n      return stopRecursion;\n    if (hasOwnProp.call(value, propertyName))\n      results[results.length] = value[propertyName];\n  });\n  return results;\n}\n\nfunction defineEnumerableProperty(obj, propName, getterFn) {\n  Object.defineProperty(obj, propName, {\n    enumerable: true,\n    get: getterFn\n  });\n}\n\n// Returns an object containing the walk functions. If `traversalStrategy`\n// is specified, it is a function determining how objects should be\n// traversed. Given an object, it returns the object to be recursively\n// walked. The default strategy is equivalent to `_.identity` for regular\n// objects, and for DOM nodes it returns the node's DOM children.\nfunction Walker(traversalStrategy) {\n  if (!(this instanceof Walker))\n    return new Walker(traversalStrategy);\n\n  // There are two different strategy shorthands: if a single string is\n  // specified, treat the value of that property as the traversal target.\n  // If an array is specified, the traversal target is the node itself, but\n  // only the properties contained in the array will be traversed.\n  if (isString(traversalStrategy)) {\n    var prop = traversalStrategy;\n    traversalStrategy = function(node) {\n      if (isObject(node) && prop in node) return node[prop];\n    };\n  } else if (Array.isArray(traversalStrategy)) {\n    var props = traversalStrategy;\n    traversalStrategy = function(node) {\n      if (isObject(node)) return pick(node, props);\n    };\n  }\n  this._traversalStrategy = traversalStrategy || defaultTraversal;\n}\n\nextend(Walker.prototype, {\n  STOP_RECURSION: stopRecursion,\n\n  // Performs a preorder traversal of `obj` and returns the first value\n  // which passes a truth test.\n  find: function(obj, visitor, context) {\n    var result;\n    this.preorder(obj, function(value, key, parent) {\n      if (visitor.call(context, value, key, parent)) {\n        result = value;\n        return stopWalk;\n      }\n    }, context);\n    return result;\n  },\n\n  // Recursively traverses `obj` and returns all the elements that pass a\n  // truth test. `strategy` is the traversal function to use, e.g. `preorder`\n  // or `postorder`.\n  filter: function(obj, strategy, visitor, context) {\n    var results = [];\n    if (obj === null) return results;\n    strategy(obj, function(value, key, parent) {\n      if (visitor.call(context, value, key, parent)) results.push(value);\n    }, null, this._traversalStrategy);\n    return results;\n  },\n\n  // Recursively traverses `obj` and returns all the elements for which a\n  // truth test fails.\n  reject: function(obj, strategy, visitor, context) {\n    return this.filter(obj, strategy, function(value, key, parent) {\n      return !visitor.call(context, value, key, parent);\n    });\n  },\n\n  // Produces a new array of values by recursively traversing `obj` and\n  // mapping each value through the transformation function `visitor`.\n  // `strategy` is the traversal function to use, e.g. `preorder` or\n  // `postorder`.\n  map: function(obj, strategy, visitor, context) {\n    var results = [];\n    strategy(obj, function(value, key, parent) {\n      results[results.length] = visitor.call(context, value, key, parent);\n    }, null, this._traversalStrategy);\n    return results;\n  },\n\n  // Return the value of properties named `propertyName` reachable from the\n  // tree rooted at `obj`. Results are not recursively searched; use\n  // `pluckRec` for that.\n  pluck: function(obj, propertyName) {\n    return pluck.call(this, obj, propertyName, false);\n  },\n\n  // Version of `pluck` which recursively searches results for nested objects\n  // with a property named `propertyName`.\n  pluckRec: function(obj, propertyName) {\n    return pluck.call(this, obj, propertyName, true);\n  },\n\n  // Recursively traverses `obj` in a depth-first fashion, invoking the\n  // `visitor` function for each object only after traversing its children.\n  // `traversalStrategy` is intended for internal callers, and is not part\n  // of the public API.\n  postorder: function(obj, visitor, context, traversalStrategy) {\n    traversalStrategy = traversalStrategy || this._traversalStrategy;\n    walkImpl(obj, traversalStrategy, null, visitor, context);\n  },\n\n  // Recursively traverses `obj` in a depth-first fashion, invoking the\n  // `visitor` function for each object before traversing its children.\n  // `traversalStrategy` is intended for internal callers, and is not part\n  // of the public API.\n  preorder: function(obj, visitor, context, traversalStrategy) {\n    traversalStrategy = traversalStrategy || this._traversalStrategy;\n    walkImpl(obj, traversalStrategy, visitor, null, context);\n  },\n\n  // Builds up a single value by doing a post-order traversal of `obj` and\n  // calling the `visitor` function on each object in the tree. For leaf\n  // objects, the `memo` argument to `visitor` is the value of the `leafMemo`\n  // argument to `reduce`. For non-leaf objects, `memo` is a collection of\n  // the results of calling `reduce` on the object's children.\n  reduce: function(obj, visitor, leafMemo, context) {\n    var reducer = function(value, key, parent, subResults) {\n      return visitor(subResults || leafMemo, value, key, parent);\n    };\n    return walkImpl(obj, this._traversalStrategy, null, reducer, context, true);\n  },\n\n  // An 'attribute' is a value that is calculated by invoking a visitor\n  // function on a node. The first argument of the visitor is a collection\n  // of the attribute values for the node's children. These are calculated\n  // lazily -- in this way the visitor can decide in what order to visit the\n  // subtrees.\n  createAttribute: function(visitor, defaultValue, context) {\n    var self = this;\n    var memo = new WeakMap();\n    function _visit(stack, value, key, parent) {\n      if (isObject(value) && stack.indexOf(value) >= 0)\n        throw new TypeError('A cycle was detected at ' + value);\n\n      if (memo.has(value))\n        return memo.get(value);\n\n      var subResults;\n      var target = self._traversalStrategy(value);\n      if (isObject(target) && Object.keys(target).length > 0) {\n        subResults = {};\n        each(target, function(child, k) {\n          defineEnumerableProperty(subResults, k, function() {\n            return _visit(copyAndPush(stack, value), child, k, value);\n          });\n        });\n      }\n      var result = visitor.call(context, subResults, value, key, parent);\n      memo.set(value, result);\n      return result;\n    }\n    return function(obj) { return _visit([], obj); };\n  }\n});\n\nvar WalkerProto = Walker.prototype;\n\n// Set up a few convenient aliases.\nWalkerProto.each = WalkerProto.preorder;\nWalkerProto.collect = WalkerProto.map;\nWalkerProto.detect = WalkerProto.find;\nWalkerProto.select = WalkerProto.filter;\n\n// Export the walker constructor, but make it behave like an instance.\nWalker._traversalStrategy = defaultTraversal;\nmodule.exports = extend(Walker, WalkerProto);\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = extend;\nfunction extend(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || typeof add !== 'object') return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n}\n","/*\n * Copyright 2012 The Polymer Authors. All rights reserved.\n * Use of this source code is governed by a BSD-style\n * license that can be found in the LICENSE file.\n */\n\nif (typeof WeakMap === 'undefined') {\n  (function() {\n    var defineProperty = Object.defineProperty;\n    var counter = Date.now() % 1e9;\n\n    var WeakMap = function() {\n      this.name = '__st' + (Math.random() * 1e9 >>> 0) + (counter++ + '__');\n    };\n\n    WeakMap.prototype = {\n      set: function(key, value) {\n        var entry = key[this.name];\n        if (entry && entry[0] === key)\n          entry[1] = value;\n        else\n          defineProperty(key, this.name, {value: [key, value], writable: true});\n        return this;\n      },\n      get: function(key) {\n        var entry;\n        return (entry = key[this.name]) && entry[0] === key ?\n            entry[1] : undefined;\n      },\n      delete: function(key) {\n        var entry = key[this.name];\n        if (!entry || entry[0] !== key) return false;\n        entry[0] = entry[1] = undefined;\n        return true;\n      },\n      has: function(key) {\n        var entry = key[this.name];\n        if (!entry) return false;\n        return entry[0] === key;\n      }\n    };\n\n    module.exports = WeakMap;\n  })();\n} else {\n  module.exports = WeakMap;\n}\n","var isObject = require('./isObject');\nvar isSoftSetHook = require('./isSoftSetHook');\n\nmodule.exports = applyProperties;\n\nfunction applyProperties(node, props, previous) {\n  for (var propName in props) {\n    var propValue = props[propName]\n\n    if (propValue === undefined) {\n      removeProperty(node, propName, previous);\n    } else if (isSoftSetHook(propValue)) {\n      removeProperty(node, propName, propValue, previous)\n      node[propName] = propValue.value\n    } else {\n      if (isObject(propValue)) {\n        patchObject(node, props, previous, propName, propValue);\n      } else {\n        node[propName] = propValue\n      }\n    }\n  }\n}\n\nfunction removeProperty(node, propName, previous) {\n  if (!previous) {\n    return\n  }\n  var previousValue = previous[propName]\n\n  if (propName === \"attributes\") {\n    for (var attrName in previousValue) {\n      node.removeAttribute(attrName)\n    }\n  } else if (propName === \"style\") {\n    for (var i in previousValue) {\n      node.style[i] = \"\"\n    }\n  } else if (typeof previousValue === \"string\") {\n    node[propName] = \"\"\n  } else {\n    node[propName] = null\n  }\n}\n\nfunction patchObject(node, props, previous, propName, propValue) {\n  var previousValue = previous ? previous[propName] : undefined\n\n  // Set attributes\n  if (propName === \"attributes\") {\n    for (var attrName in propValue) {\n      var attrValue = propValue[attrName]\n\n      if (attrValue === undefined) {\n        node.removeAttribute(attrName)\n      } else {\n        node.setAttribute(attrName, attrValue)\n      }\n    }\n\n    return\n  }\n\n  if (previousValue && isObject(previousValue) &&\n    getPrototype(previousValue) !== getPrototype(propValue)) {\n    node[propName] = propValue\n    return\n  }\n\n  if (!isObject(node[propName])) {\n    node[propName] = {}\n  }\n\n  var replacer = propName === \"style\" ? \"\" : undefined\n\n  for (var k in propValue) {\n    var value = propValue[k]\n    node[propName][k] = (value === undefined) ? replacer : value\n  }\n}\n\nfunction getPrototype(value) {\n  // getPrototypeOf shim for older browsers\n  /* istanbul ignore else */\n  if (Object.getPrototypeOf) {\n    return Object.getPrototypeOf(value)\n  } else {\n    return value.__proto__ || value.constructor.prototype;\n  }\n}\n","var applyProperties = require(\"./applyProperties\")\nvar isVText = require('./isVText');\nvar isVNode = require('./isVNode');\n\nmodule.exports = createElement;\n\nfunction createElement(vnode) {\n  var doc = document;\n\n  if (isVText(vnode)) {\n    return doc.createTextNode(vnode.x) // 'x' means 'text'\n  } else if (!isVNode(vnode)) {\n    return null\n  }\n\n  var node = (!vnode.n) ? // 'n' === 'namespace'\n    doc.createElement(vnode.tn) : // 'tn' === 'tagName'\n    doc.createElementNS(vnode.n, vnode.tn)\n\n  var props = vnode.p // 'p' === 'properties'\n  applyProperties(node, props)\n\n  var children = vnode.c // 'c' === 'children'\n\n  if (children) {\n    for (var i = 0; i < children.length; i++) {\n      var childNode = createElement(children[i])\n      if (childNode) {\n        node.appendChild(childNode)\n      }\n    }\n  }\n\n  return node\n}\n","// Maps a virtual DOM tree onto a real DOM tree in an efficient manner.\n// We don't want to read all of the DOM nodes in the tree so we use\n// the in-order tree indexing to eliminate recursion down certain branches.\n// We only recurse into a DOM node if we know that it contains a child of\n// interest.\n\nvar noChild = {}\n\nmodule.exports = domIndex\n\nfunction domIndex(rootNode, tree, indices, nodes) {\n  if (!indices || indices.length === 0) {\n    return {}\n  } else {\n    indices.sort(ascending)\n    return recurse(rootNode, tree, indices, nodes, 0)\n  }\n}\n\nfunction recurse(rootNode, tree, indices, nodes, rootIndex) {\n  nodes = nodes || {}\n\n\n  if (rootNode) {\n    if (indexInRange(indices, rootIndex, rootIndex)) {\n      nodes[rootIndex] = rootNode\n    }\n\n    var treeChildren = tree[0];\n\n    if (treeChildren) {\n\n      var childNodes = rootNode.childNodes\n\n      for (var i = 0; i < treeChildren.length; i++) {\n        rootIndex += 1\n\n        var vChild = treeChildren[i] || noChild\n        var nextIndex = rootIndex + (vChild[1] || 0)\n\n        // skip recursion down the tree if there are no nodes down here\n        if (indexInRange(indices, rootIndex, nextIndex)) {\n          recurse(childNodes[i], vChild, indices, nodes, rootIndex)\n        }\n\n        rootIndex = nextIndex\n      }\n    }\n  }\n\n  return nodes\n}\n\n// Binary search for an index in the interval [left, right]\nfunction indexInRange(indices, left, right) {\n  if (indices.length === 0) {\n    return false\n  }\n\n  var minIndex = 0\n  var maxIndex = indices.length - 1\n  var currentIndex\n  var currentItem\n\n  while (minIndex <= maxIndex) {\n    currentIndex = ((maxIndex + minIndex) / 2) >> 0\n    currentItem = indices[currentIndex]\n\n    if (minIndex === maxIndex) {\n      return currentItem >= left && currentItem <= right\n    } else if (currentItem < left) {\n      minIndex = currentIndex + 1\n    } else if (currentItem > right) {\n      maxIndex = currentIndex - 1\n    } else {\n      return true\n    }\n  }\n\n  return false;\n}\n\nfunction ascending(a, b) {\n  return a > b ? 1 : -1\n}\n","var patchRecursive = require('./patchRecursive');\n\nfunction patch(rootNode, patches) {\n  return patchRecursive(rootNode, patches);\n}\n\nmodule.exports = patch;","'use strict';\n\nmodule.exports = function isObject(x) {\n  return typeof x === \"object\" && x !== null;\n};","module.exports = isSoftSetHook\n\nfunction isSoftSetHook(x) {\n  return x && typeof x === 'object' && typeof x.value !== 'undefined';\n}\n","module.exports = isVirtualNode\n\nvar types = require('./types');\n\nfunction isVirtualNode(x) {\n  return x && x.t === types.VirtualNode\n}\n","module.exports = isVirtualText\n\nvar types = require('./types');\n\nfunction isVirtualText(x) {\n  return x && x.t === types.VirtualTree;\n}\n","var applyProperties = require(\"./applyProperties\");\nvar patchTypes = require(\"../patchTypes\");\nvar render = require('./createElement');\n\nmodule.exports = applyPatch\n\nfunction applyPatch(vpatch, domNode, patchRecursive) {\n  var type = vpatch[0]\n  var patch = vpatch[1]\n  var vNode = vpatch[2]\n\n  switch (type) {\n    case patchTypes.REMOVE:\n      return removeNode(domNode)\n    case patchTypes.INSERT:\n      return insertNode(domNode, patch)\n    case patchTypes.VTEXT:\n      return stringPatch(domNode, patch)\n    case patchTypes.VNODE:\n      return vNodePatch(domNode, patch)\n    case patchTypes.ORDER:\n      reorderChildren(domNode, patch)\n      return domNode\n    case patchTypes.PROPS:\n      applyProperties(domNode, patch, vNode.p) // 'p' === 'properties'\n      return domNode\n    case patchTypes.THUNK:\n      return replaceRoot(domNode,\n          patchRecursive(domNode, patch))\n    default:\n      return domNode\n  }\n}\n\nfunction removeNode(domNode) {\n  var parentNode = domNode.parentNode\n\n  if (parentNode) {\n    parentNode.removeChild(domNode)\n  }\n\n  return null\n}\n\nfunction insertNode(parentNode, vNode) {\n  var newNode = render(vNode)\n\n  if (parentNode) {\n    parentNode.appendChild(newNode)\n  }\n\n  return parentNode\n}\n\nfunction stringPatch(domNode, vText) {\n  var newNode\n\n  if (domNode.nodeType === 3) {\n    domNode.replaceData(0, domNode.length, vText.x) // 'x' means 'text'\n    newNode = domNode\n  } else {\n    var parentNode = domNode.parentNode\n    newNode = render(vText)\n\n    if (parentNode && newNode !== domNode) {\n      parentNode.replaceChild(newNode, domNode)\n    }\n  }\n\n  return newNode\n}\n\nfunction vNodePatch(domNode, vNode) {\n  var parentNode = domNode.parentNode\n  var newNode = render(vNode)\n\n  if (parentNode && newNode !== domNode) {\n    parentNode.replaceChild(newNode, domNode)\n  }\n\n  return newNode\n}\n\nfunction reorderChildren(domNode, moves) {\n  var childNodes = domNode.childNodes\n  var keyMap = {}\n  var node\n  var remove\n  var insert\n\n  for (var i = 0; i < moves.removes.length; i++) {\n    remove = moves.removes[i]\n    node = childNodes[remove.from]\n    if (remove.key) {\n      keyMap[remove.key] = node\n    }\n    domNode.removeChild(node)\n  }\n\n  var length = childNodes.length\n  for (var j = 0; j < moves.inserts.length; j++) {\n    insert = moves.inserts[j]\n    node = keyMap[insert.key]\n    // this is the weirdest bug i've ever seen in webkit\n    domNode.insertBefore(node, insert.to >= length++ ? null : childNodes[insert.to])\n  }\n}\n\nfunction replaceRoot(oldRoot, newRoot) {\n    if (oldRoot && newRoot && oldRoot !== newRoot && oldRoot.parentNode) {\n        oldRoot.parentNode.replaceChild(newRoot, oldRoot)\n    }\n\n    return newRoot;\n}\n","var domIndex = require(\"./domIndex\")\nvar patchOp = require(\"./patchOp\")\n\nfunction patchRecursive(rootNode, patches) {\n  var indices = patchIndices(patches)\n\n  if (indices.length === 0) {\n    return rootNode\n  }\n\n  var index = domIndex(rootNode, patches.a, indices)\n\n  for (var i = 0; i < indices.length; i++) {\n    var nodeIndex = indices[i]\n    rootNode = applyPatch(rootNode,\n      index[nodeIndex],\n      patches[nodeIndex])\n  }\n\n  return rootNode\n}\n\nfunction applyPatch(rootNode, domNode, patchList) {\n  if (!domNode) {\n    return rootNode\n  }\n\n  var newNode\n\n  for (var i = 0; i < patchList.length; i++) {\n    newNode = patchOp(patchList[i], domNode, patchRecursive)\n\n    if (domNode === rootNode) {\n      rootNode = newNode\n    }\n  }\n\n  return rootNode\n}\n\nfunction patchIndices(patches) {\n  var indices = []\n\n  for (var key in patches) {\n    if (key !== \"a\") {\n      indices.push(Number(key))\n    }\n  }\n\n  return indices\n}\n\n\nmodule.exports = patchRecursive;\n","// copied from vdom-as-json/types.js\n\nmodule.exports = {\n  VirtualTree: 1,\n  VirtualPatch: 2,\n  VirtualNode: 3,\n  SoftSetHook: 4\n};","// original this was is-vpatch.js\n\nmodule.exports = {\n  NONE: 0,\n  VTEXT: 1,\n  VNODE: 2,\n  WIDGET: 3,\n  PROPS: 4,\n  ORDER: 5,\n  INSERT: 6,\n  REMOVE: 7,\n  THUNK: 8\n};","var patchTypes = require('../patchTypes');\nvar toJson = require('vdom-as-json/toJson');\n\n// traverse the thing that the original patch structure called \"a',\n// i.e. the virtual tree representing the current node structure.\n// this thing only really needs two properties - \"children\" and \"count\",\n// so trim out everything else\nfunction serializeCurrentNode(currentNode) {\n  var children = currentNode.children;\n  if (!children) {\n    return null;\n  }\n  var len = children.length;\n  var arr = new Array(len);\n  var i = -1;\n  while (++i < len) {\n    arr[i] = serializeCurrentNode(children[i]);\n  }\n  if (currentNode.count) {\n    return [arr, currentNode.count];\n  } else {\n    return [arr];\n  }\n}\n\nfunction serializeVirtualPatchOrPatches(vPatch) {\n  if (Array.isArray(vPatch)) {\n    var len = vPatch.length;\n    var res = new Array(len);\n    var i = -1;\n    while (++i < len) {\n      res[i] = serializeVirtualPatch(vPatch[i]);\n    }\n    return res;\n  }\n  return [serializeVirtualPatch(vPatch)];\n}\n\nfunction serializeVirtualPatch(vPatch) {\n  var type = vPatch.type;\n  var res = [\n    type,\n    vPatch.patch && vPatch.patch.a ? toJson(serializeRootPatch(vPatch.patch)) : toJson(vPatch.patch)\n  ];\n\n  if (type === patchTypes.PROPS) {\n    // this is the only time the vNode is needed\n    res.push({p: vPatch.vNode.properties}); // 'p' === 'properties'\n  }\n  return res;\n}\n\nfunction serializeRootPatch(patch) {\n  var outputRootNode = serializeCurrentNode(patch.a);\n\n  var res = {\n    a: outputRootNode\n  };\n\n  for (var key in patch) {\n    if (key !== 'a') {\n      res[key] = serializeVirtualPatchOrPatches(patch[key]);\n    }\n  }\n\n  return res;\n};\nmodule.exports = serializeRootPatch;\n","'use strict';\n\nvar types = require('./types');\n\nvar SoftSetHook =\n  require('virtual-dom/virtual-hyperscript/hooks/soft-set-hook');\n\nfunction arrayToJson(arr) {\n  var len = arr.length;\n  var i = -1;\n  var res = new Array(len);\n  while (++i < len) {\n    res[i] = toJson(arr[i]);\n  }\n  return res;\n}\n\nfunction plainObjectToJson(obj) {\n  var res = {};\n  /* jshint -W089 */\n  /* this is fine; these objects are always plain */\n  for (var key in obj) {\n    var val = obj[key];\n    res[key] = typeof val !== 'undefined' ? toJson(val) : val;\n  }\n  return res;\n}\n\nfunction virtualNodeToJson(obj) {\n  var res = {\n    // type\n    t: types.VirtualNode,\n    tn: obj.tagName\n  };\n  if (Object.keys(obj.properties).length) {\n    res.p = plainObjectToJson(obj.properties);\n  }\n  if (obj.children.length) {\n    res.c = arrayToJson(obj.children);\n  }\n  if (obj.key) {\n    res.k = obj.key;\n  }\n  if (obj.namespace) {\n    res.n = obj.namespace;\n  }\n  return res;\n}\n\nfunction virtualTextToJson(obj) {\n  return {\n    // type\n    t: types.VirtualTree,\n    // text\n    x: obj.text\n  };\n}\n\nfunction virtualPatchToJson(obj) {\n  var res = {\n    // type\n    t: types.VirtualPatch,\n    // patch type\n    pt: obj.type\n  };\n\n  if (obj.vNode) {\n    res.v = toJson(obj.vNode);\n  }\n\n  if (obj.patch) {\n    res.p = toJson(obj.patch);\n  }\n\n  return res;\n}\n\nfunction softSetHookToJson(obj) {\n  return {\n    // type\n    t: types.SoftSetHook,\n    value: obj.value\n  };\n}\n\nfunction objectToJson(obj) {\n  if ('patch' in obj && typeof obj.type === 'number') {\n    return virtualPatchToJson(obj);\n  }\n  if (obj.type === 'VirtualNode') {\n    return virtualNodeToJson(obj);\n  }\n  if (obj.type === 'VirtualText') {\n    return virtualTextToJson(obj);\n  }\n  if (obj instanceof SoftSetHook) {\n    return softSetHookToJson(obj);\n  }\n\n  // plain object\n  return plainObjectToJson(obj);\n}\n\nfunction toJson(obj) {\n\n  var type = typeof obj;\n\n  switch (type) {\n    case 'string':\n    case 'boolean':\n    case 'number':\n      return obj;\n  }\n\n  // type === 'object'\n  if (Array.isArray(obj)) {\n    return arrayToJson(obj);\n  }\n\n  if (!obj) { // null\n    return null;\n  }\n\n  return objectToJson(obj);\n}\n\nmodule.exports = toJson;","module.exports = {\n  VirtualTree: 1,\n  VirtualPatch: 2,\n  VirtualNode: 3,\n  SoftSetHook: 4\n};","'use strict';\n\nmodule.exports = require('./lib/toJson');","module.exports = require('./lib/patch');\n","module.exports = require('./lib/serialize');\n","function delegator(counterpart, channels, callback, options) {\n    var connectFnName, messageHandlers;\n\n    function postMessage(namespace, message) {\n        if (typeof message.type !== 'string') {\n            return;\n        }\n\n        message.type = namespace + '::' + message.type;\n        counterpart.postMessage(message);\n    }\n\n    function connectChannel(channel) {\n        if (typeof channel.namespace === 'string' &&\n            typeof channel.handleMessage === 'function') {\n            messageHandlers[channel.namespace] = channel.handleMessage;\n        }\n\n        if (typeof channel[connectFnName] === 'function') {\n            channel[connectFnName](postMessage.bind(null, channel.namespace));\n        }\n    }\n\n    function handleMessage(type, data) {\n        var namespaced = type.split('::');\n\n        if (namespaced.length !== 2) {\n            return;\n        }\n\n        if (messageHandlers[namespaced[0]] != null) {\n            messageHandlers[namespaced[0]](namespaced[1], data);\n        }\n    }\n\n    function onmessage(event) {\n        if (typeof options.logger === 'function') {\n            options.logger(event.data.type, event.data.data);\n        }\n\n        return handleMessage(event.data.type, event.data.data);\n    }\n\n    connectFnName = (typeof callback === 'function') ? 'connectWorker' : 'connectMain';\n    messageHandlers = {};\n    channels.forEach(connectChannel);\n    counterpart.onmessage = onmessage;\n\n    if (typeof callback === 'function') {\n        callback();\n    }\n}\n\nmodule.exports = delegator;\n","(function (global){\nvar delegator = require('./delegator');\nvar shim = require('./shim');\n\nvar WORKER_ENABLED = !!(global === global.window && global.URL && global.Worker);\nvar IN_WORKER_CONTEXT = !!(global === global.self && global.location);\nvar PATHNAME = WORKER_ENABLED && (function getPathname() {\n    var scripts = global.document.getElementsByTagName('script');\n    return new global.URL(scripts[scripts.length - 1].src).pathname;\n})();\n\nfunction duet(channels, callback, options) {\n    var shimmed;\n\n    if (typeof callback !== 'function') {\n        throw new Error('duet callback is not a function');\n    }\n\n    channels = (Array.isArray(channels) && channels) || [];\n\n    options = (typeof options == 'object' && options !== null && options) || {};\n\n    if (!options.forceShim) {\n\n        if (WORKER_ENABLED) {\n            return delegator(new global.Worker(PATHNAME), channels, null, options);\n        }\n\n        if (IN_WORKER_CONTEXT) {\n            return delegator(global.self, channels, callback, options);\n        }\n\n    }\n\n    shimmed = shim();\n\n    delegator(shimmed.worker, channels, null, options);\n    delegator(shimmed.self, channels, callback, options);\n}\n\nmodule.exports = duet;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9kdWV0L2xpYi9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsidmFyIGRlbGVnYXRvciA9IHJlcXVpcmUoJy4vZGVsZWdhdG9yJyk7XG52YXIgc2hpbSA9IHJlcXVpcmUoJy4vc2hpbScpO1xuXG52YXIgV09SS0VSX0VOQUJMRUQgPSAhIShnbG9iYWwgPT09IGdsb2JhbC53aW5kb3cgJiYgZ2xvYmFsLlVSTCAmJiBnbG9iYWwuV29ya2VyKTtcbnZhciBJTl9XT1JLRVJfQ09OVEVYVCA9ICEhKGdsb2JhbCA9PT0gZ2xvYmFsLnNlbGYgJiYgZ2xvYmFsLmxvY2F0aW9uKTtcbnZhciBQQVRITkFNRSA9IFdPUktFUl9FTkFCTEVEICYmIChmdW5jdGlvbiBnZXRQYXRobmFtZSgpIHtcbiAgICB2YXIgc2NyaXB0cyA9IGdsb2JhbC5kb2N1bWVudC5nZXRFbGVtZW50c0J5VGFnTmFtZSgnc2NyaXB0Jyk7XG4gICAgcmV0dXJuIG5ldyBnbG9iYWwuVVJMKHNjcmlwdHNbc2NyaXB0cy5sZW5ndGggLSAxXS5zcmMpLnBhdGhuYW1lO1xufSkoKTtcblxuZnVuY3Rpb24gZHVldChjaGFubmVscywgY2FsbGJhY2ssIG9wdGlvbnMpIHtcbiAgICB2YXIgc2hpbW1lZDtcblxuICAgIGlmICh0eXBlb2YgY2FsbGJhY2sgIT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdkdWV0IGNhbGxiYWNrIGlzIG5vdCBhIGZ1bmN0aW9uJyk7XG4gICAgfVxuXG4gICAgY2hhbm5lbHMgPSAoQXJyYXkuaXNBcnJheShjaGFubmVscykgJiYgY2hhbm5lbHMpIHx8IFtdO1xuXG4gICAgb3B0aW9ucyA9ICh0eXBlb2Ygb3B0aW9ucyA9PSAnb2JqZWN0JyAmJiBvcHRpb25zICE9PSBudWxsICYmIG9wdGlvbnMpIHx8IHt9O1xuXG4gICAgaWYgKCFvcHRpb25zLmZvcmNlU2hpbSkge1xuXG4gICAgICAgIGlmIChXT1JLRVJfRU5BQkxFRCkge1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRvcihuZXcgZ2xvYmFsLldvcmtlcihQQVRITkFNRSksIGNoYW5uZWxzLCBudWxsLCBvcHRpb25zKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChJTl9XT1JLRVJfQ09OVEVYVCkge1xuICAgICAgICAgICAgcmV0dXJuIGRlbGVnYXRvcihnbG9iYWwuc2VsZiwgY2hhbm5lbHMsIGNhbGxiYWNrLCBvcHRpb25zKTtcbiAgICAgICAgfVxuXG4gICAgfVxuXG4gICAgc2hpbW1lZCA9IHNoaW0oKTtcblxuICAgIGRlbGVnYXRvcihzaGltbWVkLndvcmtlciwgY2hhbm5lbHMsIG51bGwsIG9wdGlvbnMpO1xuICAgIGRlbGVnYXRvcihzaGltbWVkLnNlbGYsIGNoYW5uZWxzLCBjYWxsYmFjaywgb3B0aW9ucyk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gZHVldDtcbiJdfQ==","function shim() {\n    var shimmed = { worker: {} };\n\n    shimmed.self = {postMessage: messenger(shimmed.worker)};\n    shimmed.worker.postMessage = messenger(shimmed.self);\n\n    return shimmed;\n}\n\nfunction messenger(destination) {\n    return function postMessage(data) {\n        setTimeout(function onTick() {\n            if (typeof destination.onmessage === 'function') {\n                destination.onmessage({data: data});\n            }\n        }, 0);\n    }\n}\n\nmodule.exports = shim;\n","const pathname = require('pathname-match')\nconst wayfarer = require('wayfarer')\nconst assert = require('assert')\n\nmodule.exports = sheetRouter\n\n// Fast, modular client router\n// fn(str, any[..], fn?) -> fn(str, any[..])\nfunction sheetRouter (dft, createTree, createRoute) {\n  createRoute = (createRoute ? createRoute(_createRoute) : _createRoute)\n\n  if (!createTree) {\n    createTree = dft\n    dft = ''\n  }\n\n  assert.equal(typeof dft, 'string', 'sheet-router: dft must be a string')\n  assert.equal(typeof createTree, 'function', 'sheet-router: createTree must be a function')\n  assert.equal(typeof createRoute, 'function', 'sheet-router: createRoute must be a function')\n\n  const router = wayfarer(dft)\n  const tree = createTree(createRoute)\n\n  // register tree in router\n  ;(function walk (tree, route) {\n    if (Array.isArray(tree[0])) {\n      // walk over all routes at the root of the tree\n      tree.forEach(function (node) {\n        walk(node, route)\n      })\n    } else if (tree[1]) {\n      // handle inline functions as args\n      const innerRoute = tree[0]\n        ? route.concat(tree[0]).join('/')\n        : route.length ? route.join('/') : tree[0]\n      router.on(innerRoute, tree[1])\n      walk(tree[2], route.concat(tree[0]))\n    } else if (Array.isArray(tree[2])) {\n      // traverse and append route\n      walk(tree[2], route.concat(tree[0]))\n    } else {\n      // register path in router\n      const nwRoute = tree[0]\n        ? route.concat(tree[0]).join('/')\n        : route.length ? route.join('/') : tree[0]\n      router.on(nwRoute, tree[2])\n    }\n  })(tree, [])\n\n  // match a route on the router\n  return function match (route) {\n    assert.equal(typeof route, 'string', 'route must be a string')\n    const args = [].slice.call(arguments)\n    args[0] = pathname(args[0])\n    return router.apply(null, args)\n  }\n}\n\n// register regular route\nfunction _createRoute (route, inline, child) {\n  if (!child) {\n    child = inline\n    inline = null\n  }\n  assert.equal(typeof route, 'string', 'route must be a string')\n  assert.ok(child, 'child exists')\n  route = route.replace(/^\\//, '')\n  return [ route, inline, child ]\n}\n","const assert = require('assert')\nconst trie = require('./trie')\n\nmodule.exports = Wayfarer\n\n// create a router\n// str -> obj\nfunction Wayfarer (dft) {\n  if (!(this instanceof Wayfarer)) return new Wayfarer(dft)\n\n  const _default = (dft || '').replace(/^\\//, '')\n  const _trie = trie()\n\n  emit._trie = _trie\n  emit.emit = emit\n  emit.on = on\n  emit._wayfarer = true\n\n  return emit\n\n  // define a route\n  // (str, fn) -> obj\n  function on (route, cb) {\n    assert.equal(typeof route, 'string')\n    assert.equal(typeof cb, 'function')\n\n    route = route || '/'\n\n    if (cb && cb._wayfarer && cb._trie) {\n      _trie.mount(route, cb._trie.trie)\n    } else {\n      const node = _trie.create(route)\n      node.cb = cb\n    }\n\n    return emit\n  }\n\n  // match and call a route\n  // (str, obj?) -> null\n  function emit (route) {\n    assert.notEqual(route, undefined, \"'route' must be defined\")\n    const args = new Array(arguments.length)\n    for (var i = 1; i < args.length; i++) {\n      args[i] = arguments[i]\n    }\n\n    const node = _trie.match(route)\n    if (node && node.cb) {\n      args[0] = node.params\n      return node.cb.apply(null, args)\n    }\n\n    const dft = _trie.match(_default)\n    if (dft && dft.cb) {\n      args[0] = dft.params\n      return dft.cb.apply(null, args)\n    }\n\n    throw new Error(\"route '\" + route + \"' did not match\")\n  }\n}\n","const mutate = require('xtend/mutable')\nconst assert = require('assert')\nconst xtend = require('xtend')\n\nmodule.exports = Trie\n\n// create a new trie\n// null -> obj\nfunction Trie () {\n  if (!(this instanceof Trie)) return new Trie()\n  this.trie = { nodes: {} }\n}\n\n// create a node on the trie at route\n// and return a node\n// str -> null\nTrie.prototype.create = function (route) {\n  assert.equal(typeof route, 'string', 'route should be a string')\n  // strip leading '/' and split routes\n  const routes = route.replace(/^\\//, '').split('/')\n  return (function createNode (index, trie, routes) {\n    const route = routes[index]\n\n    if (route === undefined) return trie\n\n    var node = null\n    if (/^:/.test(route)) {\n      // if node is a name match, set name and append to ':' node\n      if (!trie.nodes['$$']) {\n        node = { nodes: {} }\n        trie.nodes['$$'] = node\n      } else {\n        node = trie.nodes['$$']\n      }\n      trie.name = route.replace(/^:/, '')\n    } else if (!trie.nodes[route]) {\n      node = { nodes: {} }\n      trie.nodes[route] = node\n    } else {\n      node = trie.nodes[route]\n    }\n\n    // we must recurse deeper\n    return createNode(index + 1, node, routes)\n  })(0, this.trie, routes)\n}\n\n// match a route on the trie\n// and return the node\n// str -> obj\nTrie.prototype.match = function (route) {\n  assert.equal(typeof route, 'string', 'route should be a string')\n\n  const routes = route.replace(/^\\//, '').split('/')\n  const params = {}\n\n  var node = (function search (index, trie) {\n    // either there's no match, or we're done searching\n    if (trie === undefined) return undefined\n    const route = routes[index]\n    if (route === undefined) return trie\n\n    if (trie.nodes[route]) {\n      // match regular routes first\n      return search(index + 1, trie.nodes[route])\n    } else if (trie.name) {\n      // match named routes\n      params[trie.name] = route\n      return search(index + 1, trie.nodes['$$'])\n    } else {\n      // no matches found\n      return search(index + 1)\n    }\n  })(0, this.trie)\n\n  if (!node) return undefined\n  node = xtend(node)\n  node.params = params\n  return node\n}\n\n// mount a trie onto a node at route\n// (str, obj) -> null\nTrie.prototype.mount = function (route, trie) {\n  assert.equal(typeof route, 'string', 'route should be a string')\n  assert.equal(typeof trie, 'object', 'trie should be a object')\n\n  const split = route.replace(/^\\//, '').split('/')\n  var node = null\n  var key = null\n\n  if (split.length === 1) {\n    key = split[0]\n    node = this.create(key)\n  } else {\n    const headArr = split.splice(0, split.length - 1)\n    const head = headArr.join('/')\n    key = split[0]\n    node = this.create(head)\n  }\n\n  mutate(node.nodes, trie.nodes)\n  if (trie.name) node.name = trie.name\n\n  // delegate properties from '/' to the new node\n  // '/' cannot be reached once mounted\n  if (node.nodes['']) {\n    Object.keys(node.nodes['']).forEach(function (key) {\n      if (key === 'nodes') return\n      node[key] = node.nodes[''][key]\n    })\n    mutate(node.nodes, node.nodes[''].nodes)\n    delete node.nodes[''].nodes\n  }\n}\n","var diff = require(\"./vtree/diff.js\")\n\nmodule.exports = diff\n","\"use strict\";\n\nmodule.exports = function isObject(x) {\n\treturn typeof x === \"object\" && x !== null;\n};\n","var nativeIsArray = Array.isArray\nvar toString = Object.prototype.toString\n\nmodule.exports = nativeIsArray || isArray\n\nfunction isArray(obj) {\n    return toString.call(obj) === \"[object Array]\"\n}\n","'use strict';\n\nmodule.exports = SoftSetHook;\n\nfunction SoftSetHook(value) {\n    if (!(this instanceof SoftSetHook)) {\n        return new SoftSetHook(value);\n    }\n\n    this.value = value;\n}\n\nSoftSetHook.prototype.hook = function (node, propertyName) {\n    if (node[propertyName] !== this.value) {\n        node[propertyName] = this.value;\n    }\n};\n","var isVNode = require(\"./is-vnode\")\nvar isVText = require(\"./is-vtext\")\nvar isWidget = require(\"./is-widget\")\nvar isThunk = require(\"./is-thunk\")\n\nmodule.exports = handleThunk\n\nfunction handleThunk(a, b) {\n    var renderedA = a\n    var renderedB = b\n\n    if (isThunk(b)) {\n        renderedB = renderThunk(b, a)\n    }\n\n    if (isThunk(a)) {\n        renderedA = renderThunk(a, null)\n    }\n\n    return {\n        a: renderedA,\n        b: renderedB\n    }\n}\n\nfunction renderThunk(thunk, previous) {\n    var renderedThunk = thunk.vnode\n\n    if (!renderedThunk) {\n        renderedThunk = thunk.vnode = thunk.render(previous)\n    }\n\n    if (!(isVNode(renderedThunk) ||\n            isVText(renderedThunk) ||\n            isWidget(renderedThunk))) {\n        throw new Error(\"thunk did not return a valid node\");\n    }\n\n    return renderedThunk\n}\n","module.exports = isThunk\r\n\r\nfunction isThunk(t) {\r\n    return t && t.type === \"Thunk\"\r\n}\r\n","module.exports = isHook\n\nfunction isHook(hook) {\n    return hook &&\n      (typeof hook.hook === \"function\" && !hook.hasOwnProperty(\"hook\") ||\n       typeof hook.unhook === \"function\" && !hook.hasOwnProperty(\"unhook\"))\n}\n","var version = require(\"./version\")\n\nmodule.exports = isVirtualNode\n\nfunction isVirtualNode(x) {\n    return x && x.type === \"VirtualNode\" && x.version === version\n}\n","var version = require(\"./version\")\n\nmodule.exports = isVirtualText\n\nfunction isVirtualText(x) {\n    return x && x.type === \"VirtualText\" && x.version === version\n}\n","module.exports = isWidget\n\nfunction isWidget(w) {\n    return w && w.type === \"Widget\"\n}\n","module.exports = \"2\"\n","var version = require(\"./version\")\nvar isVNode = require(\"./is-vnode\")\nvar isWidget = require(\"./is-widget\")\nvar isThunk = require(\"./is-thunk\")\nvar isVHook = require(\"./is-vhook\")\n\nmodule.exports = VirtualNode\n\nvar noProperties = {}\nvar noChildren = []\n\nfunction VirtualNode(tagName, properties, children, key, namespace) {\n    this.tagName = tagName\n    this.properties = properties || noProperties\n    this.children = children || noChildren\n    this.key = key != null ? String(key) : undefined\n    this.namespace = (typeof namespace === \"string\") ? namespace : null\n\n    var count = (children && children.length) || 0\n    var descendants = 0\n    var hasWidgets = false\n    var hasThunks = false\n    var descendantHooks = false\n    var hooks\n\n    for (var propName in properties) {\n        if (properties.hasOwnProperty(propName)) {\n            var property = properties[propName]\n            if (isVHook(property) && property.unhook) {\n                if (!hooks) {\n                    hooks = {}\n                }\n\n                hooks[propName] = property\n            }\n        }\n    }\n\n    for (var i = 0; i < count; i++) {\n        var child = children[i]\n        if (isVNode(child)) {\n            descendants += child.count || 0\n\n            if (!hasWidgets && child.hasWidgets) {\n                hasWidgets = true\n            }\n\n            if (!hasThunks && child.hasThunks) {\n                hasThunks = true\n            }\n\n            if (!descendantHooks && (child.hooks || child.descendantHooks)) {\n                descendantHooks = true\n            }\n        } else if (!hasWidgets && isWidget(child)) {\n            if (typeof child.destroy === \"function\") {\n                hasWidgets = true\n            }\n        } else if (!hasThunks && isThunk(child)) {\n            hasThunks = true;\n        }\n    }\n\n    this.count = count + descendants\n    this.hasWidgets = hasWidgets\n    this.hasThunks = hasThunks\n    this.hooks = hooks\n    this.descendantHooks = descendantHooks\n}\n\nVirtualNode.prototype.version = version\nVirtualNode.prototype.type = \"VirtualNode\"\n","var version = require(\"./version\")\n\nVirtualPatch.NONE = 0\nVirtualPatch.VTEXT = 1\nVirtualPatch.VNODE = 2\nVirtualPatch.WIDGET = 3\nVirtualPatch.PROPS = 4\nVirtualPatch.ORDER = 5\nVirtualPatch.INSERT = 6\nVirtualPatch.REMOVE = 7\nVirtualPatch.THUNK = 8\n\nmodule.exports = VirtualPatch\n\nfunction VirtualPatch(type, vNode, patch) {\n    this.type = Number(type)\n    this.vNode = vNode\n    this.patch = patch\n}\n\nVirtualPatch.prototype.version = version\nVirtualPatch.prototype.type = \"VirtualPatch\"\n","var isObject = require(\"is-object\")\nvar isHook = require(\"../vnode/is-vhook\")\n\nmodule.exports = diffProps\n\nfunction diffProps(a, b) {\n    var diff\n\n    for (var aKey in a) {\n        if (!(aKey in b)) {\n            diff = diff || {}\n            diff[aKey] = undefined\n        }\n\n        var aValue = a[aKey]\n        var bValue = b[aKey]\n\n        if (aValue === bValue) {\n            continue\n        } else if (isObject(aValue) && isObject(bValue)) {\n            if (getPrototype(bValue) !== getPrototype(aValue)) {\n                diff = diff || {}\n                diff[aKey] = bValue\n            } else if (isHook(bValue)) {\n                 diff = diff || {}\n                 diff[aKey] = bValue\n            } else {\n                var objectDiff = diffProps(aValue, bValue)\n                if (objectDiff) {\n                    diff = diff || {}\n                    diff[aKey] = objectDiff\n                }\n            }\n        } else {\n            diff = diff || {}\n            diff[aKey] = bValue\n        }\n    }\n\n    for (var bKey in b) {\n        if (!(bKey in a)) {\n            diff = diff || {}\n            diff[bKey] = b[bKey]\n        }\n    }\n\n    return diff\n}\n\nfunction getPrototype(value) {\n  if (Object.getPrototypeOf) {\n    return Object.getPrototypeOf(value)\n  } else if (value.__proto__) {\n    return value.__proto__\n  } else if (value.constructor) {\n    return value.constructor.prototype\n  }\n}\n","var isArray = require(\"x-is-array\")\n\nvar VPatch = require(\"../vnode/vpatch\")\nvar isVNode = require(\"../vnode/is-vnode\")\nvar isVText = require(\"../vnode/is-vtext\")\nvar isWidget = require(\"../vnode/is-widget\")\nvar isThunk = require(\"../vnode/is-thunk\")\nvar handleThunk = require(\"../vnode/handle-thunk\")\n\nvar diffProps = require(\"./diff-props\")\n\nmodule.exports = diff\n\nfunction diff(a, b) {\n    var patch = { a: a }\n    walk(a, b, patch, 0)\n    return patch\n}\n\nfunction walk(a, b, patch, index) {\n    if (a === b) {\n        return\n    }\n\n    var apply = patch[index]\n    var applyClear = false\n\n    if (isThunk(a) || isThunk(b)) {\n        thunks(a, b, patch, index)\n    } else if (b == null) {\n\n        // If a is a widget we will add a remove patch for it\n        // Otherwise any child widgets/hooks must be destroyed.\n        // This prevents adding two remove patches for a widget.\n        if (!isWidget(a)) {\n            clearState(a, patch, index)\n            apply = patch[index]\n        }\n\n        apply = appendPatch(apply, new VPatch(VPatch.REMOVE, a, b))\n    } else if (isVNode(b)) {\n        if (isVNode(a)) {\n            if (a.tagName === b.tagName &&\n                a.namespace === b.namespace &&\n                a.key === b.key) {\n                var propsPatch = diffProps(a.properties, b.properties)\n                if (propsPatch) {\n                    apply = appendPatch(apply,\n                        new VPatch(VPatch.PROPS, a, propsPatch))\n                }\n                apply = diffChildren(a, b, patch, apply, index)\n            } else {\n                apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b))\n                applyClear = true\n            }\n        } else {\n            apply = appendPatch(apply, new VPatch(VPatch.VNODE, a, b))\n            applyClear = true\n        }\n    } else if (isVText(b)) {\n        if (!isVText(a)) {\n            apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b))\n            applyClear = true\n        } else if (a.text !== b.text) {\n            apply = appendPatch(apply, new VPatch(VPatch.VTEXT, a, b))\n        }\n    } else if (isWidget(b)) {\n        if (!isWidget(a)) {\n            applyClear = true\n        }\n\n        apply = appendPatch(apply, new VPatch(VPatch.WIDGET, a, b))\n    }\n\n    if (apply) {\n        patch[index] = apply\n    }\n\n    if (applyClear) {\n        clearState(a, patch, index)\n    }\n}\n\nfunction diffChildren(a, b, patch, apply, index) {\n    var aChildren = a.children\n    var orderedSet = reorder(aChildren, b.children)\n    var bChildren = orderedSet.children\n\n    var aLen = aChildren.length\n    var bLen = bChildren.length\n    var len = aLen > bLen ? aLen : bLen\n\n    for (var i = 0; i < len; i++) {\n        var leftNode = aChildren[i]\n        var rightNode = bChildren[i]\n        index += 1\n\n        if (!leftNode) {\n            if (rightNode) {\n                // Excess nodes in b need to be added\n                apply = appendPatch(apply,\n                    new VPatch(VPatch.INSERT, null, rightNode))\n            }\n        } else {\n            walk(leftNode, rightNode, patch, index)\n        }\n\n        if (isVNode(leftNode) && leftNode.count) {\n            index += leftNode.count\n        }\n    }\n\n    if (orderedSet.moves) {\n        // Reorder nodes last\n        apply = appendPatch(apply, new VPatch(\n            VPatch.ORDER,\n            a,\n            orderedSet.moves\n        ))\n    }\n\n    return apply\n}\n\nfunction clearState(vNode, patch, index) {\n    // TODO: Make this a single walk, not two\n    unhook(vNode, patch, index)\n    destroyWidgets(vNode, patch, index)\n}\n\n// Patch records for all destroyed widgets must be added because we need\n// a DOM node reference for the destroy function\nfunction destroyWidgets(vNode, patch, index) {\n    if (isWidget(vNode)) {\n        if (typeof vNode.destroy === \"function\") {\n            patch[index] = appendPatch(\n                patch[index],\n                new VPatch(VPatch.REMOVE, vNode, null)\n            )\n        }\n    } else if (isVNode(vNode) && (vNode.hasWidgets || vNode.hasThunks)) {\n        var children = vNode.children\n        var len = children.length\n        for (var i = 0; i < len; i++) {\n            var child = children[i]\n            index += 1\n\n            destroyWidgets(child, patch, index)\n\n            if (isVNode(child) && child.count) {\n                index += child.count\n            }\n        }\n    } else if (isThunk(vNode)) {\n        thunks(vNode, null, patch, index)\n    }\n}\n\n// Create a sub-patch for thunks\nfunction thunks(a, b, patch, index) {\n    var nodes = handleThunk(a, b)\n    var thunkPatch = diff(nodes.a, nodes.b)\n    if (hasPatches(thunkPatch)) {\n        patch[index] = new VPatch(VPatch.THUNK, null, thunkPatch)\n    }\n}\n\nfunction hasPatches(patch) {\n    for (var index in patch) {\n        if (index !== \"a\") {\n            return true\n        }\n    }\n\n    return false\n}\n\n// Execute hooks when two nodes are identical\nfunction unhook(vNode, patch, index) {\n    if (isVNode(vNode)) {\n        if (vNode.hooks) {\n            patch[index] = appendPatch(\n                patch[index],\n                new VPatch(\n                    VPatch.PROPS,\n                    vNode,\n                    undefinedKeys(vNode.hooks)\n                )\n            )\n        }\n\n        if (vNode.descendantHooks || vNode.hasThunks) {\n            var children = vNode.children\n            var len = children.length\n            for (var i = 0; i < len; i++) {\n                var child = children[i]\n                index += 1\n\n                unhook(child, patch, index)\n\n                if (isVNode(child) && child.count) {\n                    index += child.count\n                }\n            }\n        }\n    } else if (isThunk(vNode)) {\n        thunks(vNode, null, patch, index)\n    }\n}\n\nfunction undefinedKeys(obj) {\n    var result = {}\n\n    for (var key in obj) {\n        result[key] = undefined\n    }\n\n    return result\n}\n\n// List diff, naive left to right reordering\nfunction reorder(aChildren, bChildren) {\n    // O(M) time, O(M) memory\n    var bChildIndex = keyIndex(bChildren)\n    var bKeys = bChildIndex.keys\n    var bFree = bChildIndex.free\n\n    if (bFree.length === bChildren.length) {\n        return {\n            children: bChildren,\n            moves: null\n        }\n    }\n\n    // O(N) time, O(N) memory\n    var aChildIndex = keyIndex(aChildren)\n    var aKeys = aChildIndex.keys\n    var aFree = aChildIndex.free\n\n    if (aFree.length === aChildren.length) {\n        return {\n            children: bChildren,\n            moves: null\n        }\n    }\n\n    // O(MAX(N, M)) memory\n    var newChildren = []\n\n    var freeIndex = 0\n    var freeCount = bFree.length\n    var deletedItems = 0\n\n    // Iterate through a and match a node in b\n    // O(N) time,\n    for (var i = 0 ; i < aChildren.length; i++) {\n        var aItem = aChildren[i]\n        var itemIndex\n\n        if (aItem.key) {\n            if (bKeys.hasOwnProperty(aItem.key)) {\n                // Match up the old keys\n                itemIndex = bKeys[aItem.key]\n                newChildren.push(bChildren[itemIndex])\n\n            } else {\n                // Remove old keyed items\n                itemIndex = i - deletedItems++\n                newChildren.push(null)\n            }\n        } else {\n            // Match the item in a with the next free item in b\n            if (freeIndex < freeCount) {\n                itemIndex = bFree[freeIndex++]\n                newChildren.push(bChildren[itemIndex])\n            } else {\n                // There are no free items in b to match with\n                // the free items in a, so the extra free nodes\n                // are deleted.\n                itemIndex = i - deletedItems++\n                newChildren.push(null)\n            }\n        }\n    }\n\n    var lastFreeIndex = freeIndex >= bFree.length ?\n        bChildren.length :\n        bFree[freeIndex]\n\n    // Iterate through b and append any new keys\n    // O(M) time\n    for (var j = 0; j < bChildren.length; j++) {\n        var newItem = bChildren[j]\n\n        if (newItem.key) {\n            if (!aKeys.hasOwnProperty(newItem.key)) {\n                // Add any new keyed items\n                // We are adding new items to the end and then sorting them\n                // in place. In future we should insert new items in place.\n                newChildren.push(newItem)\n            }\n        } else if (j >= lastFreeIndex) {\n            // Add any leftover non-keyed items\n            newChildren.push(newItem)\n        }\n    }\n\n    var simulate = newChildren.slice()\n    var simulateIndex = 0\n    var removes = []\n    var inserts = []\n    var simulateItem\n\n    for (var k = 0; k < bChildren.length;) {\n        var wantedItem = bChildren[k]\n        simulateItem = simulate[simulateIndex]\n\n        // remove items\n        while (simulateItem === null && simulate.length) {\n            removes.push(remove(simulate, simulateIndex, null))\n            simulateItem = simulate[simulateIndex]\n        }\n\n        if (!simulateItem || simulateItem.key !== wantedItem.key) {\n            // if we need a key in this position...\n            if (wantedItem.key) {\n                if (simulateItem && simulateItem.key) {\n                    // if an insert doesn't put this key in place, it needs to move\n                    if (bKeys[simulateItem.key] !== k + 1) {\n                        removes.push(remove(simulate, simulateIndex, simulateItem.key))\n                        simulateItem = simulate[simulateIndex]\n                        // if the remove didn't put the wanted item in place, we need to insert it\n                        if (!simulateItem || simulateItem.key !== wantedItem.key) {\n                            inserts.push({key: wantedItem.key, to: k})\n                        }\n                        // items are matching, so skip ahead\n                        else {\n                            simulateIndex++\n                        }\n                    }\n                    else {\n                        inserts.push({key: wantedItem.key, to: k})\n                    }\n                }\n                else {\n                    inserts.push({key: wantedItem.key, to: k})\n                }\n                k++\n            }\n            // a key in simulate has no matching wanted key, remove it\n            else if (simulateItem && simulateItem.key) {\n                removes.push(remove(simulate, simulateIndex, simulateItem.key))\n            }\n        }\n        else {\n            simulateIndex++\n            k++\n        }\n    }\n\n    // remove all the remaining nodes from simulate\n    while(simulateIndex < simulate.length) {\n        simulateItem = simulate[simulateIndex]\n        removes.push(remove(simulate, simulateIndex, simulateItem && simulateItem.key))\n    }\n\n    // If the only moves we have are deletes then we can just\n    // let the delete patch remove these items.\n    if (removes.length === deletedItems && !inserts.length) {\n        return {\n            children: newChildren,\n            moves: null\n        }\n    }\n\n    return {\n        children: newChildren,\n        moves: {\n            removes: removes,\n            inserts: inserts\n        }\n    }\n}\n\nfunction remove(arr, index, key) {\n    arr.splice(index, 1)\n\n    return {\n        from: index,\n        key: key\n    }\n}\n\nfunction keyIndex(children) {\n    var keys = {}\n    var free = []\n    var length = children.length\n\n    for (var i = 0; i < length; i++) {\n        var child = children[i]\n\n        if (child.key) {\n            keys[child.key] = i\n        } else {\n            free.push(i)\n        }\n    }\n\n    return {\n        keys: keys,     // A hash of key name to index\n        free: free      // An array of unkeyed item indices\n    }\n}\n\nfunction appendPatch(apply, patch) {\n    if (apply) {\n        if (isArray(apply)) {\n            apply.push(patch)\n        } else {\n            apply = [apply, patch]\n        }\n\n        return apply\n    } else {\n        return patch\n    }\n}\n","const choo = require('./choo');\nconst duet = require('duet');\nconst duetLocationChannel = require('duet-location/channel');\nconst duetVirtualDOMChannel = require('duet-virtual-dom/channel');\n\nmodule.exports = chooet;\n\nfunction chooet (cb, opts) {\n  opts = typeof opts === 'object' ? opts : {};\n  opts.channels = Array.isArray(opts.channels) ? opts.channels : [];\n  const channels = opts.channels.concat(duetLocationChannel, duetVirtualDOMChannel);\n  delete opts.channels;\n  duet(channels, cb.bind(null, choo), opts);\n}\n"]} | |
require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ | |
var attrToProp = require('hyperscript-attribute-to-property') | |
var VAR = 0, TEXT = 1, OPEN = 2, CLOSE = 3, ATTR = 4 | |
var ATTR_KEY = 5, ATTR_KEY_W = 6 | |
var ATTR_VALUE_W = 7, ATTR_VALUE = 8 | |
var ATTR_VALUE_SQ = 9, ATTR_VALUE_DQ = 10 | |
var ATTR_EQ = 11, ATTR_BREAK = 12 | |
module.exports = function (h, opts) { | |
h = attrToProp(h) | |
if (!opts) opts = {} | |
var concat = opts.concat || function (a, b) { | |
return String(a) + String(b) | |
} | |
return function (strings) { | |
var state = TEXT, reg = '' | |
var arglen = arguments.length | |
var parts = [] | |
for (var i = 0; i < strings.length; i++) { | |
if (i < arglen - 1) { | |
var arg = arguments[i+1] | |
var p = parse(strings[i]) | |
var xstate = state | |
if (xstate === ATTR_VALUE_DQ) xstate = ATTR_VALUE | |
if (xstate === ATTR_VALUE_SQ) xstate = ATTR_VALUE | |
if (xstate === ATTR_VALUE_W) xstate = ATTR_VALUE | |
if (xstate === ATTR) xstate = ATTR_KEY | |
p.push([ VAR, xstate, arg ]) | |
parts.push.apply(parts, p) | |
} else parts.push.apply(parts, parse(strings[i])) | |
} | |
var tree = [null,{},[]] | |
var stack = [[tree,-1]] | |
for (var i = 0; i < parts.length; i++) { | |
var cur = stack[stack.length-1][0] | |
var p = parts[i], s = p[0] | |
if (s === OPEN && /^\//.test(p[1])) { | |
var ix = stack[stack.length-1][1] | |
if (stack.length > 1) { | |
stack.pop() | |
stack[stack.length-1][0][2][ix] = h( | |
cur[0], cur[1], cur[2].length ? cur[2] : undefined | |
) | |
} | |
} else if (s === OPEN) { | |
var c = [p[1],{},[]] | |
cur[2].push(c) | |
stack.push([c,cur[2].length-1]) | |
} else if (s === ATTR_KEY || (s === VAR && p[1] === ATTR_KEY)) { | |
var key = '' | |
var copyKey | |
for (; i < parts.length; i++) { | |
if (parts[i][0] === ATTR_KEY) { | |
key = concat(key, parts[i][1]) | |
} else if (parts[i][0] === VAR && parts[i][1] === ATTR_KEY) { | |
if (typeof parts[i][2] === 'object' && !key) { | |
for (copyKey in parts[i][2]) { | |
if (parts[i][2].hasOwnProperty(copyKey) && !cur[1][copyKey]) { | |
cur[1][copyKey] = parts[i][2][copyKey] | |
} | |
} | |
} else { | |
key = concat(key, parts[i][2]) | |
} | |
} else break | |
} | |
if (parts[i][0] === ATTR_EQ) i++ | |
var j = i | |
for (; i < parts.length; i++) { | |
if (parts[i][0] === ATTR_VALUE || parts[i][0] === ATTR_KEY) { | |
if (!cur[1][key]) cur[1][key] = strfn(parts[i][1]) | |
else cur[1][key] = concat(cur[1][key], parts[i][1]) | |
} else if (parts[i][0] === VAR | |
&& (parts[i][1] === ATTR_VALUE || parts[i][1] === ATTR_KEY)) { | |
if (!cur[1][key]) cur[1][key] = strfn(parts[i][2]) | |
else cur[1][key] = concat(cur[1][key], parts[i][2]) | |
} else { | |
if (key.length && !cur[1][key] && i === j | |
&& (parts[i][0] === CLOSE || parts[i][0] === ATTR_BREAK)) { | |
// https://html.spec.whatwg.org/multipage/infrastructure.html#boolean-attributes | |
// empty string is falsy, not well behaved value in browser | |
cur[1][key] = key.toLowerCase() | |
} | |
break | |
} | |
} | |
} else if (s === ATTR_KEY) { | |
cur[1][p[1]] = true | |
} else if (s === VAR && p[1] === ATTR_KEY) { | |
cur[1][p[2]] = true | |
} else if (s === CLOSE) { | |
if (selfClosing(cur[0]) && stack.length) { | |
var ix = stack[stack.length-1][1] | |
stack.pop() | |
stack[stack.length-1][0][2][ix] = h( | |
cur[0], cur[1], cur[2].length ? cur[2] : undefined | |
) | |
} | |
} else if (s === VAR && p[1] === TEXT) { | |
if (p[2] === undefined || p[2] === null) p[2] = '' | |
else if (!p[2]) p[2] = concat('', p[2]) | |
if (Array.isArray(p[2][0])) { | |
cur[2].push.apply(cur[2], p[2]) | |
} else { | |
cur[2].push(p[2]) | |
} | |
} else if (s === TEXT) { | |
cur[2].push(p[1]) | |
} else if (s === ATTR_EQ || s === ATTR_BREAK) { | |
// no-op | |
} else { | |
throw new Error('unhandled: ' + s) | |
} | |
} | |
if (tree[2].length > 1 && /^\s*$/.test(tree[2][0])) { | |
tree[2].shift() | |
} | |
if (tree[2].length > 2 | |
|| (tree[2].length === 2 && /\S/.test(tree[2][1]))) { | |
throw new Error( | |
'multiple root elements must be wrapped in an enclosing tag' | |
) | |
} | |
if (Array.isArray(tree[2][0]) && typeof tree[2][0][0] === 'string' | |
&& Array.isArray(tree[2][0][2])) { | |
tree[2][0] = h(tree[2][0][0], tree[2][0][1], tree[2][0][2]) | |
} | |
return tree[2][0] | |
function parse (str) { | |
var res = [] | |
if (state === ATTR_VALUE_W) state = ATTR | |
for (var i = 0; i < str.length; i++) { | |
var c = str.charAt(i) | |
if (state === TEXT && c === '<') { | |
if (reg.length) res.push([TEXT, reg]) | |
reg = '' | |
state = OPEN | |
} else if (c === '>' && !quot(state)) { | |
if (state === OPEN) { | |
res.push([OPEN,reg]) | |
} else if (state === ATTR_KEY) { | |
res.push([ATTR_KEY,reg]) | |
} else if (state === ATTR_VALUE && reg.length) { | |
res.push([ATTR_VALUE,reg]) | |
} | |
res.push([CLOSE]) | |
reg = '' | |
state = TEXT | |
} else if (state === TEXT) { | |
reg += c | |
} else if (state === OPEN && /\s/.test(c)) { | |
res.push([OPEN, reg]) | |
reg = '' | |
state = ATTR | |
} else if (state === OPEN) { | |
reg += c | |
} else if (state === ATTR && /[\w-]/.test(c)) { | |
state = ATTR_KEY | |
reg = c | |
} else if (state === ATTR && /\s/.test(c)) { | |
if (reg.length) res.push([ATTR_KEY,reg]) | |
res.push([ATTR_BREAK]) | |
} else if (state === ATTR_KEY && /\s/.test(c)) { | |
res.push([ATTR_KEY,reg]) | |
reg = '' | |
state = ATTR_KEY_W | |
} else if (state === ATTR_KEY && c === '=') { | |
res.push([ATTR_KEY,reg],[ATTR_EQ]) | |
reg = '' | |
state = ATTR_VALUE_W | |
} else if (state === ATTR_KEY) { | |
reg += c | |
} else if ((state === ATTR_KEY_W || state === ATTR) && c === '=') { | |
res.push([ATTR_EQ]) | |
state = ATTR_VALUE_W | |
} else if ((state === ATTR_KEY_W || state === ATTR) && !/\s/.test(c)) { | |
res.push([ATTR_BREAK]) | |
if (/[\w-]/.test(c)) { | |
reg += c | |
state = ATTR_KEY | |
} else state = ATTR | |
} else if (state === ATTR_VALUE_W && c === '"') { | |
state = ATTR_VALUE_DQ | |
} else if (state === ATTR_VALUE_W && c === "'") { | |
state = ATTR_VALUE_SQ | |
} else if (state === ATTR_VALUE_DQ && c === '"') { | |
res.push([ATTR_VALUE,reg],[ATTR_BREAK]) | |
reg = '' | |
state = ATTR | |
} else if (state === ATTR_VALUE_SQ && c === "'") { | |
res.push([ATTR_VALUE,reg],[ATTR_BREAK]) | |
reg = '' | |
state = ATTR | |
} else if (state === ATTR_VALUE_W && !/\s/.test(c)) { | |
state = ATTR_VALUE | |
i-- | |
} else if (state === ATTR_VALUE && /\s/.test(c)) { | |
res.push([ATTR_VALUE,reg],[ATTR_BREAK]) | |
reg = '' | |
state = ATTR | |
} else if (state === ATTR_VALUE || state === ATTR_VALUE_SQ | |
|| state === ATTR_VALUE_DQ) { | |
reg += c | |
} | |
} | |
if (state === TEXT && reg.length) { | |
res.push([TEXT,reg]) | |
reg = '' | |
} else if (state === ATTR_VALUE && reg.length) { | |
res.push([ATTR_VALUE,reg]) | |
reg = '' | |
} else if (state === ATTR_VALUE_DQ && reg.length) { | |
res.push([ATTR_VALUE,reg]) | |
reg = '' | |
} else if (state === ATTR_VALUE_SQ && reg.length) { | |
res.push([ATTR_VALUE,reg]) | |
reg = '' | |
} else if (state === ATTR_KEY) { | |
res.push([ATTR_KEY,reg]) | |
reg = '' | |
} | |
return res | |
} | |
} | |
function strfn (x) { | |
if (typeof x === 'function') return x | |
else if (typeof x === 'string') return x | |
else if (x && typeof x === 'object') return x | |
else return concat('', x) | |
} | |
} | |
function quot (state) { | |
return state === ATTR_VALUE_SQ || state === ATTR_VALUE_DQ | |
} | |
var hasOwn = Object.prototype.hasOwnProperty | |
function has (obj, key) { return hasOwn.call(obj, key) } | |
var closeRE = RegExp('^(' + [ | |
'area', 'base', 'basefont', 'bgsound', 'br', 'col', 'command', 'embed', | |
'frame', 'hr', 'img', 'input', 'isindex', 'keygen', 'link', 'meta', 'param', | |
'source', 'track', 'wbr', | |
// SVG TAGS | |
'animate', 'animateTransform', 'circle', 'cursor', 'desc', 'ellipse', | |
'feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite', | |
'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap', | |
'feDistantLight', 'feFlood', 'feFuncA', 'feFuncB', 'feFuncG', 'feFuncR', | |
'feGaussianBlur', 'feImage', 'feMergeNode', 'feMorphology', | |
'feOffset', 'fePointLight', 'feSpecularLighting', 'feSpotLight', 'feTile', | |
'feTurbulence', 'font-face-format', 'font-face-name', 'font-face-uri', | |
'glyph', 'glyphRef', 'hkern', 'image', 'line', 'missing-glyph', 'mpath', | |
'path', 'polygon', 'polyline', 'rect', 'set', 'stop', 'tref', 'use', 'view', | |
'vkern' | |
].join('|') + ')(?:[\.#][a-zA-Z0-9\u007F-\uFFFF_:-]+)*$') | |
function selfClosing (tag) { return closeRE.test(tag) } | |
},{"hyperscript-attribute-to-property":2}],2:[function(require,module,exports){ | |
module.exports = attributeToProperty | |
var transform = { | |
'class': 'className', | |
'for': 'htmlFor', | |
'http-equiv': 'httpEquiv' | |
} | |
function attributeToProperty (h) { | |
return function (tagName, attrs, children) { | |
for (var attr in attrs) { | |
if (attr in transform) { | |
attrs[transform[attr]] = attrs[attr] | |
delete attrs[attr] | |
} | |
} | |
return h(tagName, attrs, children) | |
} | |
} | |
},{}],3:[function(require,module,exports){ | |
var h = require("./virtual-hyperscript/index.js") | |
module.exports = h | |
},{"./virtual-hyperscript/index.js":11}],4:[function(require,module,exports){ | |
/*! | |
* Cross-Browser Split 1.1.1 | |
* Copyright 2007-2012 Steven Levithan <stevenlevithan.com> | |
* Available under the MIT License | |
* ECMAScript compliant, uniform cross-browser split method | |
*/ | |
/** | |
* Splits a string into an array of strings using a regex or string separator. Matches of the | |
* separator are not included in the result array. However, if `separator` is a regex that contains | |
* capturing groups, backreferences are spliced into the result each time `separator` is matched. | |
* Fixes browser bugs compared to the native `String.prototype.split` and can be used reliably | |
* cross-browser. | |
* @param {String} str String to split. | |
* @param {RegExp|String} separator Regex or string to use for separating the string. | |
* @param {Number} [limit] Maximum number of items to include in the result array. | |
* @returns {Array} Array of substrings. | |
* @example | |
* | |
* // Basic use | |
* split('a b c d', ' '); | |
* // -> ['a', 'b', 'c', 'd'] | |
* | |
* // With limit | |
* split('a b c d', ' ', 2); | |
* // -> ['a', 'b'] | |
* | |
* // Backreferences in result array | |
* split('..word1 word2..', /([a-z]+)(\d+)/i); | |
* // -> ['..', 'word', '1', ' ', 'word', '2', '..'] | |
*/ | |
module.exports = (function split(undef) { | |
var nativeSplit = String.prototype.split, | |
compliantExecNpcg = /()??/.exec("")[1] === undef, | |
// NPCG: nonparticipating capturing group | |
self; | |
self = function(str, separator, limit) { | |
// If `separator` is not a regex, use `nativeSplit` | |
if (Object.prototype.toString.call(separator) !== "[object RegExp]") { | |
return nativeSplit.call(str, separator, limit); | |
} | |
var output = [], | |
flags = (separator.ignoreCase ? "i" : "") + (separator.multiline ? "m" : "") + (separator.extended ? "x" : "") + // Proposed for ES6 | |
(separator.sticky ? "y" : ""), | |
// Firefox 3+ | |
lastLastIndex = 0, | |
// Make `global` and avoid `lastIndex` issues by working with a copy | |
separator = new RegExp(separator.source, flags + "g"), | |
separator2, match, lastIndex, lastLength; | |
str += ""; // Type-convert | |
if (!compliantExecNpcg) { | |
// Doesn't need flags gy, but they don't hurt | |
separator2 = new RegExp("^" + separator.source + "$(?!\\s)", flags); | |
} | |
/* Values for `limit`, per the spec: | |
* If undefined: 4294967295 // Math.pow(2, 32) - 1 | |
* If 0, Infinity, or NaN: 0 | |
* If positive number: limit = Math.floor(limit); if (limit > 4294967295) limit -= 4294967296; | |
* If negative number: 4294967296 - Math.floor(Math.abs(limit)) | |
* If other: Type-convert, then use the above rules | |
*/ | |
limit = limit === undef ? -1 >>> 0 : // Math.pow(2, 32) - 1 | |
limit >>> 0; // ToUint32(limit) | |
while (match = separator.exec(str)) { | |
// `separator.lastIndex` is not reliable cross-browser | |
lastIndex = match.index + match[0].length; | |
if (lastIndex > lastLastIndex) { | |
output.push(str.slice(lastLastIndex, match.index)); | |
// Fix browsers whose `exec` methods don't consistently return `undefined` for | |
// nonparticipating capturing groups | |
if (!compliantExecNpcg && match.length > 1) { | |
match[0].replace(separator2, function() { | |
for (var i = 1; i < arguments.length - 2; i++) { | |
if (arguments[i] === undef) { | |
match[i] = undef; | |
} | |
} | |
}); | |
} | |
if (match.length > 1 && match.index < str.length) { | |
Array.prototype.push.apply(output, match.slice(1)); | |
} | |
lastLength = match[0].length; | |
lastLastIndex = lastIndex; | |
if (output.length >= limit) { | |
break; | |
} | |
} | |
if (separator.lastIndex === match.index) { | |
separator.lastIndex++; // Avoid an infinite loop | |
} | |
} | |
if (lastLastIndex === str.length) { | |
if (lastLength || !separator.test("")) { | |
output.push(""); | |
} | |
} else { | |
output.push(str.slice(lastLastIndex)); | |
} | |
return output.length > limit ? output.slice(0, limit) : output; | |
}; | |
return self; | |
})(); | |
},{}],5:[function(require,module,exports){ | |
'use strict'; | |
var OneVersionConstraint = require('individual/one-version'); | |
var MY_VERSION = '7'; | |
OneVersionConstraint('ev-store', MY_VERSION); | |
var hashKey = '__EV_STORE_KEY@' + MY_VERSION; | |
module.exports = EvStore; | |
function EvStore(elem) { | |
var hash = elem[hashKey]; | |
if (!hash) { | |
hash = elem[hashKey] = {}; | |
} | |
return hash; | |
} | |
},{"individual/one-version":7}],6:[function(require,module,exports){ | |
(function (global){ | |
'use strict'; | |
/*global window, global*/ | |
var root = typeof window !== 'undefined' ? | |
window : typeof global !== 'undefined' ? | |
global : {}; | |
module.exports = Individual; | |
function Individual(key, value) { | |
if (key in root) { | |
return root[key]; | |
} | |
root[key] = value; | |
return value; | |
} | |
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) | |
//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy92aXJ0dWFsLWRvbS9ub2RlX21vZHVsZXMvZXYtc3RvcmUvbm9kZV9tb2R1bGVzL2luZGl2aWR1YWwvaW5kZXguanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLypnbG9iYWwgd2luZG93LCBnbG9iYWwqL1xuXG52YXIgcm9vdCA9IHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnID9cbiAgICB3aW5kb3cgOiB0eXBlb2YgZ2xvYmFsICE9PSAndW5kZWZpbmVkJyA/XG4gICAgZ2xvYmFsIDoge307XG5cbm1vZHVsZS5leHBvcnRzID0gSW5kaXZpZHVhbDtcblxuZnVuY3Rpb24gSW5kaXZpZHVhbChrZXksIHZhbHVlKSB7XG4gICAgaWYgKGtleSBpbiByb290KSB7XG4gICAgICAgIHJldHVybiByb290W2tleV07XG4gICAgfVxuXG4gICAgcm9vdFtrZXldID0gdmFsdWU7XG5cbiAgICByZXR1cm4gdmFsdWU7XG59XG4iXX0= | |
},{}],7:[function(require,module,exports){ | |
'use strict'; | |
var Individual = require('./index.js'); | |
module.exports = OneVersion; | |
function OneVersion(moduleName, version, defaultValue) { | |
var key = '__INDIVIDUAL_ONE_VERSION_' + moduleName; | |
var enforceKey = key + '_ENFORCE_SINGLETON'; | |
var versionValue = Individual(enforceKey, version); | |
if (versionValue !== version) { | |
throw new Error('Can only have one copy of ' + | |
moduleName + '.\n' + | |
'You already have version ' + versionValue + | |
' installed.\n' + | |
'This means you cannot install version ' + version); | |
} | |
return Individual(key, defaultValue); | |
} | |
},{"./index.js":6}],8:[function(require,module,exports){ | |
var nativeIsArray = Array.isArray | |
var toString = Object.prototype.toString | |
module.exports = nativeIsArray || isArray | |
function isArray(obj) { | |
return toString.call(obj) === "[object Array]" | |
} | |
},{}],9:[function(require,module,exports){ | |
'use strict'; | |
var EvStore = require('ev-store'); | |
module.exports = EvHook; | |
function EvHook(value) { | |
if (!(this instanceof EvHook)) { | |
return new EvHook(value); | |
} | |
this.value = value; | |
} | |
EvHook.prototype.hook = function (node, propertyName) { | |
var es = EvStore(node); | |
var propName = propertyName.substr(3); | |
es[propName] = this.value; | |
}; | |
EvHook.prototype.unhook = function(node, propertyName) { | |
var es = EvStore(node); | |
var propName = propertyName.substr(3); | |
es[propName] = undefined; | |
}; | |
},{"ev-store":5}],10:[function(require,module,exports){ | |
'use strict'; | |
module.exports = SoftSetHook; | |
function SoftSetHook(value) { | |
if (!(this instanceof SoftSetHook)) { | |
return new SoftSetHook(value); | |
} | |
this.value = value; | |
} | |
SoftSetHook.prototype.hook = function (node, propertyName) { | |
if (node[propertyName] !== this.value) { | |
node[propertyName] = this.value; | |
} | |
}; | |
},{}],11:[function(require,module,exports){ | |
'use strict'; | |
var isArray = require('x-is-array'); | |
var VNode = require('../vnode/vnode.js'); | |
var VText = require('../vnode/vtext.js'); | |
var isVNode = require('../vnode/is-vnode'); | |
var isVText = require('../vnode/is-vtext'); | |
var isWidget = require('../vnode/is-widget'); | |
var isHook = require('../vnode/is-vhook'); | |
var isVThunk = require('../vnode/is-thunk'); | |
var parseTag = require('./parse-tag.js'); | |
var softSetHook = require('./hooks/soft-set-hook.js'); | |
var evHook = require('./hooks/ev-hook.js'); | |
module.exports = h; | |
function h(tagName, properties, children) { | |
var childNodes = []; | |
var tag, props, key, namespace; | |
if (!children && isChildren(properties)) { | |
children = properties; | |
props = {}; | |
} | |
props = props || properties || {}; | |
tag = parseTag(tagName, props); | |
// support keys | |
if (props.hasOwnProperty('key')) { | |
key = props.key; | |
props.key = undefined; | |
} | |
// support namespace | |
if (props.hasOwnProperty('namespace')) { | |
namespace = props.namespace; | |
props.namespace = undefined; | |
} | |
// fix cursor bug | |
if (tag === 'INPUT' && | |
!namespace && | |
props.hasOwnProperty('value') && | |
props.value !== undefined && | |
!isHook(props.value) | |
) { | |
props.value = softSetHook(props.value); | |
} | |
transformProperties(props); | |
if (children !== undefined && children !== null) { | |
addChild(children, childNodes, tag, props); | |
} | |
return new VNode(tag, props, childNodes, key, namespace); | |
} | |
function addChild(c, childNodes, tag, props) { | |
if (typeof c === 'string') { | |
childNodes.push(new VText(c)); | |
} else if (typeof c === 'number') { | |
childNodes.push(new VText(String(c))); | |
} else if (isChild(c)) { | |
childNodes.push(c); | |
} else if (isArray(c)) { | |
for (var i = 0; i < c.length; i++) { | |
addChild(c[i], childNodes, tag, props); | |
} | |
} else if (c === null || c === undefined) { | |
return; | |
} else { | |
throw UnexpectedVirtualElement({ | |
foreignObject: c, | |
parentVnode: { | |
tagName: tag, | |
properties: props | |
} | |
}); | |
} | |
} | |
function transformProperties(props) { | |
for (var propName in props) { | |
if (props.hasOwnProperty(propName)) { | |
var value = props[propName]; | |
if (isHook(value)) { | |
continue; | |
} | |
if (propName.substr(0, 3) === 'ev-') { | |
// add ev-foo support | |
props[propName] = evHook(value); | |
} | |
} | |
} | |
} | |
function isChild(x) { | |
return isVNode(x) || isVText(x) || isWidget(x) || isVThunk(x); | |
} | |
function isChildren(x) { | |
return typeof x === 'string' || isArray(x) || isChild(x); | |
} | |
function UnexpectedVirtualElement(data) { | |
var err = new Error(); | |
err.type = 'virtual-hyperscript.unexpected.virtual-element'; | |
err.message = 'Unexpected virtual child passed to h().\n' + | |
'Expected a VNode / Vthunk / VWidget / string but:\n' + | |
'got:\n' + | |
errorString(data.foreignObject) + | |
'.\n' + | |
'The parent vnode is:\n' + | |
errorString(data.parentVnode) | |
'\n' + | |
'Suggested fix: change your `h(..., [ ... ])` callsite.'; | |
err.foreignObject = data.foreignObject; | |
err.parentVnode = data.parentVnode; | |
return err; | |
} | |
function errorString(obj) { | |
try { | |
return JSON.stringify(obj, null, ' '); | |
} catch (e) { | |
return String(obj); | |
} | |
} | |
},{"../vnode/is-thunk":13,"../vnode/is-vhook":14,"../vnode/is-vnode":15,"../vnode/is-vtext":16,"../vnode/is-widget":17,"../vnode/vnode.js":19,"../vnode/vtext.js":20,"./hooks/ev-hook.js":9,"./hooks/soft-set-hook.js":10,"./parse-tag.js":12,"x-is-array":8}],12:[function(require,module,exports){ | |
'use strict'; | |
var split = require('browser-split'); | |
var classIdSplit = /([\.#]?[a-zA-Z0-9\u007F-\uFFFF_:-]+)/; | |
var notClassId = /^\.|#/; | |
module.exports = parseTag; | |
function parseTag(tag, props) { | |
if (!tag) { | |
return 'DIV'; | |
} | |
var noId = !(props.hasOwnProperty('id')); | |
var tagParts = split(tag, classIdSplit); | |
var tagName = null; | |
if (notClassId.test(tagParts[1])) { | |
tagName = 'DIV'; | |
} | |
var classes, part, type, i; | |
for (i = 0; i < tagParts.length; i++) { | |
part = tagParts[i]; | |
if (!part) { | |
continue; | |
} | |
type = part.charAt(0); | |
if (!tagName) { | |
tagName = part; | |
} else if (type === '.') { | |
classes = classes || []; | |
classes.push(part.substring(1, part.length)); | |
} else if (type === '#' && noId) { | |
props.id = part.substring(1, part.length); | |
} | |
} | |
if (classes) { | |
if (props.className) { | |
classes.push(props.className); | |
} | |
props.className = classes.join(' '); | |
} | |
return props.namespace ? tagName : tagName.toUpperCase(); | |
} | |
},{"browser-split":4}],13:[function(require,module,exports){ | |
module.exports = isThunk | |
function isThunk(t) { | |
return t && t.type === "Thunk" | |
} | |
},{}],14:[function(require,module,exports){ | |
module.exports = isHook | |
function isHook(hook) { | |
return hook && | |
(typeof hook.hook === "function" && !hook.hasOwnProperty("hook") || | |
typeof hook.unhook === "function" && !hook.hasOwnProperty("unhook")) | |
} | |
},{}],15:[function(require,module,exports){ | |
var version = require("./version") | |
module.exports = isVirtualNode | |
function isVirtualNode(x) { | |
return x && x.type === "VirtualNode" && x.version === version | |
} | |
},{"./version":18}],16:[function(require,module,exports){ | |
var version = require("./version") | |
module.exports = isVirtualText | |
function isVirtualText(x) { | |
return x && x.type === "VirtualText" && x.version === version | |
} | |
},{"./version":18}],17:[function(require,module,exports){ | |
module.exports = isWidget | |
function isWidget(w) { | |
return w && w.type === "Widget" | |
} | |
},{}],18:[function(require,module,exports){ | |
module.exports = "2" | |
},{}],19:[function(require,module,exports){ | |
var version = require("./version") | |
var isVNode = require("./is-vnode") | |
var isWidget = require("./is-widget") | |
var isThunk = require("./is-thunk") | |
var isVHook = require("./is-vhook") | |
module.exports = VirtualNode | |
var noProperties = {} | |
var noChildren = [] | |
function VirtualNode(tagName, properties, children, key, namespace) { | |
this.tagName = tagName | |
this.properties = properties || noProperties | |
this.children = children || noChildren | |
this.key = key != null ? String(key) : undefined | |
this.namespace = (typeof namespace === "string") ? namespace : null | |
var count = (children && children.length) || 0 | |
var descendants = 0 | |
var hasWidgets = false | |
var hasThunks = false | |
var descendantHooks = false | |
var hooks | |
for (var propName in properties) { | |
if (properties.hasOwnProperty(propName)) { | |
var property = properties[propName] | |
if (isVHook(property) && property.unhook) { | |
if (!hooks) { | |
hooks = {} | |
} | |
hooks[propName] = property | |
} | |
} | |
} | |
for (var i = 0; i < count; i++) { | |
var child = children[i] | |
if (isVNode(child)) { | |
descendants += child.count || 0 | |
if (!hasWidgets && child.hasWidgets) { | |
hasWidgets = true | |
} | |
if (!hasThunks && child.hasThunks) { | |
hasThunks = true | |
} | |
if (!descendantHooks && (child.hooks || child.descendantHooks)) { | |
descendantHooks = true | |
} | |
} else if (!hasWidgets && isWidget(child)) { | |
if (typeof child.destroy === "function") { | |
hasWidgets = true | |
} | |
} else if (!hasThunks && isThunk(child)) { | |
hasThunks = true; | |
} | |
} | |
this.count = count + descendants | |
this.hasWidgets = hasWidgets | |
this.hasThunks = hasThunks | |
this.hooks = hooks | |
this.descendantHooks = descendantHooks | |
} | |
VirtualNode.prototype.version = version | |
VirtualNode.prototype.type = "VirtualNode" | |
},{"./is-thunk":13,"./is-vhook":14,"./is-vnode":15,"./is-widget":17,"./version":18}],20:[function(require,module,exports){ | |
var version = require("./version") | |
module.exports = VirtualText | |
function VirtualText(text) { | |
this.text = String(text) | |
} | |
VirtualText.prototype.version = version | |
VirtualText.prototype.type = "VirtualText" | |
},{"./version":18}],"chooet/html":[function(require,module,exports){ | |
module.exports = require('hyperx')(require('virtual-dom/h')); | |
},{"hyperx":1,"virtual-dom/h":3}]},{},[]) | |
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/browser-pack/_prelude.js","node_modules/hyperx/index.js","node_modules/hyperx/node_modules/hyperscript-attribute-to-property/index.js","node_modules/virtual-dom/h.js","node_modules/virtual-dom/node_modules/browser-split/index.js","node_modules/virtual-dom/node_modules/ev-store/index.js","node_modules/virtual-dom/node_modules/ev-store/node_modules/individual/index.js","node_modules/virtual-dom/node_modules/ev-store/node_modules/individual/one-version.js","node_modules/virtual-dom/node_modules/x-is-array/index.js","node_modules/virtual-dom/virtual-hyperscript/hooks/ev-hook.js","node_modules/virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js","node_modules/virtual-dom/virtual-hyperscript/index.js","node_modules/virtual-dom/virtual-hyperscript/parse-tag.js","node_modules/virtual-dom/vnode/is-thunk.js","node_modules/virtual-dom/vnode/is-vhook.js","node_modules/virtual-dom/vnode/is-vnode.js","node_modules/virtual-dom/vnode/is-vtext.js","node_modules/virtual-dom/vnode/is-widget.js","node_modules/virtual-dom/vnode/version.js","node_modules/virtual-dom/vnode/vnode.js","node_modules/virtual-dom/vnode/vtext.js","html.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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1GA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var attrToProp = require('hyperscript-attribute-to-property')\n\nvar VAR = 0, TEXT = 1, OPEN = 2, CLOSE = 3, ATTR = 4\nvar ATTR_KEY = 5, ATTR_KEY_W = 6\nvar ATTR_VALUE_W = 7, ATTR_VALUE = 8\nvar ATTR_VALUE_SQ = 9, ATTR_VALUE_DQ = 10\nvar ATTR_EQ = 11, ATTR_BREAK = 12\n\nmodule.exports = function (h, opts) {\n  h = attrToProp(h)\n  if (!opts) opts = {}\n  var concat = opts.concat || function (a, b) {\n    return String(a) + String(b)\n  }\n\n  return function (strings) {\n    var state = TEXT, reg = ''\n    var arglen = arguments.length\n    var parts = []\n\n    for (var i = 0; i < strings.length; i++) {\n      if (i < arglen - 1) {\n        var arg = arguments[i+1]\n        var p = parse(strings[i])\n        var xstate = state\n        if (xstate === ATTR_VALUE_DQ) xstate = ATTR_VALUE\n        if (xstate === ATTR_VALUE_SQ) xstate = ATTR_VALUE\n        if (xstate === ATTR_VALUE_W) xstate = ATTR_VALUE\n        if (xstate === ATTR) xstate = ATTR_KEY\n        p.push([ VAR, xstate, arg ])\n        parts.push.apply(parts, p)\n      } else parts.push.apply(parts, parse(strings[i]))\n    }\n\n    var tree = [null,{},[]]\n    var stack = [[tree,-1]]\n    for (var i = 0; i < parts.length; i++) {\n      var cur = stack[stack.length-1][0]\n      var p = parts[i], s = p[0]\n      if (s === OPEN && /^\\//.test(p[1])) {\n        var ix = stack[stack.length-1][1]\n        if (stack.length > 1) {\n          stack.pop()\n          stack[stack.length-1][0][2][ix] = h(\n            cur[0], cur[1], cur[2].length ? cur[2] : undefined\n          )\n        }\n      } else if (s === OPEN) {\n        var c = [p[1],{},[]]\n        cur[2].push(c)\n        stack.push([c,cur[2].length-1])\n      } else if (s === ATTR_KEY || (s === VAR && p[1] === ATTR_KEY)) {\n        var key = ''\n        var copyKey\n        for (; i < parts.length; i++) {\n          if (parts[i][0] === ATTR_KEY) {\n            key = concat(key, parts[i][1])\n          } else if (parts[i][0] === VAR && parts[i][1] === ATTR_KEY) {\n            if (typeof parts[i][2] === 'object' && !key) {\n              for (copyKey in parts[i][2]) {\n                if (parts[i][2].hasOwnProperty(copyKey) && !cur[1][copyKey]) {\n                  cur[1][copyKey] = parts[i][2][copyKey]\n                }\n              }\n            } else {\n              key = concat(key, parts[i][2])\n            }\n          } else break\n        }\n        if (parts[i][0] === ATTR_EQ) i++\n        var j = i\n        for (; i < parts.length; i++) {\n          if (parts[i][0] === ATTR_VALUE || parts[i][0] === ATTR_KEY) {\n            if (!cur[1][key]) cur[1][key] = strfn(parts[i][1])\n            else cur[1][key] = concat(cur[1][key], parts[i][1])\n          } else if (parts[i][0] === VAR\n          && (parts[i][1] === ATTR_VALUE || parts[i][1] === ATTR_KEY)) {\n            if (!cur[1][key]) cur[1][key] = strfn(parts[i][2])\n            else cur[1][key] = concat(cur[1][key], parts[i][2])\n          } else {\n            if (key.length && !cur[1][key] && i === j\n            && (parts[i][0] === CLOSE || parts[i][0] === ATTR_BREAK)) {\n              // https://html.spec.whatwg.org/multipage/infrastructure.html#boolean-attributes\n              // empty string is falsy, not well behaved value in browser\n              cur[1][key] = key.toLowerCase()\n            }\n            break\n          }\n        }\n      } else if (s === ATTR_KEY) {\n        cur[1][p[1]] = true\n      } else if (s === VAR && p[1] === ATTR_KEY) {\n        cur[1][p[2]] = true\n      } else if (s === CLOSE) {\n        if (selfClosing(cur[0]) && stack.length) {\n          var ix = stack[stack.length-1][1]\n          stack.pop()\n          stack[stack.length-1][0][2][ix] = h(\n            cur[0], cur[1], cur[2].length ? cur[2] : undefined\n          )\n        }\n      } else if (s === VAR && p[1] === TEXT) {\n        if (p[2] === undefined || p[2] === null) p[2] = ''\n        else if (!p[2]) p[2] = concat('', p[2])\n        if (Array.isArray(p[2][0])) {\n          cur[2].push.apply(cur[2], p[2])\n        } else {\n          cur[2].push(p[2])\n        }\n      } else if (s === TEXT) {\n        cur[2].push(p[1])\n      } else if (s === ATTR_EQ || s === ATTR_BREAK) {\n        // no-op\n      } else {\n        throw new Error('unhandled: ' + s)\n      }\n    }\n\n    if (tree[2].length > 1 && /^\\s*$/.test(tree[2][0])) {\n      tree[2].shift()\n    }\n\n    if (tree[2].length > 2\n    || (tree[2].length === 2 && /\\S/.test(tree[2][1]))) {\n      throw new Error(\n        'multiple root elements must be wrapped in an enclosing tag'\n      )\n    }\n    if (Array.isArray(tree[2][0]) && typeof tree[2][0][0] === 'string'\n    && Array.isArray(tree[2][0][2])) {\n      tree[2][0] = h(tree[2][0][0], tree[2][0][1], tree[2][0][2])\n    }\n    return tree[2][0]\n\n    function parse (str) {\n      var res = []\n      if (state === ATTR_VALUE_W) state = ATTR\n      for (var i = 0; i < str.length; i++) {\n        var c = str.charAt(i)\n        if (state === TEXT && c === '<') {\n          if (reg.length) res.push([TEXT, reg])\n          reg = ''\n          state = OPEN\n        } else if (c === '>' && !quot(state)) {\n          if (state === OPEN) {\n            res.push([OPEN,reg])\n          } else if (state === ATTR_KEY) {\n            res.push([ATTR_KEY,reg])\n          } else if (state === ATTR_VALUE && reg.length) {\n            res.push([ATTR_VALUE,reg])\n          }\n          res.push([CLOSE])\n          reg = ''\n          state = TEXT\n        } else if (state === TEXT) {\n          reg += c\n        } else if (state === OPEN && /\\s/.test(c)) {\n          res.push([OPEN, reg])\n          reg = ''\n          state = ATTR\n        } else if (state === OPEN) {\n          reg += c\n        } else if (state === ATTR && /[\\w-]/.test(c)) {\n          state = ATTR_KEY\n          reg = c\n        } else if (state === ATTR && /\\s/.test(c)) {\n          if (reg.length) res.push([ATTR_KEY,reg])\n          res.push([ATTR_BREAK])\n        } else if (state === ATTR_KEY && /\\s/.test(c)) {\n          res.push([ATTR_KEY,reg])\n          reg = ''\n          state = ATTR_KEY_W\n        } else if (state === ATTR_KEY && c === '=') {\n          res.push([ATTR_KEY,reg],[ATTR_EQ])\n          reg = ''\n          state = ATTR_VALUE_W\n        } else if (state === ATTR_KEY) {\n          reg += c\n        } else if ((state === ATTR_KEY_W || state === ATTR) && c === '=') {\n          res.push([ATTR_EQ])\n          state = ATTR_VALUE_W\n        } else if ((state === ATTR_KEY_W || state === ATTR) && !/\\s/.test(c)) {\n          res.push([ATTR_BREAK])\n          if (/[\\w-]/.test(c)) {\n            reg += c\n            state = ATTR_KEY\n          } else state = ATTR\n        } else if (state === ATTR_VALUE_W && c === '\"') {\n          state = ATTR_VALUE_DQ\n        } else if (state === ATTR_VALUE_W && c === \"'\") {\n          state = ATTR_VALUE_SQ\n        } else if (state === ATTR_VALUE_DQ && c === '\"') {\n          res.push([ATTR_VALUE,reg],[ATTR_BREAK])\n          reg = ''\n          state = ATTR\n        } else if (state === ATTR_VALUE_SQ && c === \"'\") {\n          res.push([ATTR_VALUE,reg],[ATTR_BREAK])\n          reg = ''\n          state = ATTR\n        } else if (state === ATTR_VALUE_W && !/\\s/.test(c)) {\n          state = ATTR_VALUE\n          i--\n        } else if (state === ATTR_VALUE && /\\s/.test(c)) {\n          res.push([ATTR_VALUE,reg],[ATTR_BREAK])\n          reg = ''\n          state = ATTR\n        } else if (state === ATTR_VALUE || state === ATTR_VALUE_SQ\n        || state === ATTR_VALUE_DQ) {\n          reg += c\n        }\n      }\n      if (state === TEXT && reg.length) {\n        res.push([TEXT,reg])\n        reg = ''\n      } else if (state === ATTR_VALUE && reg.length) {\n        res.push([ATTR_VALUE,reg])\n        reg = ''\n      } else if (state === ATTR_VALUE_DQ && reg.length) {\n        res.push([ATTR_VALUE,reg])\n        reg = ''\n      } else if (state === ATTR_VALUE_SQ && reg.length) {\n        res.push([ATTR_VALUE,reg])\n        reg = ''\n      } else if (state === ATTR_KEY) {\n        res.push([ATTR_KEY,reg])\n        reg = ''\n      }\n      return res\n    }\n  }\n\n  function strfn (x) {\n    if (typeof x === 'function') return x\n    else if (typeof x === 'string') return x\n    else if (x && typeof x === 'object') return x\n    else return concat('', x)\n  }\n}\n\nfunction quot (state) {\n  return state === ATTR_VALUE_SQ || state === ATTR_VALUE_DQ\n}\n\nvar hasOwn = Object.prototype.hasOwnProperty\nfunction has (obj, key) { return hasOwn.call(obj, key) }\n\nvar closeRE = RegExp('^(' + [\n  'area', 'base', 'basefont', 'bgsound', 'br', 'col', 'command', 'embed',\n  'frame', 'hr', 'img', 'input', 'isindex', 'keygen', 'link', 'meta', 'param',\n  'source', 'track', 'wbr',\n  // SVG TAGS\n  'animate', 'animateTransform', 'circle', 'cursor', 'desc', 'ellipse',\n  'feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite',\n  'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap',\n  'feDistantLight', 'feFlood', 'feFuncA', 'feFuncB', 'feFuncG', 'feFuncR',\n  'feGaussianBlur', 'feImage', 'feMergeNode', 'feMorphology',\n  'feOffset', 'fePointLight', 'feSpecularLighting', 'feSpotLight', 'feTile',\n  'feTurbulence', 'font-face-format', 'font-face-name', 'font-face-uri',\n  'glyph', 'glyphRef', 'hkern', 'image', 'line', 'missing-glyph', 'mpath',\n  'path', 'polygon', 'polyline', 'rect', 'set', 'stop', 'tref', 'use', 'view',\n  'vkern'\n].join('|') + ')(?:[\\.#][a-zA-Z0-9\\u007F-\\uFFFF_:-]+)*$')\nfunction selfClosing (tag) { return closeRE.test(tag) }\n","module.exports = attributeToProperty\n\nvar transform = {\n  'class': 'className',\n  'for': 'htmlFor',\n  'http-equiv': 'httpEquiv'\n}\n\nfunction attributeToProperty (h) {\n  return function (tagName, attrs, children) {\n    for (var attr in attrs) {\n      if (attr in transform) {\n        attrs[transform[attr]] = attrs[attr]\n        delete attrs[attr]\n      }\n    }\n    return h(tagName, attrs, children)\n  }\n}\n","var h = require(\"./virtual-hyperscript/index.js\")\n\nmodule.exports = h\n","/*!\n * Cross-Browser Split 1.1.1\n * Copyright 2007-2012 Steven Levithan <stevenlevithan.com>\n * Available under the MIT License\n * ECMAScript compliant, uniform cross-browser split method\n */\n\n/**\n * Splits a string into an array of strings using a regex or string separator. Matches of the\n * separator are not included in the result array. However, if `separator` is a regex that contains\n * capturing groups, backreferences are spliced into the result each time `separator` is matched.\n * Fixes browser bugs compared to the native `String.prototype.split` and can be used reliably\n * cross-browser.\n * @param {String} str String to split.\n * @param {RegExp|String} separator Regex or string to use for separating the string.\n * @param {Number} [limit] Maximum number of items to include in the result array.\n * @returns {Array} Array of substrings.\n * @example\n *\n * // Basic use\n * split('a b c d', ' ');\n * // -> ['a', 'b', 'c', 'd']\n *\n * // With limit\n * split('a b c d', ' ', 2);\n * // -> ['a', 'b']\n *\n * // Backreferences in result array\n * split('..word1 word2..', /([a-z]+)(\\d+)/i);\n * // -> ['..', 'word', '1', ' ', 'word', '2', '..']\n */\nmodule.exports = (function split(undef) {\n\n  var nativeSplit = String.prototype.split,\n    compliantExecNpcg = /()??/.exec(\"\")[1] === undef,\n    // NPCG: nonparticipating capturing group\n    self;\n\n  self = function(str, separator, limit) {\n    // If `separator` is not a regex, use `nativeSplit`\n    if (Object.prototype.toString.call(separator) !== \"[object RegExp]\") {\n      return nativeSplit.call(str, separator, limit);\n    }\n    var output = [],\n      flags = (separator.ignoreCase ? \"i\" : \"\") + (separator.multiline ? \"m\" : \"\") + (separator.extended ? \"x\" : \"\") + // Proposed for ES6\n      (separator.sticky ? \"y\" : \"\"),\n      // Firefox 3+\n      lastLastIndex = 0,\n      // Make `global` and avoid `lastIndex` issues by working with a copy\n      separator = new RegExp(separator.source, flags + \"g\"),\n      separator2, match, lastIndex, lastLength;\n    str += \"\"; // Type-convert\n    if (!compliantExecNpcg) {\n      // Doesn't need flags gy, but they don't hurt\n      separator2 = new RegExp(\"^\" + separator.source + \"$(?!\\\\s)\", flags);\n    }\n    /* Values for `limit`, per the spec:\n     * If undefined: 4294967295 // Math.pow(2, 32) - 1\n     * If 0, Infinity, or NaN: 0\n     * If positive number: limit = Math.floor(limit); if (limit > 4294967295) limit -= 4294967296;\n     * If negative number: 4294967296 - Math.floor(Math.abs(limit))\n     * If other: Type-convert, then use the above rules\n     */\n    limit = limit === undef ? -1 >>> 0 : // Math.pow(2, 32) - 1\n    limit >>> 0; // ToUint32(limit)\n    while (match = separator.exec(str)) {\n      // `separator.lastIndex` is not reliable cross-browser\n      lastIndex = match.index + match[0].length;\n      if (lastIndex > lastLastIndex) {\n        output.push(str.slice(lastLastIndex, match.index));\n        // Fix browsers whose `exec` methods don't consistently return `undefined` for\n        // nonparticipating capturing groups\n        if (!compliantExecNpcg && match.length > 1) {\n          match[0].replace(separator2, function() {\n            for (var i = 1; i < arguments.length - 2; i++) {\n              if (arguments[i] === undef) {\n                match[i] = undef;\n              }\n            }\n          });\n        }\n        if (match.length > 1 && match.index < str.length) {\n          Array.prototype.push.apply(output, match.slice(1));\n        }\n        lastLength = match[0].length;\n        lastLastIndex = lastIndex;\n        if (output.length >= limit) {\n          break;\n        }\n      }\n      if (separator.lastIndex === match.index) {\n        separator.lastIndex++; // Avoid an infinite loop\n      }\n    }\n    if (lastLastIndex === str.length) {\n      if (lastLength || !separator.test(\"\")) {\n        output.push(\"\");\n      }\n    } else {\n      output.push(str.slice(lastLastIndex));\n    }\n    return output.length > limit ? output.slice(0, limit) : output;\n  };\n\n  return self;\n})();\n","'use strict';\n\nvar OneVersionConstraint = require('individual/one-version');\n\nvar MY_VERSION = '7';\nOneVersionConstraint('ev-store', MY_VERSION);\n\nvar hashKey = '__EV_STORE_KEY@' + MY_VERSION;\n\nmodule.exports = EvStore;\n\nfunction EvStore(elem) {\n    var hash = elem[hashKey];\n\n    if (!hash) {\n        hash = elem[hashKey] = {};\n    }\n\n    return hash;\n}\n","(function (global){\n'use strict';\n\n/*global window, global*/\n\nvar root = typeof window !== 'undefined' ?\n    window : typeof global !== 'undefined' ?\n    global : {};\n\nmodule.exports = Individual;\n\nfunction Individual(key, value) {\n    if (key in root) {\n        return root[key];\n    }\n\n    root[key] = value;\n\n    return value;\n}\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy92aXJ0dWFsLWRvbS9ub2RlX21vZHVsZXMvZXYtc3RvcmUvbm9kZV9tb2R1bGVzL2luZGl2aWR1YWwvaW5kZXguanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLypnbG9iYWwgd2luZG93LCBnbG9iYWwqL1xuXG52YXIgcm9vdCA9IHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnID9cbiAgICB3aW5kb3cgOiB0eXBlb2YgZ2xvYmFsICE9PSAndW5kZWZpbmVkJyA/XG4gICAgZ2xvYmFsIDoge307XG5cbm1vZHVsZS5leHBvcnRzID0gSW5kaXZpZHVhbDtcblxuZnVuY3Rpb24gSW5kaXZpZHVhbChrZXksIHZhbHVlKSB7XG4gICAgaWYgKGtleSBpbiByb290KSB7XG4gICAgICAgIHJldHVybiByb290W2tleV07XG4gICAgfVxuXG4gICAgcm9vdFtrZXldID0gdmFsdWU7XG5cbiAgICByZXR1cm4gdmFsdWU7XG59XG4iXX0=","'use strict';\n\nvar Individual = require('./index.js');\n\nmodule.exports = OneVersion;\n\nfunction OneVersion(moduleName, version, defaultValue) {\n    var key = '__INDIVIDUAL_ONE_VERSION_' + moduleName;\n    var enforceKey = key + '_ENFORCE_SINGLETON';\n\n    var versionValue = Individual(enforceKey, version);\n\n    if (versionValue !== version) {\n        throw new Error('Can only have one copy of ' +\n            moduleName + '.\\n' +\n            'You already have version ' + versionValue +\n            ' installed.\\n' +\n            'This means you cannot install version ' + version);\n    }\n\n    return Individual(key, defaultValue);\n}\n","var nativeIsArray = Array.isArray\nvar toString = Object.prototype.toString\n\nmodule.exports = nativeIsArray || isArray\n\nfunction isArray(obj) {\n    return toString.call(obj) === \"[object Array]\"\n}\n","'use strict';\n\nvar EvStore = require('ev-store');\n\nmodule.exports = EvHook;\n\nfunction EvHook(value) {\n    if (!(this instanceof EvHook)) {\n        return new EvHook(value);\n    }\n\n    this.value = value;\n}\n\nEvHook.prototype.hook = function (node, propertyName) {\n    var es = EvStore(node);\n    var propName = propertyName.substr(3);\n\n    es[propName] = this.value;\n};\n\nEvHook.prototype.unhook = function(node, propertyName) {\n    var es = EvStore(node);\n    var propName = propertyName.substr(3);\n\n    es[propName] = undefined;\n};\n","'use strict';\n\nmodule.exports = SoftSetHook;\n\nfunction SoftSetHook(value) {\n    if (!(this instanceof SoftSetHook)) {\n        return new SoftSetHook(value);\n    }\n\n    this.value = value;\n}\n\nSoftSetHook.prototype.hook = function (node, propertyName) {\n    if (node[propertyName] !== this.value) {\n        node[propertyName] = this.value;\n    }\n};\n","'use strict';\n\nvar isArray = require('x-is-array');\n\nvar VNode = require('../vnode/vnode.js');\nvar VText = require('../vnode/vtext.js');\nvar isVNode = require('../vnode/is-vnode');\nvar isVText = require('../vnode/is-vtext');\nvar isWidget = require('../vnode/is-widget');\nvar isHook = require('../vnode/is-vhook');\nvar isVThunk = require('../vnode/is-thunk');\n\nvar parseTag = require('./parse-tag.js');\nvar softSetHook = require('./hooks/soft-set-hook.js');\nvar evHook = require('./hooks/ev-hook.js');\n\nmodule.exports = h;\n\nfunction h(tagName, properties, children) {\n    var childNodes = [];\n    var tag, props, key, namespace;\n\n    if (!children && isChildren(properties)) {\n        children = properties;\n        props = {};\n    }\n\n    props = props || properties || {};\n    tag = parseTag(tagName, props);\n\n    // support keys\n    if (props.hasOwnProperty('key')) {\n        key = props.key;\n        props.key = undefined;\n    }\n\n    // support namespace\n    if (props.hasOwnProperty('namespace')) {\n        namespace = props.namespace;\n        props.namespace = undefined;\n    }\n\n    // fix cursor bug\n    if (tag === 'INPUT' &&\n        !namespace &&\n        props.hasOwnProperty('value') &&\n        props.value !== undefined &&\n        !isHook(props.value)\n    ) {\n        props.value = softSetHook(props.value);\n    }\n\n    transformProperties(props);\n\n    if (children !== undefined && children !== null) {\n        addChild(children, childNodes, tag, props);\n    }\n\n\n    return new VNode(tag, props, childNodes, key, namespace);\n}\n\nfunction addChild(c, childNodes, tag, props) {\n    if (typeof c === 'string') {\n        childNodes.push(new VText(c));\n    } else if (typeof c === 'number') {\n        childNodes.push(new VText(String(c)));\n    } else if (isChild(c)) {\n        childNodes.push(c);\n    } else if (isArray(c)) {\n        for (var i = 0; i < c.length; i++) {\n            addChild(c[i], childNodes, tag, props);\n        }\n    } else if (c === null || c === undefined) {\n        return;\n    } else {\n        throw UnexpectedVirtualElement({\n            foreignObject: c,\n            parentVnode: {\n                tagName: tag,\n                properties: props\n            }\n        });\n    }\n}\n\nfunction transformProperties(props) {\n    for (var propName in props) {\n        if (props.hasOwnProperty(propName)) {\n            var value = props[propName];\n\n            if (isHook(value)) {\n                continue;\n            }\n\n            if (propName.substr(0, 3) === 'ev-') {\n                // add ev-foo support\n                props[propName] = evHook(value);\n            }\n        }\n    }\n}\n\nfunction isChild(x) {\n    return isVNode(x) || isVText(x) || isWidget(x) || isVThunk(x);\n}\n\nfunction isChildren(x) {\n    return typeof x === 'string' || isArray(x) || isChild(x);\n}\n\nfunction UnexpectedVirtualElement(data) {\n    var err = new Error();\n\n    err.type = 'virtual-hyperscript.unexpected.virtual-element';\n    err.message = 'Unexpected virtual child passed to h().\\n' +\n        'Expected a VNode / Vthunk / VWidget / string but:\\n' +\n        'got:\\n' +\n        errorString(data.foreignObject) +\n        '.\\n' +\n        'The parent vnode is:\\n' +\n        errorString(data.parentVnode)\n        '\\n' +\n        'Suggested fix: change your `h(..., [ ... ])` callsite.';\n    err.foreignObject = data.foreignObject;\n    err.parentVnode = data.parentVnode;\n\n    return err;\n}\n\nfunction errorString(obj) {\n    try {\n        return JSON.stringify(obj, null, '    ');\n    } catch (e) {\n        return String(obj);\n    }\n}\n","'use strict';\n\nvar split = require('browser-split');\n\nvar classIdSplit = /([\\.#]?[a-zA-Z0-9\\u007F-\\uFFFF_:-]+)/;\nvar notClassId = /^\\.|#/;\n\nmodule.exports = parseTag;\n\nfunction parseTag(tag, props) {\n    if (!tag) {\n        return 'DIV';\n    }\n\n    var noId = !(props.hasOwnProperty('id'));\n\n    var tagParts = split(tag, classIdSplit);\n    var tagName = null;\n\n    if (notClassId.test(tagParts[1])) {\n        tagName = 'DIV';\n    }\n\n    var classes, part, type, i;\n\n    for (i = 0; i < tagParts.length; i++) {\n        part = tagParts[i];\n\n        if (!part) {\n            continue;\n        }\n\n        type = part.charAt(0);\n\n        if (!tagName) {\n            tagName = part;\n        } else if (type === '.') {\n            classes = classes || [];\n            classes.push(part.substring(1, part.length));\n        } else if (type === '#' && noId) {\n            props.id = part.substring(1, part.length);\n        }\n    }\n\n    if (classes) {\n        if (props.className) {\n            classes.push(props.className);\n        }\n\n        props.className = classes.join(' ');\n    }\n\n    return props.namespace ? tagName : tagName.toUpperCase();\n}\n","module.exports = isThunk\r\n\r\nfunction isThunk(t) {\r\n    return t && t.type === \"Thunk\"\r\n}\r\n","module.exports = isHook\n\nfunction isHook(hook) {\n    return hook &&\n      (typeof hook.hook === \"function\" && !hook.hasOwnProperty(\"hook\") ||\n       typeof hook.unhook === \"function\" && !hook.hasOwnProperty(\"unhook\"))\n}\n","var version = require(\"./version\")\n\nmodule.exports = isVirtualNode\n\nfunction isVirtualNode(x) {\n    return x && x.type === \"VirtualNode\" && x.version === version\n}\n","var version = require(\"./version\")\n\nmodule.exports = isVirtualText\n\nfunction isVirtualText(x) {\n    return x && x.type === \"VirtualText\" && x.version === version\n}\n","module.exports = isWidget\n\nfunction isWidget(w) {\n    return w && w.type === \"Widget\"\n}\n","module.exports = \"2\"\n","var version = require(\"./version\")\nvar isVNode = require(\"./is-vnode\")\nvar isWidget = require(\"./is-widget\")\nvar isThunk = require(\"./is-thunk\")\nvar isVHook = require(\"./is-vhook\")\n\nmodule.exports = VirtualNode\n\nvar noProperties = {}\nvar noChildren = []\n\nfunction VirtualNode(tagName, properties, children, key, namespace) {\n    this.tagName = tagName\n    this.properties = properties || noProperties\n    this.children = children || noChildren\n    this.key = key != null ? String(key) : undefined\n    this.namespace = (typeof namespace === \"string\") ? namespace : null\n\n    var count = (children && children.length) || 0\n    var descendants = 0\n    var hasWidgets = false\n    var hasThunks = false\n    var descendantHooks = false\n    var hooks\n\n    for (var propName in properties) {\n        if (properties.hasOwnProperty(propName)) {\n            var property = properties[propName]\n            if (isVHook(property) && property.unhook) {\n                if (!hooks) {\n                    hooks = {}\n                }\n\n                hooks[propName] = property\n            }\n        }\n    }\n\n    for (var i = 0; i < count; i++) {\n        var child = children[i]\n        if (isVNode(child)) {\n            descendants += child.count || 0\n\n            if (!hasWidgets && child.hasWidgets) {\n                hasWidgets = true\n            }\n\n            if (!hasThunks && child.hasThunks) {\n                hasThunks = true\n            }\n\n            if (!descendantHooks && (child.hooks || child.descendantHooks)) {\n                descendantHooks = true\n            }\n        } else if (!hasWidgets && isWidget(child)) {\n            if (typeof child.destroy === \"function\") {\n                hasWidgets = true\n            }\n        } else if (!hasThunks && isThunk(child)) {\n            hasThunks = true;\n        }\n    }\n\n    this.count = count + descendants\n    this.hasWidgets = hasWidgets\n    this.hasThunks = hasThunks\n    this.hooks = hooks\n    this.descendantHooks = descendantHooks\n}\n\nVirtualNode.prototype.version = version\nVirtualNode.prototype.type = \"VirtualNode\"\n","var version = require(\"./version\")\n\nmodule.exports = VirtualText\n\nfunction VirtualText(text) {\n    this.text = String(text)\n}\n\nVirtualText.prototype.version = version\nVirtualText.prototype.type = \"VirtualText\"\n","module.exports = require('hyperx')(require('virtual-dom/h'));\n"]} | |
const chooet = require('chooet'); | |
const html = require('chooet/html'); | |
chooet(choo => { | |
app = choo(); | |
app.model({ | |
state: { title: 'Not quite set yet' }, | |
reducers: { | |
update: (data, state) => ({ title: data }) | |
} | |
}); | |
const mainView = (state, prev, send) => html` | |
<main> | |
<h1>Title: ${state.title}</h1> | |
<input | |
type="text" | |
name="title" | |
dataset=${{input: (event, value) => send('update', value.title)}}> | |
</main> | |
`; | |
app.router(route => [ | |
route('/', mainView) | |
]); | |
app.start('body'); | |
}); | |
;}, 0) |
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
{ | |
"name": "requirebin-sketch", | |
"version": "1.0.0", | |
"dependencies": { | |
"chooet": "1.0.1" | |
} | |
} |
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
<!-- contents of this file will be placed inside the <body> --> |
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
<!-- contents of this file will be placed inside the <head> --> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment