Skip to content

Instantly share code, notes, and snippets.

@joshski
Created October 22, 2017 10:36
Show Gist options
  • Save joshski/b6fdb8131c9c8d451863b41a6558d727 to your computer and use it in GitHub Desktop.
Save joshski/b6fdb8131c9c8d451863b41a6558d727 to your computer and use it in GitHub Desktop.
requirebin sketch
var hyperdom = require('hyperdom')
var h = hyperdom.html
class App {
render() {
return h('.container',
h('#example',
h('div.foo div', h('input[type=submit]'))
),
h.component({
onadd: function(pre) {
pre.innerText = document.querySelector('#example').innerHTML
}
}, h('pre'))
)
}
}
hyperdom.append(document.body, new App())
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){
},{}],2:[function(require,module,exports){
var VText = require("virtual-dom/vnode/vtext.js")
var domComponent = require('./domComponent');
var hyperdom = require('.');
var deprecations = require('./deprecations');
function ComponentWidget(state, vdom) {
if (!vdom) {
throw new Error('hyperdom.html.component([options], vdom) expects a vdom argument');
}
this.state = state;
this.key = state.key;
var currentRender = hyperdom.currentRender();
if (typeof vdom === 'function') {
this.render = function () {
if (currentRender) {
currentRender.eventHandlerWrapper = state.on;
}
return vdom.apply(this.state, arguments);
};
this.canRefresh = true;
} else {
vdom = vdom || new VText('');
this.render = function () {
return vdom;
}
}
this.cacheKey = state.cacheKey;
this.component = domComponent();
var renderFinished = currentRender && currentRender.finished;
if (renderFinished) {
this.afterRender = function (fn) {
renderFinished.then(fn);
};
} else {
this.afterRender = function () {};
}
}
ComponentWidget.prototype.type = 'Widget';
ComponentWidget.prototype.init = function () {
var self = this;
if (self.state.onbeforeadd) {
self.state.onbeforeadd();
}
var vdom = this.render(this);
if (vdom instanceof Array) {
throw new Error('vdom returned from component cannot be an array');
}
var element = this.component.create(vdom);
if (self.state.onadd) {
this.afterRender(function () {
self.state.onadd(element);
});
}
if (self.state.detached) {
return document.createTextNode('');
} else {
return element;
}
};
ComponentWidget.prototype.update = function (previous) {
var self = this;
var refresh = !this.cacheKey || this.cacheKey !== previous.cacheKey;
if (refresh) {
if (self.state.onupdate) {
this.afterRender(function () {
self.state.onupdate(self.component.element);
});
}
}
this.component = previous.component;
if (previous.state && this.state) {
var keys = Object.keys(this.state);
for(var n = 0; n < keys.length; n++) {
var key = keys[n];
previous.state[key] = self.state[key];
}
this.state = previous.state;
}
if (refresh) {
var element = this.component.update(this.render(this));
if (self.state.detached) {
return document.createTextNode('');
} else {
return element;
}
}
};
ComponentWidget.prototype.refresh = function () {
this.component.update(this.render(this));
if (this.state.onupdate) {
this.state.onupdate(this.component.element);
}
};
ComponentWidget.prototype.rerender = ComponentWidget.prototype.refresh;
ComponentWidget.prototype.destroy = function (element) {
var self = this;
if (self.state.onremove) {
this.afterRender(function () {
self.state.onremove(element);
});
}
this.component.destroy();
};
module.exports = function (state, vdom) {
deprecations.component('hyperdom.html.component is deprecated, please use ViewModels');
if (typeof state === 'function') {
return new ComponentWidget({}, state);
} else if (state.constructor === Object) {
return new ComponentWidget(state, vdom);
} else {
return new ComponentWidget({}, state);
}
};
module.exports.ComponentWidget = ComponentWidget;
},{".":"hyperdom","./deprecations":3,"./domComponent":4,"virtual-dom/vnode/vtext.js":32}],3:[function(require,module,exports){
function deprecationWarning() {
var warningIssued = false;
return function (arg) {
if (!warningIssued) {
console.warn(arg);
warningIssued = true;
}
};
}
module.exports = {
refresh: deprecationWarning(),
currentRender: deprecationWarning(),
window: deprecationWarning(),
component: deprecationWarning(),
renderFunction: deprecationWarning(),
refreshAfter: deprecationWarning(),
norefresh: deprecationWarning()
};
},{}],4:[function(require,module,exports){
var createElement = require('virtual-dom/create-element');
var diff = require('virtual-dom/diff');
var patch = require('virtual-dom/patch');
var toVdom = require('./toVdom');
var isVdom = require('./isVdom');
function DomComponent(options) {
this.document = options && options.document;
}
function prepareVdom(object) {
var vdom = toVdom(object);
if (!isVdom(vdom)) {
throw new Error('expected render to return vdom');
} else {
return vdom;
}
}
DomComponent.prototype.create = function (vdom) {
this.vdom = prepareVdom(vdom);
return this.element = createElement(this.vdom, {document: this.document});
};
DomComponent.prototype.merge = function (vdom, element) {
this.vdom = prepareVdom(vdom);
return this.element = element;
};
DomComponent.prototype.update = function (vdom) {
var oldVdom = this.vdom;
this.vdom = prepareVdom(vdom);
var patches = diff(oldVdom, this.vdom);
return this.element = patch(this.element, patches);
};
DomComponent.prototype.destroy = function (options) {
function destroyWidgets(vdom) {
if (vdom.type === 'Widget') {
vdom.destroy();
} else if (vdom.children) {
vdom.children.forEach(destroyWidgets);
}
}
destroyWidgets(this.vdom);
if (options && options.removeElement && this.element.parentNode) {
this.element.parentNode.removeChild(this.element);
}
};
function domComponent(options) {
return new DomComponent(options);
}
module.exports = domComponent;
},{"./isVdom":5,"./toVdom":40,"virtual-dom/create-element":8,"virtual-dom/diff":9,"virtual-dom/patch":14}],5:[function(require,module,exports){
var virtualDomVersion = require("virtual-dom/vnode/version")
module.exports = function(x) {
var type = x.type;
if (type == 'VirtualNode' || type == 'VirtualText') {
return x.version == virtualDomVersion;
} else {
return type == 'Widget' || type == 'Thunk';
}
};
},{"virtual-dom/vnode/version":29}],6:[function(require,module,exports){
module.exports = function (model, property) {
var hyperdomMeta = model._hyperdomMeta;
if (!hyperdomMeta) {
hyperdomMeta = {};
Object.defineProperty(model, '_hyperdomMeta', {value: hyperdomMeta});
}
if (property) {
var meta = hyperdomMeta[property];
if (!meta) {
meta = hyperdomMeta[property] = {};
}
return meta;
} else {
return hyperdomMeta;
}
};
},{}],7:[function(require,module,exports){
var hyperdomMeta = require('./meta');
var runRender = require('./runRender');
var hyperdom = require('.');
var Set = require('./set');
var lastId = 0;
function Mount(model, options) {
var win = (options && options.window) || window;
this.requestRender = (options && options.requestRender) || win.requestAnimationFrame || win.setTimeout;
this.model = model;
this.renderQueued = false;
this.mountRenderRequested = false;
this.widgetRendersRequested = undefined;
this.id = ++lastId;
this.mounted = true;
}
Mount.prototype.queueRender = function () {
if (!this.renderQueued) {
var requestRender = this.requestRender;
var self = this;
requestRender(function () {
self.renderQueued = false;
if (self.mounted) {
runRender(self, function () {
if (self.mountRenderRequested) {
var vdom = self.render();
self.component.update(vdom);
self.mountRenderRequested = false;
} else if (self.widgetRendersRequested && self.widgetRendersRequested.length) {
for (var i = 0, l = self.widgetRendersRequested.length; i < l; i++) {
var w = self.widgetRendersRequested[i];
w.rerender();
}
self.widgetRendersRequested = undefined;
}
});
}
});
this.renderQueued = true;
}
};
Mount.prototype.render = function() {
return this.renderViewModel(this.model);
};
Mount.prototype.rerender = function () {
this.mountRenderRequested = true;
this.queueRender();
};
Mount.prototype.rerenderWidget = function (widget) {
if (!this.widgetRendersRequested) {
this.widgetRendersRequested = [];
}
this.widgetRendersRequested.push(widget);
this.queueRender();
};
Mount.prototype._renderViewModel = function(model) {
var self = this;
model.rerender = function () {
self.rerender();
};
model.rerenderViewModel = function() {
var meta = hyperdomMeta(this);
meta.widgets.forEach(function (w) {
self.rerenderWidget(w);
});
};
var meta = hyperdomMeta(model);
if (!meta.mount) {
meta.mount = this;
}
if (!meta.widgets) {
meta.widgets = new Set();
}
if (typeof model.onload == 'function') {
if (!meta.loaded) {
meta.loaded = true;
hyperdom.refreshify(function () { return model.onload(); }, {refresh: 'promise'})();
}
}
var vdom = model.render();
if (vdom instanceof Array) {
throw new Error('vdom returned from component cannot be an array');
}
if (vdom && vdom.properties) {
vdom.properties._hyperdomViewModel = model;
}
return vdom;
}
Mount.prototype.renderViewModel = function(model) {
if (typeof model.renderCacheKey === 'function') {
var meta = hyperdomMeta(model);
var key = model.renderCacheKey();
if (key !== undefined && meta.cacheKey === key && meta.cachedVdom) {
return meta.cachedVdom;
} else {
meta.cacheKey = key;
return meta.cachedVdom = this._renderViewModel(model);
}
} else {
return this._renderViewModel(model);
}
};
Mount.prototype.detach = function () {
this.mounted = false;
};
Mount.prototype.remove = function () {
this.component.destroy({removeElement: true});
this.mounted = false;
};
module.exports = Mount;
},{".":"hyperdom","./meta":6,"./runRender":37,"./set":38}],8:[function(require,module,exports){
var createElement = require("./vdom/create-element.js")
module.exports = createElement
},{"./vdom/create-element.js":16}],9:[function(require,module,exports){
var diff = require("./vtree/diff.js")
module.exports = diff
},{"./vtree/diff.js":34}],10:[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;
})();
},{}],11:[function(require,module,exports){
(function (global){
var topLevel = typeof global !== 'undefined' ? global :
typeof window !== 'undefined' ? window : {}
var minDoc = require('min-document');
if (typeof document !== 'undefined') {
module.exports = document;
} else {
var doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'];
if (!doccy) {
doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'] = minDoc;
}
module.exports = doccy;
}
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"min-document":1}],12:[function(require,module,exports){
"use strict";
module.exports = function isObject(x) {
return typeof x === "object" && x !== null;
};
},{}],13:[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]"
}
},{}],14:[function(require,module,exports){
var patch = require("./vdom/patch.js")
module.exports = patch
},{"./vdom/patch.js":19}],15:[function(require,module,exports){
var isObject = require("is-object")
var isHook = require("../vnode/is-vhook.js")
module.exports = applyProperties
function applyProperties(node, props, previous) {
for (var propName in props) {
var propValue = props[propName]
if (propValue === undefined) {
removeProperty(node, propName, propValue, previous);
} else if (isHook(propValue)) {
removeProperty(node, propName, propValue, previous)
if (propValue.hook) {
propValue.hook(node,
propName,
previous ? previous[propName] : undefined)
}
} else {
if (isObject(propValue)) {
patchObject(node, props, previous, propName, propValue);
} else {
node[propName] = propValue
}
}
}
}
function removeProperty(node, propName, propValue, previous) {
if (previous) {
var previousValue = previous[propName]
if (!isHook(previousValue)) {
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
}
} else if (previousValue.unhook) {
previousValue.unhook(node, propName, propValue)
}
}
}
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) {
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.js":25,"is-object":12}],16:[function(require,module,exports){
var document = require("global/document")
var applyProperties = require("./apply-properties")
var isVNode = require("../vnode/is-vnode.js")
var isVText = require("../vnode/is-vtext.js")
var isWidget = require("../vnode/is-widget.js")
var handleThunk = require("../vnode/handle-thunk.js")
module.exports = createElement
function createElement(vnode, opts) {
var doc = opts ? opts.document || document : document
var warn = opts ? opts.warn : null
vnode = handleThunk(vnode).a
if (isWidget(vnode)) {
return vnode.init()
} else if (isVText(vnode)) {
return doc.createTextNode(vnode.text)
} else if (!isVNode(vnode)) {
if (warn) {
warn("Item is not a valid virtual dom node", vnode)
}
return null
}
var node = (vnode.namespace === null) ?
doc.createElement(vnode.tagName) :
doc.createElementNS(vnode.namespace, vnode.tagName)
var props = vnode.properties
applyProperties(node, props)
var children = vnode.children
for (var i = 0; i < children.length; i++) {
var childNode = createElement(children[i], opts)
if (childNode) {
node.appendChild(childNode)
}
}
return node
}
},{"../vnode/handle-thunk.js":23,"../vnode/is-vnode.js":26,"../vnode/is-vtext.js":27,"../vnode/is-widget.js":28,"./apply-properties":15,"global/document":11}],17:[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 vChildren = tree.children
if (vChildren) {
var childNodes = rootNode.childNodes
for (var i = 0; i < tree.children.length; i++) {
rootIndex += 1
var vChild = vChildren[i] || noChild
var nextIndex = rootIndex + (vChild.count || 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
}
},{}],18:[function(require,module,exports){
var applyProperties = require("./apply-properties")
var isWidget = require("../vnode/is-widget.js")
var VPatch = require("../vnode/vpatch.js")
var updateWidget = require("./update-widget")
module.exports = applyPatch
function applyPatch(vpatch, domNode, renderOptions) {
var type = vpatch.type
var vNode = vpatch.vNode
var patch = vpatch.patch
switch (type) {
case VPatch.REMOVE:
return removeNode(domNode, vNode)
case VPatch.INSERT:
return insertNode(domNode, patch, renderOptions)
case VPatch.VTEXT:
return stringPatch(domNode, vNode, patch, renderOptions)
case VPatch.WIDGET:
return widgetPatch(domNode, vNode, patch, renderOptions)
case VPatch.VNODE:
return vNodePatch(domNode, vNode, patch, renderOptions)
case VPatch.ORDER:
reorderChildren(domNode, patch)
return domNode
case VPatch.PROPS:
applyProperties(domNode, patch, vNode.properties)
return domNode
case VPatch.THUNK:
return replaceRoot(domNode,
renderOptions.patch(domNode, patch, renderOptions))
default:
return domNode
}
}
function removeNode(domNode, vNode) {
var parentNode = domNode.parentNode
if (parentNode) {
parentNode.removeChild(domNode)
}
destroyWidget(domNode, vNode);
return null
}
function insertNode(parentNode, vNode, renderOptions) {
var newNode = renderOptions.render(vNode, renderOptions)
if (parentNode) {
parentNode.appendChild(newNode)
}
return parentNode
}
function stringPatch(domNode, leftVNode, vText, renderOptions) {
var newNode
if (domNode.nodeType === 3) {
domNode.replaceData(0, domNode.length, vText.text)
newNode = domNode
} else {
var parentNode = domNode.parentNode
newNode = renderOptions.render(vText, renderOptions)
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
}
return newNode
}
function widgetPatch(domNode, leftVNode, widget, renderOptions) {
var updating = updateWidget(leftVNode, widget)
var newNode
if (updating) {
newNode = widget.update(leftVNode, domNode) || domNode
} else {
newNode = renderOptions.render(widget, renderOptions)
}
var parentNode = domNode.parentNode
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
if (!updating) {
destroyWidget(domNode, leftVNode)
}
return newNode
}
function vNodePatch(domNode, leftVNode, vNode, renderOptions) {
var parentNode = domNode.parentNode
var newNode = renderOptions.render(vNode, renderOptions)
if (parentNode && newNode !== domNode) {
parentNode.replaceChild(newNode, domNode)
}
return newNode
}
function destroyWidget(domNode, w) {
if (typeof w.destroy === "function" && isWidget(w)) {
w.destroy(domNode)
}
}
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;
}
},{"../vnode/is-widget.js":28,"../vnode/vpatch.js":31,"./apply-properties":15,"./update-widget":20}],19:[function(require,module,exports){
var document = require("global/document")
var isArray = require("x-is-array")
var render = require("./create-element")
var domIndex = require("./dom-index")
var patchOp = require("./patch-op")
module.exports = patch
function patch(rootNode, patches, renderOptions) {
renderOptions = renderOptions || {}
renderOptions.patch = renderOptions.patch && renderOptions.patch !== patch
? renderOptions.patch
: patchRecursive
renderOptions.render = renderOptions.render || render
return renderOptions.patch(rootNode, patches, renderOptions)
}
function patchRecursive(rootNode, patches, renderOptions) {
var indices = patchIndices(patches)
if (indices.length === 0) {
return rootNode
}
var index = domIndex(rootNode, patches.a, indices)
var ownerDocument = rootNode.ownerDocument
if (!renderOptions.document && ownerDocument !== document) {
renderOptions.document = ownerDocument
}
for (var i = 0; i < indices.length; i++) {
var nodeIndex = indices[i]
rootNode = applyPatch(rootNode,
index[nodeIndex],
patches[nodeIndex],
renderOptions)
}
return rootNode
}
function applyPatch(rootNode, domNode, patchList, renderOptions) {
if (!domNode) {
return rootNode
}
var newNode
if (isArray(patchList)) {
for (var i = 0; i < patchList.length; i++) {
newNode = patchOp(patchList[i], domNode, renderOptions)
if (domNode === rootNode) {
rootNode = newNode
}
}
} else {
newNode = patchOp(patchList, domNode, renderOptions)
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
}
},{"./create-element":16,"./dom-index":17,"./patch-op":18,"global/document":11,"x-is-array":13}],20:[function(require,module,exports){
var isWidget = require("../vnode/is-widget.js")
module.exports = updateWidget
function updateWidget(a, b) {
if (isWidget(a) && isWidget(b)) {
if ("name" in a && "name" in b) {
return a.id === b.id
} else {
return a.init === b.init
}
}
return false
}
},{"../vnode/is-widget.js":28}],21:[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;
}
};
},{}],22:[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":10}],23:[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":24,"./is-vnode":26,"./is-vtext":27,"./is-widget":28}],24:[function(require,module,exports){
module.exports = isThunk
function isThunk(t) {
return t && t.type === "Thunk"
}
},{}],25:[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"))
}
},{}],26:[function(require,module,exports){
var version = require("./version")
module.exports = isVirtualNode
function isVirtualNode(x) {
return x && x.type === "VirtualNode" && x.version === version
}
},{"./version":29}],27:[function(require,module,exports){
var version = require("./version")
module.exports = isVirtualText
function isVirtualText(x) {
return x && x.type === "VirtualText" && x.version === version
}
},{"./version":29}],28:[function(require,module,exports){
module.exports = isWidget
function isWidget(w) {
return w && w.type === "Widget"
}
},{}],29:[function(require,module,exports){
module.exports = "2"
},{}],30:[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":24,"./is-vhook":25,"./is-vnode":26,"./is-widget":28,"./version":29}],31:[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":29}],32:[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":29}],33:[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":25,"is-object":12}],34:[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":23,"../vnode/is-thunk":24,"../vnode/is-vnode":26,"../vnode/is-vtext":27,"../vnode/is-widget":28,"../vnode/vpatch":31,"./diff-props":33,"x-is-array":13}],35:[function(require,module,exports){
var simplePromise = require('./simplePromise');
function Render(mount) {
this.finished = simplePromise();
this.mount = mount;
this.attachment = mount;
}
module.exports = Render;
},{"./simplePromise":39}],36:[function(require,module,exports){
(function (global){
var h = require('./vhtml');
var domComponent = require('./domComponent');
var bindingMeta = require('./meta');
var toVdom = require('./toVdom');
var parseTag = require('virtual-dom/virtual-hyperscript/parse-tag');
var ViewModel = require('./viewModel');
var Mount = require('./mount');
var runRender = require('./runRender');
var deprecations = require('./deprecations');
var hyperdom = require('.');
function isViewModelOrComponent(component) {
return component
&& ((typeof component.init === 'function'
&& typeof component.update === 'function'
&& typeof component.destroy === 'function') || (typeof component.renderViewModel === 'function'));
}
exports.merge = function (element, render, model, options) {
var mount = startAttachment(render, model, options, function(mount, domComponentOptions) {
var component = domComponent(domComponentOptions);
var currentRender = hyperdom.currentRender;
currentRender.eventHandlerWrapper = function() {
return null;
};
var vdom = mount.render();
component.merge(vdom, element);
return component;
});
mount.rerender();
return mount;
};
exports.append = function (element, render, model, options) {
return startAttachment(render, model, options, function(mount, domComponentOptions) {
var component = domComponent(domComponentOptions);
var vdom = mount.render();
element.appendChild(component.create(vdom));
return component;
});
};
exports.replace = function (element, render, model, options) {
return startAttachment(render, model, options, function(mount, domComponentOptions) {
var component = domComponent(domComponentOptions);
var vdom = mount.render();
element.parentNode.replaceChild(component.create(vdom), element);
return component;
});
};
exports.appendVDom = function (vdom, render, model, options) {
return startAttachment(render, model, options, function(mount) {
var component = {
create: function(newVDom) {
vdom.children = [];
if (newVDom) {
vdom.children.push(newVDom);
}
},
update: function(newVDom) {
vdom.children = [];
if (newVDom) {
vdom.children.push(newVDom);
}
}
};
component.create(mount.render());
return component;
});
};
exports.ViewModel = ViewModel;
function startAttachment(render, model, options, attachToDom) {
if (typeof render == 'object' && typeof render.render == 'function') {
return start(render, attachToDom, model);
} else {
deprecations.renderFunction('hyperdom.append and hyperdom.replace with render functions are deprecated, please pass a ViewModel');
return start({render: function () { return render(model); }}, attachToDom, options);
}
}
function start(model, attachToDom, options) {
var mount = new Mount(model, options);
runRender(mount, function () {
if (options) {
var domComponentOptions = {document: options.document};
}
mount.component = attachToDom(mount, domComponentOptions);
});
return mount;
}
var norefresh = {};
function norefreshFunction() {
return norefresh;
}
function refreshify(fn, options) {
if (!fn) {
return fn;
}
var currentRender = hyperdom.currentRender();
if (!currentRender) {
if (typeof global === 'object') {
return fn;
} else {
throw new Error('You cannot create virtual-dom event handlers outside a render function. See https://github.com/featurist/hyperdom#outside-render-cycle');
}
}
var mount = currentRender.mount;
var handleEventResult = exports.createEventResultHandler(mount, options);
if (options && (options.norefresh == true || options.refresh == false)) {
return fn;
}
return function () {
var result = fn.apply(this, arguments);
return handleEventResult(result);
};
}
exports.createEventResultHandler = function(mount, options) {
var onlyRefreshAfterPromise = options && options.refresh == 'promise';
var viewModelToRefresh = options && options.viewModel;
var componentToRefresh = options && options.component;
function handleEventResult(result, promiseResult) {
if (result && typeof(result.then) == 'function') {
result.then(function (result) { handleEventResult(result, true); });
}
if (onlyRefreshAfterPromise && !promiseResult) {
return;
}
if (isViewModelOrComponent(result)) {
mount.rerenderWidget(result);
} else if (result instanceof Array) {
for (var i = 0; i < result.length; i++) {
handleEventResult(result[i]);
}
} else if (viewModelToRefresh) {
viewModelToRefresh.rerenderViewModel();
} else if (componentToRefresh) {
componentToRefresh.refresh();
} else if (result === norefresh) {
// don't refresh;
} else if (result === norefreshFunction) {
deprecations.norefresh('hyperdom.html.norefresh is deprecated, please use hyperdom.norefresh()');
// don't refresh;
} else {
mount.rerender();
return result;
}
}
return handleEventResult;
};
function bindTextInput(attributes, children, get, set) {
var textEventNames = ['onkeyup', 'oninput', 'onpaste', 'textInput'];
var bindingValue = get();
if (!(bindingValue instanceof Error)) {
attributes.value = bindingValue != undefined? bindingValue: '';
}
attachEventHandler(attributes, textEventNames, function (ev) {
if (bindingValue != ev.target.value) {
set(ev.target.value);
}
});
}
function sequenceFunctions(handler1, handler2) {
return function (ev) {
handler1(ev);
return handler2(ev);
};
}
function insertEventHandler(attributes, eventName, handler) {
var previousHandler = attributes[eventName];
if (previousHandler) {
attributes[eventName] = sequenceFunctions(handler, previousHandler);
} else {
attributes[eventName] = handler;
}
}
function attachEventHandler(attributes, eventNames, handler) {
if (eventNames instanceof Array) {
for (var n = 0; n < eventNames.length; n++) {
insertEventHandler(attributes, eventNames[n], handler);
}
} else {
insertEventHandler(attributes, eventNames, handler);
}
}
function ListenerHook(listener) {
this.listener = exports.html.refreshify(listener);
}
ListenerHook.prototype.hook = function (element, propertyName) {
element.addEventListener(propertyName.substring(2), this.listener, false);
};
ListenerHook.prototype.unhook = function (element, propertyName) {
element.removeEventListener(propertyName.substring(2), this.listener);
};
function customEvent(name) {
if (typeof Event == 'function') {
return new Event(name);
} else {
var event = document.createEvent('Event');
event.initEvent(name, false, false);
return event;
}
}
var inputTypeBindings = {
text: bindTextInput,
textarea: bindTextInput,
checkbox: function (attributes, children, get, set) {
attributes.checked = get();
attachEventHandler(attributes, 'onclick', function (ev) {
attributes.checked = ev.target.checked;
set(ev.target.checked);
});
},
radio: function (attributes, children, get, set) {
var value = attributes.value;
attributes.checked = get() == attributes.value;
attributes.on_hyperdomsyncchecked = new ListenerHook(function (event) {
attributes.checked = event.target.checked;
});
attachEventHandler(attributes, 'onclick', function (event) {
var name = event.target.name;
if (name) {
var inputs = document.getElementsByName(name);
for (var i = 0, l = inputs.length; i < l; i++) {
inputs[i].dispatchEvent(customEvent('_hyperdomsyncchecked'));
}
}
set(value);
});
},
select: function (attributes, children, get, set) {
var currentValue = get();
var options = children.filter(function (child) {
return child.tagName.toLowerCase() == 'option';
});
var values = [];
var selectedIndex;
for(var n = 0; n < options.length; n++) {
var option = options[n];
var hasValue = option.properties.hasOwnProperty('value');
var value = option.properties.value;
var text = option.children.map(function (x) { return x.text; }).join('');
values.push(hasValue? value: text);
var selected = value == currentValue || text == currentValue;
if (selected) {
selectedIndex = n;
}
option.properties.selected = selected;
option.properties.value = n;
}
if (selectedIndex !== undefined) {
attributes.selectedIndex = selectedIndex;
}
attachEventHandler(attributes, 'onchange', function (ev) {
attributes.selectedIndex = ev.target.selectedIndex;
set(values[ev.target.value]);
});
},
file: function (attributes, children, get, set) {
var multiple = attributes.multiple;
attachEventHandler(attributes, 'onchange', function (ev) {
if (multiple) {
set(ev.target.files);
} else {
set(ev.target.files[0]);
}
});
}
};
function bindModel(attributes, children, type) {
var bind = inputTypeBindings[type] || bindTextInput;
var bindingAttr = makeBinding(attributes.binding);
bind(attributes, children, bindingAttr.get, bindingAttr.set);
}
function inputType(selector, attributes) {
if (/^textarea\b/i.test(selector)) {
return 'textarea';
} else if (/^select\b/i.test(selector)) {
return 'select';
} else {
return attributes.type || 'text';
}
}
var renames = {
for: 'htmlFor',
class: 'className',
contenteditable: 'contentEditable',
tabindex: 'tabIndex',
colspan: 'colSpan'
};
var dataAttributeRegex = /^data-/;
function prepareAttributes(tag, attributes, childElements) {
var keys = Object.keys(attributes);
var dataset;
var currentRender = hyperdom.currentRender();
var eventHandlerWrapper = currentRender && currentRender.eventHandlerWrapper;
for (var k = 0; k < keys.length; k++) {
var key = keys[k];
var attribute = attributes[key];
if (typeof(attribute) == 'function') {
if (eventHandlerWrapper) {
var fn = eventHandlerWrapper.call(undefined, key.replace(/^on/, ''), attribute);
attributes[key] = typeof fn === 'function'? refreshify(fn): fn;
} else {
attributes[key] = refreshify(attribute);
}
}
var rename = renames[key];
if (rename) {
attributes[rename] = attribute;
delete attributes[key];
continue;
}
if (dataAttributeRegex.test(key)) {
if (!dataset) {
dataset = attributes.dataset;
if (!dataset) {
dataset = attributes.dataset = {};
}
}
var datakey = key
.replace(dataAttributeRegex, '')
.replace(/-([a-z])/ig, function(_, x) { return x.toUpperCase(); });
dataset[datakey] = attribute;
delete attributes[key];
continue;
}
}
if (attributes.className) {
attributes.className = generateClassName(attributes.className);
}
if (attributes.binding) {
bindModel(attributes, childElements, inputType(tag, attributes));
delete attributes.binding;
}
}
/**
* this function is quite ugly and you may be very tempted
* to refactor it into smaller functions, I certainly am.
* however, it was written like this for performance
* so think of that before refactoring! :)
*/
exports.html = function (hierarchySelector) {
var hasHierarchy = hierarchySelector.indexOf(' ') >= 0;
var selector, selectorElements;
if (hasHierarchy) {
selectorElements = hierarchySelector.match(/\S+/g);
selector = selectorElements[selectorElements.length - 1];
} else {
selector = hierarchySelector;
}
var childElements;
var vdom;
var tag;
var attributes = arguments[1];
if (attributes && attributes.constructor == Object && typeof attributes.render !== 'function') {
childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 2));
prepareAttributes(selector, attributes, childElements);
tag = parseTag(selector, attributes);
vdom = h(tag, attributes, childElements);
} else {
attributes = {};
childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 1));
tag = parseTag(selector, attributes);
vdom = h(tag, attributes, childElements);
}
if (hasHierarchy) {
for(var n = selectorElements.length - 2; n >= 0; n--) {
vdom = h(selectorElements[n], {}, [vdom]);
}
}
return vdom;
};
exports.jsx = function (tag, attributes) {
var childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 2));
if (attributes) {
prepareAttributes(tag, attributes, childElements);
}
return h(tag, attributes || {}, childElements);
};
Object.defineProperty(exports.html, 'currentRender', {get: function () {
deprecations.currentRender('hyperdom.html.currentRender is deprecated, please use hyperdom.currentRender() instead');
return exports.html._currentRender;
}});
Object.defineProperty(exports.html, 'refresh', {get: function () {
deprecations.refresh('hyperdom.html.refresh is deprecated, please use viewModel.rerender() instead');
return exports.html._refresh;
}});
function refreshAfter(promise) {
deprecations.refreshAfter('hyperdom.html.refreshAfter is deprecated');
var refresh = exports.html.refresh;
promise.then(refresh);
}
exports.html.refreshify = refreshify;
exports.html.refreshAfter = refreshAfter;
exports.html.norefresh = norefresh;
function makeBinding(b, options) {
var binding = b instanceof Array
? bindingObject.apply(undefined, b)
: b;
binding.set = refreshify(binding.set, options);
return binding;
}
function makeConverter(converter) {
if (typeof converter == 'function') {
return {
view: function (model) {
return model;
},
model: function (view) {
return converter(view);
}
};
} else {
return converter;
}
}
function chainConverters(startIndex, converters) {
function makeConverters() {
if (!_converters) {
_converters = new Array(converters.length - startIndex);
for(var n = startIndex; n < converters.length; n++) {
_converters[n - startIndex] = makeConverter(converters[n]);
}
}
}
if ((converters.length - startIndex) == 1) {
return makeConverter(converters[startIndex]);
} else {
var _converters;
return {
view: function (model) {
makeConverters();
var intermediateValue = model;
for(var n = 0; n < _converters.length; n++) {
intermediateValue = _converters[n].view(intermediateValue);
}
return intermediateValue;
},
model: function (view) {
makeConverters();
var intermediateValue = view;
for(var n = _converters.length - 1; n >= 0; n--) {
intermediateValue = _converters[n].model(intermediateValue);
}
return intermediateValue;
}
};
}
}
function bindingObject(model, property) {
var _meta;
function hyperdomMeta() {
return _meta || (_meta = bindingMeta(model, property));
}
if (arguments.length > 2) {
var converter = chainConverters(2, arguments);
return {
get: function() {
var meta = hyperdomMeta();
var modelValue = model[property];
var modelText;
if (meta.error) {
return meta.view;
} else if (meta.view === undefined) {
modelText = converter.view(modelValue);
meta.view = modelText;
return modelText;
} else {
var previousValue = converter.model(meta.view);
modelText = converter.view(modelValue);
var normalisedPreviousText = converter.view(previousValue);
if (modelText === normalisedPreviousText) {
return meta.view;
} else {
meta.view = modelText;
return modelText;
}
}
},
set: function(view) {
var meta = hyperdomMeta();
meta.view = view;
try {
model[property] = converter.model(view, model[property]);
delete meta.error;
} catch (e) {
meta.error = e;
}
},
meta: function() {
return hyperdomMeta();
}
};
} else {
return {
get: function () {
return model[property];
},
set: function (value) {
model[property] = value;
},
meta: function() {
return hyperdomMeta();
}
};
}
}
exports.binding = makeBinding;
exports.html.binding = makeBinding;
exports.html.meta = bindingMeta;
function rawHtml() {
var selector;
var html;
var options;
if (arguments.length == 2) {
selector = arguments[0];
html = arguments[1];
options = {innerHTML: html};
return exports.html(selector, options);
} else {
selector = arguments[0];
options = arguments[1];
html = arguments[2];
options.innerHTML = html;
return exports.html(selector, options);
}
}
exports.html.rawHtml = rawHtml;
function generateConditionalClassNames(obj) {
return Object.keys(obj).filter(function (key) {
return obj[key];
}).join(' ') || undefined;
}
function generateClassName(obj) {
if (typeof(obj) == 'object') {
if (obj instanceof Array) {
var names = obj.map(function(item) {
return generateClassName(item);
});
return names.join(' ') || undefined;
} else {
return generateConditionalClassNames(obj);
}
} else {
return obj;
}
}
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{".":"hyperdom","./deprecations":3,"./domComponent":4,"./meta":6,"./mount":7,"./runRender":37,"./toVdom":40,"./vhtml":41,"./viewModel":42,"virtual-dom/virtual-hyperscript/parse-tag":22}],37:[function(require,module,exports){
var hyperdom = require('.');
var Render = require('./render');
var rendering = require('./rendering');
function refreshOutOfRender() {
throw new Error('Please assign hyperdom.html.refresh during a render cycle if you want to use it in event handlers. See https://github.com/featurist/hyperdom#refresh-outside-render-cycle');
}
module.exports = function(mount, fn) {
var render = new Render(mount);
try {
hyperdom._currentRender = render;
rendering.html._currentRender = render;
rendering.html._refresh = rendering.createEventResultHandler(mount);
fn();
} finally {
render.finished.fulfill();
hyperdom._currentRender = undefined;
rendering.html._refresh = refreshOutOfRender;
rendering.html._currentRender = undefined;
}
};
},{".":"hyperdom","./render":35,"./rendering":36}],38:[function(require,module,exports){
if (typeof Set === 'function') {
module.exports = Set;
} else {
module.exports = function() {
this.items = [];
};
module.exports.prototype.add = function(widget) {
if (this.items.indexOf(widget) == -1) {
this.items.push(widget);
}
};
module.exports.prototype.delete = function(widget) {
var i = this.items.indexOf(widget);
if (i !== -1) {
this.items.splice(i, 1);
}
};
module.exports.prototype.forEach = function(fn) {
for(var n = 0; n < this.items.length; n++) {
fn(this.items[n]);
}
};
}
},{}],39:[function(require,module,exports){
function SimplePromise () {
this.listeners = [];
}
SimplePromise.prototype.fulfill = function (value) {
if (!this.isFulfilled) {
this.isFulfilled = true;
this.value = value;
this.listeners.forEach(function (listener) {
listener();
});
}
};
SimplePromise.prototype.then = function (success) {
if (this.isFulfilled) {
var self = this;
setTimeout(function () {
success(self.value);
});
} else {
this.listeners.push(success);
}
};
module.exports = function () {
return new SimplePromise();
};
},{}],40:[function(require,module,exports){
var vtext = require("virtual-dom/vnode/vtext.js")
var rendering = require('./rendering');
var isVdom = require('./isVdom');
function toVdom(object) {
if (object === undefined || object === null) {
return new vtext('');
} else if (typeof(object) != 'object') {
return new vtext(String(object));
} else if (object instanceof Date) {
return new vtext(String(object));
} else if (object instanceof Error) {
return new vtext(object.toString());
} else if (isVdom(object)) {
return object;
} else if (typeof object.render === 'function') {
return new rendering.ViewModel(object);
} else {
return new vtext(JSON.stringify(object));
}
}
module.exports = toVdom;
function addChild(children, child) {
if (child instanceof Array) {
for (var n = 0; n < child.length; n++) {
addChild(children, child[n]);
}
} else {
children.push(toVdom(child));
}
}
module.exports.recursive = function (child) {
var children = [];
addChild(children, child);
return children;
};
},{"./isVdom":5,"./rendering":36,"virtual-dom/vnode/vtext.js":32}],41:[function(require,module,exports){
'use strict';
var VNode = require('virtual-dom/vnode/vnode.js');
var isHook = require('virtual-dom/vnode/is-vhook');
var softSetHook = require('virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js');
module.exports = h;
function h(tagName, props, children) {
var tag = tagName;
// support keys
if (props.hasOwnProperty('key')) {
var key = props.key;
props.key = undefined;
}
// support namespace
if (props.hasOwnProperty('namespace')) {
var namespace = props.namespace;
props.namespace = undefined;
}
// fix cursor bug
if (tag.toLowerCase() === 'input' &&
!namespace &&
props.hasOwnProperty('value') &&
props.value !== undefined &&
!isHook(props.value)
) {
props.value = softSetHook(props.value);
}
return new VNode(tag, props, children, key, namespace);
}
},{"virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js":21,"virtual-dom/vnode/is-vhook":25,"virtual-dom/vnode/vnode.js":30}],42:[function(require,module,exports){
var domComponent = require('./domComponent');
var hyperdomMeta = require('./meta');
var hyperdom = require('.');
function ViewModel(model) {
var currentRender = hyperdom.currentRender();
this.currentRender = currentRender;
this.model = model;
this.key = model.renderKey;
this.component = undefined;
this.mount = currentRender.mount;
}
ViewModel.prototype.type = 'Widget';
ViewModel.prototype.init = function () {
var self = this;
var vdom = this.render();
var meta = hyperdomMeta(this.model);
meta.widgets.add(this);
this.component = domComponent();
var element = this.component.create(vdom);
if (self.model.onadd) {
this.currentRender.finished.then(function () {
self.model.onadd(element);
});
}
if (self.model.detached) {
return document.createTextNode('');
} else {
return element;
}
};
ViewModel.prototype.update = function (previous) {
var self = this;
if (self.model.onupdate) {
this.currentRender.finished.then(function () {
self.model.onupdate(self.component.element);
});
}
this.component = previous.component;
var element = this.component.update(this.render());
if (self.model.detached) {
return document.createTextNode('');
} else {
return element;
}
};
ViewModel.prototype.render = function () {
return this.mount.renderViewModel(this.model);
};
ViewModel.prototype.rerender = function () {
this.component.update(this.render());
if (this.model.onupdate) {
this.model.onupdate(this.component.element);
}
};
ViewModel.prototype.destroy = function (element) {
var self = this;
var meta = hyperdomMeta(this.model);
meta.widgets.delete(this);
if (self.model.onremove) {
this.currentRender.finished.then(function () {
self.model.onremove(element);
});
}
this.component.destroy();
};
module.exports = ViewModel;
},{".":"hyperdom","./domComponent":4,"./meta":6}],43:[function(require,module,exports){
var domComponent = require('./domComponent');
var rendering = require('./rendering');
var VText = require("virtual-dom/vnode/vtext.js")
function WindowWidget(attributes) {
this.attributes = attributes;
this.vdom = new VText('');
this.component = domComponent();
var self = this;
this.cache = {};
Object.keys(this.attributes).forEach(function (key) {
self.cache[key] = rendering.html.refreshify(self.attributes[key]);
});
}
WindowWidget.prototype.type = 'Widget';
WindowWidget.prototype.init = function () {
applyPropertyDiffs(window, {}, this.attributes, {}, this.cache);
return this.element = document.createTextNode('');
};
function uniq(array) {
var sortedArray = array.slice();
sortedArray.sort();
var last;
for(var n = 0; n < sortedArray.length;) {
var current = sortedArray[n];
if (last === current) {
sortedArray.splice(n, 1);
} else {
n++;
}
last = current;
}
return sortedArray;
}
function applyPropertyDiffs(element, previous, current, previousCache, currentCache) {
uniq(Object.keys(previous).concat(Object.keys(current))).forEach(function (key) {
if (/^on/.test(key)) {
var event = key.slice(2);
var prev = previous[key];
var curr = current[key];
var refreshPrev = previousCache[key];
var refreshCurr = currentCache[key];
if (prev !== undefined && curr === undefined) {
element.removeEventListener(event, refreshPrev);
} else if (prev !== undefined && curr !== undefined && prev !== curr) {
element.removeEventListener(event, refreshPrev);
element.addEventListener(event, refreshCurr);
} else if (prev === undefined && curr !== undefined) {
element.addEventListener(event, refreshCurr);
}
}
});
}
WindowWidget.prototype.update = function (previous) {
applyPropertyDiffs(window, previous.attributes, this.attributes, previous.cache, this.cache);
this.component = previous.component;
return this.element;
};
WindowWidget.prototype.destroy = function () {
applyPropertyDiffs(window, this.attributes, {}, this.cache, {});
};
module.exports = function (attributes) {
return new WindowWidget(attributes);
};
},{"./domComponent":4,"./rendering":36,"virtual-dom/vnode/vtext.js":32}],"hyperdom":[function(require,module,exports){
if (typeof window === 'object') {
console.log('\n\ncreated with \uD83D\uDE80 using https://github.com/featurist/hyperdom\n\n\n');
}
var rendering = require('./rendering');
var deprecations = require('./deprecations');
exports.html = rendering.html;
exports.jsx = rendering.jsx;
exports.attach = rendering.attach;
exports.replace = rendering.replace;
exports.append = rendering.append;
exports.appendVDom = rendering.appendVDom;
exports.merge = rendering.merge;
exports.binding = rendering.binding;
exports.meta = rendering.html.meta;
exports.refreshify = rendering.html.refreshify;
exports.norefresh = rendering.html.norefresh;
var windowEvents = require('./windowEvents');
exports.html.window = function (attributes) {
deprecations.window('hyperdom.window is deprecated');
return windowEvents(attributes);
};
exports.html.component = require('./component');
exports.currentRender = function () {
return exports._currentRender;
};
},{"./component":2,"./deprecations":3,"./rendering":36,"./windowEvents":43}]},{},[])
//# sourceMappingURL=data:application/json;charset=utf-8;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/browser-resolve/empty.js","component.js","deprecations.js","domComponent.js","isVdom.js","meta.js","mount.js","node_modules/virtual-dom/create-element.js","node_modules/virtual-dom/diff.js","node_modules/virtual-dom/node_modules/browser-split/index.js","node_modules/virtual-dom/node_modules/global/document.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/patch.js","node_modules/virtual-dom/vdom/apply-properties.js","node_modules/virtual-dom/vdom/create-element.js","node_modules/virtual-dom/vdom/dom-index.js","node_modules/virtual-dom/vdom/patch-op.js","node_modules/virtual-dom/vdom/patch.js","node_modules/virtual-dom/vdom/update-widget.js","node_modules/virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js","node_modules/virtual-dom/virtual-hyperscript/parse-tag.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/vnode/vtext.js","node_modules/virtual-dom/vtree/diff-props.js","node_modules/virtual-dom/vtree/diff.js","render.js","rendering.js","runRender.js","set.js","simplePromise.js","toVdom.js","vhtml.js","viewModel.js","windowEvents.js","hyperdom"],"names":[],"mappings":"AAAA;ACAA;;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;;AC1IA;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;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;;ACHA;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;;;;ACfA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;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;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;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;;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;;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;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACroBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":["(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 VText = require(\"virtual-dom/vnode/vtext.js\")\nvar domComponent = require('./domComponent');\nvar hyperdom = require('.');\nvar deprecations = require('./deprecations');\n\nfunction ComponentWidget(state, vdom) {\n  if (!vdom) {\n    throw new Error('hyperdom.html.component([options], vdom) expects a vdom argument');\n  }\n\n  this.state = state;\n  this.key = state.key;\n  var currentRender = hyperdom.currentRender();\n\n  if (typeof vdom === 'function') {\n    this.render = function () {\n      if (currentRender) {\n        currentRender.eventHandlerWrapper = state.on;\n      }\n      return vdom.apply(this.state, arguments);\n    };\n    this.canRefresh = true;\n  } else {\n    vdom = vdom || new VText('');\n    this.render = function () {\n      return vdom;\n    }\n  }\n  this.cacheKey = state.cacheKey;\n  this.component = domComponent();\n\n  var renderFinished = currentRender && currentRender.finished;\n  if (renderFinished) {\n    this.afterRender = function (fn) {\n      renderFinished.then(fn);\n    };\n  } else {\n    this.afterRender = function () {};\n  }\n}\n\nComponentWidget.prototype.type = 'Widget';\n\nComponentWidget.prototype.init = function () {\n  var self = this;\n\n  if (self.state.onbeforeadd) {\n    self.state.onbeforeadd();\n  }\n\n  var vdom = this.render(this);\n  if (vdom instanceof Array) {\n    throw new Error('vdom returned from component cannot be an array');\n  }\n\n  var element = this.component.create(vdom);\n\n  if (self.state.onadd) {\n    this.afterRender(function () {\n      self.state.onadd(element);\n    });\n  }\n\n  if (self.state.detached) {\n    return document.createTextNode('');\n  } else {\n    return element;\n  }\n};\n\nComponentWidget.prototype.update = function (previous) {\n  var self = this;\n\n  var refresh = !this.cacheKey || this.cacheKey !== previous.cacheKey;\n\n  if (refresh) {\n    if (self.state.onupdate) {\n      this.afterRender(function () {\n        self.state.onupdate(self.component.element);\n      });\n    }\n  }\n\n  this.component = previous.component;\n\n  if (previous.state && this.state) {\n    var keys = Object.keys(this.state);\n    for(var n = 0; n < keys.length; n++) {\n      var key = keys[n];\n      previous.state[key] = self.state[key];\n    }\n    this.state = previous.state;\n  }\n\n  if (refresh) {\n    var element = this.component.update(this.render(this));\n\n    if (self.state.detached) {\n      return document.createTextNode('');\n    } else {\n      return element;\n    }\n  }\n};\n\nComponentWidget.prototype.refresh = function () {\n  this.component.update(this.render(this));\n  if (this.state.onupdate) {\n    this.state.onupdate(this.component.element);\n  }\n};\n\nComponentWidget.prototype.rerender = ComponentWidget.prototype.refresh;\n\nComponentWidget.prototype.destroy = function (element) {\n  var self = this;\n\n  if (self.state.onremove) {\n    this.afterRender(function () {\n      self.state.onremove(element);\n    });\n  }\n\n  this.component.destroy();\n};\n\nmodule.exports = function (state, vdom) {\n  deprecations.component('hyperdom.html.component is deprecated, please use ViewModels');\n  if (typeof state === 'function') {\n    return new ComponentWidget({}, state);\n  } else if (state.constructor === Object) {\n    return new ComponentWidget(state, vdom);\n  } else {\n    return new ComponentWidget({}, state);\n  }\n};\n\nmodule.exports.ComponentWidget = ComponentWidget;\n","function deprecationWarning() {\n  var warningIssued = false;\n\n  return function (arg) {\n    if (!warningIssued) {\n      console.warn(arg);\n      warningIssued = true;\n    }\n  };\n}\n\nmodule.exports = {\n  refresh: deprecationWarning(),\n  currentRender: deprecationWarning(),\n  window: deprecationWarning(),\n  component: deprecationWarning(),\n  renderFunction: deprecationWarning(),\n  refreshAfter: deprecationWarning(),\n  norefresh: deprecationWarning()\n};\n","var createElement = require('virtual-dom/create-element');\nvar diff = require('virtual-dom/diff');\nvar patch = require('virtual-dom/patch');\nvar toVdom = require('./toVdom');\nvar isVdom = require('./isVdom');\n\nfunction DomComponent(options) {\n  this.document = options && options.document;\n}\n\nfunction prepareVdom(object) {\n  var vdom = toVdom(object);\n  if (!isVdom(vdom)) {\n    throw new Error('expected render to return vdom');\n  } else {\n    return vdom;\n  }\n}\n\nDomComponent.prototype.create = function (vdom) {\n  this.vdom = prepareVdom(vdom);\n  return this.element = createElement(this.vdom, {document: this.document});\n};\n\nDomComponent.prototype.merge = function (vdom, element) {\n  this.vdom = prepareVdom(vdom);\n  return this.element = element;\n};\n\nDomComponent.prototype.update = function (vdom) {\n  var oldVdom = this.vdom;\n  this.vdom = prepareVdom(vdom);\n  var patches = diff(oldVdom, this.vdom);\n  return this.element = patch(this.element, patches);\n};\n\nDomComponent.prototype.destroy = function (options) {\n  function destroyWidgets(vdom) {\n    if (vdom.type === 'Widget') {\n      vdom.destroy();\n    } else if (vdom.children) {\n      vdom.children.forEach(destroyWidgets);\n    }\n  }\n\n  destroyWidgets(this.vdom);\n\n  if (options && options.removeElement && this.element.parentNode) {\n    this.element.parentNode.removeChild(this.element);\n  }\n};\n\nfunction domComponent(options) {\n  return new DomComponent(options);\n}\n\nmodule.exports = domComponent;\n","var virtualDomVersion = require(\"virtual-dom/vnode/version\")\n\nmodule.exports = function(x) {\n  var type = x.type;\n  if (type == 'VirtualNode' || type == 'VirtualText') {\n    return x.version == virtualDomVersion;\n  } else {\n    return type == 'Widget' || type == 'Thunk';\n  }\n};\n","module.exports = function (model, property) {\n  var hyperdomMeta = model._hyperdomMeta;\n\n  if (!hyperdomMeta) {\n    hyperdomMeta = {};\n    Object.defineProperty(model, '_hyperdomMeta', {value: hyperdomMeta});\n  }\n\n  if (property) {\n    var meta = hyperdomMeta[property];\n\n    if (!meta) {\n      meta = hyperdomMeta[property] = {};\n    }\n\n    return meta;\n  } else {\n    return hyperdomMeta;\n  }\n};\n","var hyperdomMeta = require('./meta');\nvar runRender = require('./runRender');\nvar hyperdom = require('.');\nvar Set = require('./set');\n\nvar lastId = 0;\n\nfunction Mount(model, options) {\n  var win = (options && options.window) || window;\n  this.requestRender = (options && options.requestRender) || win.requestAnimationFrame || win.setTimeout;\n\n  this.model = model;\n\n  this.renderQueued = false;\n  this.mountRenderRequested = false;\n  this.widgetRendersRequested = undefined;\n  this.id = ++lastId;\n  this.mounted = true;\n}\n\nMount.prototype.queueRender = function () {\n  if (!this.renderQueued) {\n    var requestRender = this.requestRender;\n    var self = this;\n\n    requestRender(function () {\n      self.renderQueued = false;\n\n      if (self.mounted) {\n        runRender(self, function () {\n          if (self.mountRenderRequested) {\n            var vdom = self.render();\n            self.component.update(vdom);\n            self.mountRenderRequested = false;\n          } else if (self.widgetRendersRequested && self.widgetRendersRequested.length) {\n            for (var i = 0, l = self.widgetRendersRequested.length; i < l; i++) {\n              var w = self.widgetRendersRequested[i];\n              w.rerender();\n            }\n            self.widgetRendersRequested = undefined;\n          }\n        });\n      }\n    });\n\n    this.renderQueued = true;\n  }\n};\n\nMount.prototype.render = function() {\n  return this.renderViewModel(this.model);\n};\n\nMount.prototype.rerender = function () {\n  this.mountRenderRequested = true;\n  this.queueRender();\n};\n\nMount.prototype.rerenderWidget = function (widget) {\n  if (!this.widgetRendersRequested) {\n    this.widgetRendersRequested = [];\n  }\n\n  this.widgetRendersRequested.push(widget);\n  this.queueRender();\n};\n\nMount.prototype._renderViewModel = function(model) {\n  var self = this;\n\n  model.rerender = function () {\n    self.rerender();\n  };\n  model.rerenderViewModel = function() {\n    var meta = hyperdomMeta(this);\n    meta.widgets.forEach(function (w) {\n      self.rerenderWidget(w);\n    });\n  };\n\n  var meta = hyperdomMeta(model);\n  if (!meta.mount) {\n    meta.mount = this;\n  }\n\n  if (!meta.widgets) {\n    meta.widgets = new Set();\n  }\n\n  if (typeof model.onload == 'function') {\n    if (!meta.loaded) {\n      meta.loaded = true;\n      hyperdom.refreshify(function () { return model.onload(); }, {refresh: 'promise'})();\n    }\n  }\n\n  var vdom = model.render();\n\n  if (vdom instanceof Array) {\n    throw new Error('vdom returned from component cannot be an array');\n  }\n\n  if (vdom && vdom.properties) {\n    vdom.properties._hyperdomViewModel = model;\n  }\n\n  return vdom;\n}\n\nMount.prototype.renderViewModel = function(model) {\n  if (typeof model.renderCacheKey === 'function') {\n    var meta = hyperdomMeta(model);\n    var key = model.renderCacheKey();\n    if (key !== undefined && meta.cacheKey === key && meta.cachedVdom) {\n      return meta.cachedVdom;\n    } else {\n      meta.cacheKey = key;\n      return meta.cachedVdom = this._renderViewModel(model);\n    }\n  } else {\n    return this._renderViewModel(model);\n  }\n};\n\nMount.prototype.detach = function () {\n  this.mounted = false;\n};\n\nMount.prototype.remove = function () {\n  this.component.destroy({removeElement: true});\n  this.mounted = false;\n};\n\nmodule.exports = Mount;\n","var createElement = require(\"./vdom/create-element.js\")\n\nmodule.exports = createElement\n","var diff = require(\"./vtree/diff.js\")\n\nmodule.exports = diff\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","var topLevel = typeof global !== 'undefined' ? global :\n    typeof window !== 'undefined' ? window : {}\nvar minDoc = require('min-document');\n\nif (typeof document !== 'undefined') {\n    module.exports = document;\n} else {\n    var doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'];\n\n    if (!doccy) {\n        doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'] = minDoc;\n    }\n\n    module.exports = doccy;\n}\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","var patch = require(\"./vdom/patch.js\")\n\nmodule.exports = patch\n","var isObject = require(\"is-object\")\nvar isHook = require(\"../vnode/is-vhook.js\")\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, propValue, previous);\n        } else if (isHook(propValue)) {\n            removeProperty(node, propName, propValue, previous)\n            if (propValue.hook) {\n                propValue.hook(node,\n                    propName,\n                    previous ? previous[propName] : undefined)\n            }\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, propValue, previous) {\n    if (previous) {\n        var previousValue = previous[propName]\n\n        if (!isHook(previousValue)) {\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        } else if (previousValue.unhook) {\n            previousValue.unhook(node, propName, propValue)\n        }\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    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 document = require(\"global/document\")\n\nvar applyProperties = require(\"./apply-properties\")\n\nvar isVNode = require(\"../vnode/is-vnode.js\")\nvar isVText = require(\"../vnode/is-vtext.js\")\nvar isWidget = require(\"../vnode/is-widget.js\")\nvar handleThunk = require(\"../vnode/handle-thunk.js\")\n\nmodule.exports = createElement\n\nfunction createElement(vnode, opts) {\n    var doc = opts ? opts.document || document : document\n    var warn = opts ? opts.warn : null\n\n    vnode = handleThunk(vnode).a\n\n    if (isWidget(vnode)) {\n        return vnode.init()\n    } else if (isVText(vnode)) {\n        return doc.createTextNode(vnode.text)\n    } else if (!isVNode(vnode)) {\n        if (warn) {\n            warn(\"Item is not a valid virtual dom node\", vnode)\n        }\n        return null\n    }\n\n    var node = (vnode.namespace === null) ?\n        doc.createElement(vnode.tagName) :\n        doc.createElementNS(vnode.namespace, vnode.tagName)\n\n    var props = vnode.properties\n    applyProperties(node, props)\n\n    var children = vnode.children\n\n    for (var i = 0; i < children.length; i++) {\n        var childNode = createElement(children[i], opts)\n        if (childNode) {\n            node.appendChild(childNode)\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 vChildren = tree.children\n\n        if (vChildren) {\n\n            var childNodes = rootNode.childNodes\n\n            for (var i = 0; i < tree.children.length; i++) {\n                rootIndex += 1\n\n                var vChild = vChildren[i] || noChild\n                var nextIndex = rootIndex + (vChild.count || 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 applyProperties = require(\"./apply-properties\")\n\nvar isWidget = require(\"../vnode/is-widget.js\")\nvar VPatch = require(\"../vnode/vpatch.js\")\n\nvar updateWidget = require(\"./update-widget\")\n\nmodule.exports = applyPatch\n\nfunction applyPatch(vpatch, domNode, renderOptions) {\n    var type = vpatch.type\n    var vNode = vpatch.vNode\n    var patch = vpatch.patch\n\n    switch (type) {\n        case VPatch.REMOVE:\n            return removeNode(domNode, vNode)\n        case VPatch.INSERT:\n            return insertNode(domNode, patch, renderOptions)\n        case VPatch.VTEXT:\n            return stringPatch(domNode, vNode, patch, renderOptions)\n        case VPatch.WIDGET:\n            return widgetPatch(domNode, vNode, patch, renderOptions)\n        case VPatch.VNODE:\n            return vNodePatch(domNode, vNode, patch, renderOptions)\n        case VPatch.ORDER:\n            reorderChildren(domNode, patch)\n            return domNode\n        case VPatch.PROPS:\n            applyProperties(domNode, patch, vNode.properties)\n            return domNode\n        case VPatch.THUNK:\n            return replaceRoot(domNode,\n                renderOptions.patch(domNode, patch, renderOptions))\n        default:\n            return domNode\n    }\n}\n\nfunction removeNode(domNode, vNode) {\n    var parentNode = domNode.parentNode\n\n    if (parentNode) {\n        parentNode.removeChild(domNode)\n    }\n\n    destroyWidget(domNode, vNode);\n\n    return null\n}\n\nfunction insertNode(parentNode, vNode, renderOptions) {\n    var newNode = renderOptions.render(vNode, renderOptions)\n\n    if (parentNode) {\n        parentNode.appendChild(newNode)\n    }\n\n    return parentNode\n}\n\nfunction stringPatch(domNode, leftVNode, vText, renderOptions) {\n    var newNode\n\n    if (domNode.nodeType === 3) {\n        domNode.replaceData(0, domNode.length, vText.text)\n        newNode = domNode\n    } else {\n        var parentNode = domNode.parentNode\n        newNode = renderOptions.render(vText, renderOptions)\n\n        if (parentNode && newNode !== domNode) {\n            parentNode.replaceChild(newNode, domNode)\n        }\n    }\n\n    return newNode\n}\n\nfunction widgetPatch(domNode, leftVNode, widget, renderOptions) {\n    var updating = updateWidget(leftVNode, widget)\n    var newNode\n\n    if (updating) {\n        newNode = widget.update(leftVNode, domNode) || domNode\n    } else {\n        newNode = renderOptions.render(widget, renderOptions)\n    }\n\n    var parentNode = domNode.parentNode\n\n    if (parentNode && newNode !== domNode) {\n        parentNode.replaceChild(newNode, domNode)\n    }\n\n    if (!updating) {\n        destroyWidget(domNode, leftVNode)\n    }\n\n    return newNode\n}\n\nfunction vNodePatch(domNode, leftVNode, vNode, renderOptions) {\n    var parentNode = domNode.parentNode\n    var newNode = renderOptions.render(vNode, renderOptions)\n\n    if (parentNode && newNode !== domNode) {\n        parentNode.replaceChild(newNode, domNode)\n    }\n\n    return newNode\n}\n\nfunction destroyWidget(domNode, w) {\n    if (typeof w.destroy === \"function\" && isWidget(w)) {\n        w.destroy(domNode)\n    }\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 document = require(\"global/document\")\nvar isArray = require(\"x-is-array\")\n\nvar render = require(\"./create-element\")\nvar domIndex = require(\"./dom-index\")\nvar patchOp = require(\"./patch-op\")\nmodule.exports = patch\n\nfunction patch(rootNode, patches, renderOptions) {\n    renderOptions = renderOptions || {}\n    renderOptions.patch = renderOptions.patch && renderOptions.patch !== patch\n        ? renderOptions.patch\n        : patchRecursive\n    renderOptions.render = renderOptions.render || render\n\n    return renderOptions.patch(rootNode, patches, renderOptions)\n}\n\nfunction patchRecursive(rootNode, patches, renderOptions) {\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    var ownerDocument = rootNode.ownerDocument\n\n    if (!renderOptions.document && ownerDocument !== document) {\n        renderOptions.document = ownerDocument\n    }\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            renderOptions)\n    }\n\n    return rootNode\n}\n\nfunction applyPatch(rootNode, domNode, patchList, renderOptions) {\n    if (!domNode) {\n        return rootNode\n    }\n\n    var newNode\n\n    if (isArray(patchList)) {\n        for (var i = 0; i < patchList.length; i++) {\n            newNode = patchOp(patchList[i], domNode, renderOptions)\n\n            if (domNode === rootNode) {\n                rootNode = newNode\n            }\n        }\n    } else {\n        newNode = patchOp(patchList, domNode, renderOptions)\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","var isWidget = require(\"../vnode/is-widget.js\")\n\nmodule.exports = updateWidget\n\nfunction updateWidget(a, b) {\n    if (isWidget(a) && isWidget(b)) {\n        if (\"name\" in a && \"name\" in b) {\n            return a.id === b.id\n        } else {\n            return a.init === b.init\n        }\n    }\n\n    return false\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 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","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 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","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","var simplePromise = require('./simplePromise');\n\nfunction Render(mount) {\n  this.finished = simplePromise();\n  this.mount = mount;\n  this.attachment = mount;\n}\n\nmodule.exports = Render;\n","var h = require('./vhtml');\nvar domComponent = require('./domComponent');\nvar bindingMeta = require('./meta');\nvar toVdom = require('./toVdom');\nvar parseTag = require('virtual-dom/virtual-hyperscript/parse-tag');\nvar ViewModel = require('./viewModel');\nvar Mount = require('./mount');\nvar runRender = require('./runRender');\nvar deprecations = require('./deprecations');\nvar hyperdom = require('.');\n\nfunction isViewModelOrComponent(component) {\n  return component\n    && ((typeof component.init === 'function'\n       && typeof component.update === 'function'\n       && typeof component.destroy === 'function') || (typeof component.renderViewModel === 'function'));\n}\n\nexports.merge = function (element, render, model, options) {\n  var mount = startAttachment(render, model, options, function(mount, domComponentOptions) {\n    var component = domComponent(domComponentOptions);\n    var currentRender = hyperdom.currentRender;\n    currentRender.eventHandlerWrapper = function() {\n      return null;\n    };\n    var vdom = mount.render();\n    component.merge(vdom, element);\n    return component;\n  });\n\n  mount.rerender();\n\n  return mount;\n};\n\nexports.append = function (element, render, model, options) {\n  return startAttachment(render, model, options, function(mount, domComponentOptions) {\n    var component = domComponent(domComponentOptions);\n    var vdom = mount.render();\n    element.appendChild(component.create(vdom));\n    return component;\n  });\n};\n\nexports.replace = function (element, render, model, options) {\n  return startAttachment(render, model, options, function(mount, domComponentOptions) {\n    var component = domComponent(domComponentOptions);\n    var vdom = mount.render();\n    element.parentNode.replaceChild(component.create(vdom), element);\n    return component;\n  });\n};\n\nexports.appendVDom = function (vdom, render, model, options) {\n  return startAttachment(render, model, options, function(mount) {\n    var component = {\n      create: function(newVDom) {\n        vdom.children = [];\n        if (newVDom) {\n          vdom.children.push(newVDom);\n        }\n      },\n      update: function(newVDom) {\n        vdom.children = [];\n        if (newVDom) {\n          vdom.children.push(newVDom);\n        }\n      }\n    };\n    component.create(mount.render());\n    return component;\n  });\n};\n\nexports.ViewModel = ViewModel;\n\nfunction startAttachment(render, model, options, attachToDom) {\n  if (typeof render == 'object' && typeof render.render == 'function') {\n    return start(render, attachToDom, model);\n  } else {\n    deprecations.renderFunction('hyperdom.append and hyperdom.replace with render functions are deprecated, please pass a ViewModel');\n    return start({render: function () { return render(model); }}, attachToDom, options);\n  }\n}\n\nfunction start(model, attachToDom, options) {\n  var mount = new Mount(model, options);\n  runRender(mount, function () {\n    if (options) {\n      var domComponentOptions = {document: options.document};\n    }\n    mount.component = attachToDom(mount, domComponentOptions);\n  });\n  return mount;\n}\n\nvar norefresh = {};\n\nfunction norefreshFunction() {\n  return norefresh;\n}\n\nfunction refreshify(fn, options) {\n  if (!fn) {\n    return fn;\n  }\n\n  var currentRender = hyperdom.currentRender();\n\n  if (!currentRender) {\n    if (typeof global === 'object') {\n      return fn;\n    } else {\n      throw new Error('You cannot create virtual-dom event handlers outside a render function. See https://github.com/featurist/hyperdom#outside-render-cycle');\n    }\n  }\n\n  var mount = currentRender.mount;\n  var handleEventResult = exports.createEventResultHandler(mount, options);\n\n  if (options && (options.norefresh == true || options.refresh == false)) {\n    return fn;\n  }\n\n  return function () {\n    var result = fn.apply(this, arguments);\n    return handleEventResult(result);\n  };\n}\n\nexports.createEventResultHandler = function(mount, options) {\n  var onlyRefreshAfterPromise = options && options.refresh == 'promise';\n  var viewModelToRefresh = options && options.viewModel;\n  var componentToRefresh = options && options.component;\n\n  function handleEventResult(result, promiseResult) {\n    if (result && typeof(result.then) == 'function') {\n      result.then(function (result) { handleEventResult(result, true); });\n    }\n\n    if (onlyRefreshAfterPromise && !promiseResult) {\n      return;\n    }\n\n    if (isViewModelOrComponent(result)) {\n      mount.rerenderWidget(result);\n    } else if (result instanceof Array) {\n      for (var i = 0; i < result.length; i++) {\n        handleEventResult(result[i]);\n      }\n    } else if (viewModelToRefresh) {\n      viewModelToRefresh.rerenderViewModel();\n    } else if (componentToRefresh) {\n      componentToRefresh.refresh();\n    } else if (result === norefresh) {\n      // don't refresh;\n    } else if (result === norefreshFunction) {\n      deprecations.norefresh('hyperdom.html.norefresh is deprecated, please use hyperdom.norefresh()');\n      // don't refresh;\n    } else {\n      mount.rerender();\n      return result;\n    }\n  }\n\n  return handleEventResult;\n};\n\nfunction bindTextInput(attributes, children, get, set) {\n  var textEventNames = ['onkeyup', 'oninput', 'onpaste', 'textInput'];\n\n  var bindingValue = get();\n  if (!(bindingValue instanceof Error)) {\n    attributes.value = bindingValue != undefined? bindingValue: '';\n  }\n\n  attachEventHandler(attributes, textEventNames, function (ev) {\n    if (bindingValue != ev.target.value) {\n      set(ev.target.value);\n    }\n  });\n}\n\nfunction sequenceFunctions(handler1, handler2) {\n  return function (ev) {\n    handler1(ev);\n    return handler2(ev);\n  };\n}\n\nfunction insertEventHandler(attributes, eventName, handler) {\n  var previousHandler = attributes[eventName];\n  if (previousHandler) {\n    attributes[eventName] = sequenceFunctions(handler, previousHandler);\n  } else {\n    attributes[eventName] = handler;\n  }\n}\n\nfunction attachEventHandler(attributes, eventNames, handler) {\n  if (eventNames instanceof Array) {\n    for (var n = 0; n < eventNames.length; n++) {\n      insertEventHandler(attributes, eventNames[n], handler);\n    }\n  } else {\n    insertEventHandler(attributes, eventNames, handler);\n  }\n}\n\nfunction ListenerHook(listener) {\n  this.listener = exports.html.refreshify(listener);\n}\n\nListenerHook.prototype.hook = function (element, propertyName) {\n  element.addEventListener(propertyName.substring(2), this.listener, false);\n};\n\nListenerHook.prototype.unhook = function (element, propertyName) {\n  element.removeEventListener(propertyName.substring(2), this.listener);\n};\n\nfunction customEvent(name) {\n  if (typeof Event == 'function') {\n    return new Event(name);\n  } else {\n    var event = document.createEvent('Event');\n    event.initEvent(name, false, false);\n    return event;\n  }\n}\n\nvar inputTypeBindings = {\n  text: bindTextInput,\n\n  textarea: bindTextInput,\n\n  checkbox: function (attributes, children, get, set) {\n    attributes.checked = get();\n\n    attachEventHandler(attributes, 'onclick', function (ev) {\n      attributes.checked = ev.target.checked;\n      set(ev.target.checked);\n    });\n  },\n\n  radio: function (attributes, children, get, set) {\n    var value = attributes.value;\n    attributes.checked = get() == attributes.value;\n    attributes.on_hyperdomsyncchecked = new ListenerHook(function (event) {\n      attributes.checked = event.target.checked;\n    });\n\n    attachEventHandler(attributes, 'onclick', function (event) {\n      var name = event.target.name;\n      if (name) {\n        var inputs = document.getElementsByName(name);\n        for (var i = 0, l = inputs.length; i < l; i++) {\n          inputs[i].dispatchEvent(customEvent('_hyperdomsyncchecked'));\n        }\n      }\n      set(value);\n    });\n  },\n\n  select: function (attributes, children, get, set) {\n    var currentValue = get();\n\n    var options = children.filter(function (child) {\n      return child.tagName.toLowerCase() == 'option';\n    });\n\n    var values = [];\n    var selectedIndex;\n\n    for(var n = 0; n < options.length; n++) {\n      var option = options[n];\n      var hasValue = option.properties.hasOwnProperty('value');\n      var value = option.properties.value;\n      var text = option.children.map(function (x) { return x.text; }).join('');\n\n      values.push(hasValue? value: text);\n\n      var selected = value == currentValue || text == currentValue;\n\n      if (selected) {\n        selectedIndex = n;\n      }\n\n      option.properties.selected = selected;\n      option.properties.value = n;\n    }\n\n    if (selectedIndex !== undefined) {\n      attributes.selectedIndex = selectedIndex;\n    }\n\n    attachEventHandler(attributes, 'onchange', function (ev) {\n      attributes.selectedIndex = ev.target.selectedIndex;\n      set(values[ev.target.value]);\n    });\n  },\n\n  file: function (attributes, children, get, set) {\n    var multiple = attributes.multiple;\n\n    attachEventHandler(attributes, 'onchange', function (ev) {\n      if (multiple) {\n        set(ev.target.files);\n      } else {\n        set(ev.target.files[0]);\n      }\n    });\n  }\n};\n\nfunction bindModel(attributes, children, type) {\n  var bind = inputTypeBindings[type] || bindTextInput;\n\n  var bindingAttr = makeBinding(attributes.binding);\n  bind(attributes, children, bindingAttr.get, bindingAttr.set);\n}\n\nfunction inputType(selector, attributes) {\n  if (/^textarea\\b/i.test(selector)) {\n    return 'textarea';\n  } else if (/^select\\b/i.test(selector)) {\n    return 'select';\n  } else {\n    return attributes.type || 'text';\n  }\n}\n\nvar renames = {\n  for: 'htmlFor',\n  class: 'className',\n  contenteditable: 'contentEditable',\n  tabindex: 'tabIndex',\n  colspan: 'colSpan'\n};\n\nvar dataAttributeRegex = /^data-/;\n\nfunction prepareAttributes(tag, attributes, childElements) {\n  var keys = Object.keys(attributes);\n  var dataset;\n  var currentRender = hyperdom.currentRender();\n  var eventHandlerWrapper = currentRender && currentRender.eventHandlerWrapper;\n\n  for (var k = 0; k < keys.length; k++) {\n    var key = keys[k];\n    var attribute = attributes[key];\n\n    if (typeof(attribute) == 'function') {\n      if (eventHandlerWrapper) {\n        var fn = eventHandlerWrapper.call(undefined, key.replace(/^on/, ''), attribute);\n        attributes[key] = typeof fn === 'function'? refreshify(fn): fn;\n      } else {\n        attributes[key] = refreshify(attribute);\n      }\n    }\n\n    var rename = renames[key];\n    if (rename) {\n      attributes[rename] = attribute;\n      delete attributes[key];\n      continue;\n    }\n\n    if (dataAttributeRegex.test(key)) {\n      if (!dataset) {\n        dataset = attributes.dataset;\n\n        if (!dataset) {\n          dataset = attributes.dataset = {};\n        }\n      }\n\n      var datakey = key\n        .replace(dataAttributeRegex, '')\n        .replace(/-([a-z])/ig, function(_, x) { return x.toUpperCase(); });\n\n      dataset[datakey] = attribute;\n      delete attributes[key];\n      continue;\n    }\n  }\n\n  if (attributes.className) {\n    attributes.className = generateClassName(attributes.className);\n  }\n\n  if (attributes.binding) {\n    bindModel(attributes, childElements, inputType(tag, attributes));\n    delete attributes.binding;\n  }\n}\n\n/**\n * this function is quite ugly and you may be very tempted\n * to refactor it into smaller functions, I certainly am.\n * however, it was written like this for performance\n * so think of that before refactoring! :)\n */\nexports.html = function (hierarchySelector) {\n  var hasHierarchy = hierarchySelector.indexOf(' ') >= 0;\n  var selector, selectorElements;\n\n  if (hasHierarchy) {\n    selectorElements = hierarchySelector.match(/\\S+/g);\n    selector = selectorElements[selectorElements.length - 1];\n  } else {\n    selector = hierarchySelector;\n  }\n\n  var childElements;\n  var vdom;\n  var tag;\n  var attributes = arguments[1];\n\n  if (attributes && attributes.constructor == Object && typeof attributes.render !== 'function') {\n    childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 2));\n    prepareAttributes(selector, attributes, childElements);\n    tag = parseTag(selector, attributes);\n    vdom = h(tag, attributes, childElements);\n  } else {\n    attributes = {};\n    childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 1));\n    tag = parseTag(selector, attributes);\n    vdom = h(tag, attributes, childElements);\n  }\n\n  if (hasHierarchy) {\n    for(var n = selectorElements.length - 2; n >= 0; n--) {\n      vdom = h(selectorElements[n], {}, [vdom]);\n    }\n  }\n\n  return vdom;\n};\n\nexports.jsx = function (tag, attributes) {\n  var childElements = toVdom.recursive(Array.prototype.slice.call(arguments, 2));\n  if (attributes) {\n    prepareAttributes(tag, attributes, childElements);\n  }\n  return h(tag, attributes || {}, childElements);\n};\n\nObject.defineProperty(exports.html, 'currentRender', {get: function () {\n  deprecations.currentRender('hyperdom.html.currentRender is deprecated, please use hyperdom.currentRender() instead');\n  return exports.html._currentRender;\n}});\n\nObject.defineProperty(exports.html, 'refresh', {get: function () {\n  deprecations.refresh('hyperdom.html.refresh is deprecated, please use viewModel.rerender() instead');\n  return exports.html._refresh;\n}});\n\nfunction refreshAfter(promise) {\n  deprecations.refreshAfter('hyperdom.html.refreshAfter is deprecated');\n  var refresh = exports.html.refresh;\n\n  promise.then(refresh);\n}\n\nexports.html.refreshify = refreshify;\nexports.html.refreshAfter = refreshAfter;\nexports.html.norefresh = norefresh;\n\nfunction makeBinding(b, options) {\n  var binding = b instanceof Array\n    ?  bindingObject.apply(undefined, b)\n    : b;\n\n  binding.set = refreshify(binding.set, options);\n\n  return binding;\n}\n\nfunction makeConverter(converter) {\n  if (typeof converter == 'function') {\n    return {\n      view: function (model) {\n        return model;\n      },\n      model: function (view) {\n        return converter(view);\n      }\n    };\n  } else {\n    return converter;\n  }\n}\n\nfunction chainConverters(startIndex, converters) {\n  function makeConverters() {\n    if (!_converters) {\n      _converters = new Array(converters.length - startIndex);\n\n      for(var n = startIndex; n < converters.length; n++) {\n        _converters[n - startIndex] = makeConverter(converters[n]);\n      }\n    }\n  }\n\n  if ((converters.length - startIndex) == 1) {\n    return makeConverter(converters[startIndex]);\n  } else {\n    var _converters;\n    return {\n      view: function (model) {\n        makeConverters();\n        var intermediateValue = model;\n        for(var n = 0; n < _converters.length; n++) {\n          intermediateValue = _converters[n].view(intermediateValue);\n        }\n        return intermediateValue;\n      },\n\n      model: function (view) {\n        makeConverters();\n        var intermediateValue = view;\n        for(var n = _converters.length - 1; n >= 0; n--) {\n          intermediateValue = _converters[n].model(intermediateValue);\n        }\n        return intermediateValue;\n      }\n    };\n  }\n}\n\nfunction bindingObject(model, property) {\n  var _meta;\n  function hyperdomMeta() {\n    return _meta || (_meta = bindingMeta(model, property));\n  }\n\n  if (arguments.length > 2) {\n    var converter = chainConverters(2, arguments);\n\n    return {\n      get: function() {\n        var meta = hyperdomMeta();\n        var modelValue = model[property];\n        var modelText;\n\n        if (meta.error) {\n          return meta.view;\n        } else if (meta.view === undefined) {\n          modelText = converter.view(modelValue);\n          meta.view = modelText;\n          return modelText;\n        } else {\n          var previousValue = converter.model(meta.view);\n          modelText = converter.view(modelValue);\n          var normalisedPreviousText = converter.view(previousValue);\n\n          if (modelText === normalisedPreviousText) {\n            return meta.view;\n          } else {\n            meta.view = modelText;\n            return modelText;\n          }\n        }\n      },\n\n      set: function(view) {\n        var meta = hyperdomMeta();\n        meta.view = view;\n\n        try {\n          model[property] = converter.model(view, model[property]);\n          delete meta.error;\n        } catch (e) {\n          meta.error = e;\n        }\n      },\n\n      meta: function() {\n        return hyperdomMeta();\n      }\n    };\n  } else {\n    return {\n      get: function () {\n        return model[property];\n      },\n\n      set: function (value) {\n        model[property] = value;\n      },\n\n      meta: function() {\n        return hyperdomMeta();\n      }\n    };\n  }\n}\n\nexports.binding = makeBinding;\nexports.html.binding = makeBinding;\nexports.html.meta = bindingMeta;\n\nfunction rawHtml() {\n  var selector;\n  var html;\n  var options;\n\n  if (arguments.length == 2) {\n    selector = arguments[0];\n    html = arguments[1];\n    options = {innerHTML: html};\n    return exports.html(selector, options);\n  } else {\n    selector = arguments[0];\n    options = arguments[1];\n    html = arguments[2];\n    options.innerHTML = html;\n    return exports.html(selector, options);\n  }\n}\n\nexports.html.rawHtml = rawHtml;\n\n\nfunction generateConditionalClassNames(obj) {\n  return Object.keys(obj).filter(function (key) {\n    return obj[key];\n  }).join(' ') || undefined;\n}\n\nfunction generateClassName(obj) {\n  if (typeof(obj) == 'object') {\n    if (obj instanceof Array) {\n      var names = obj.map(function(item) {\n        return generateClassName(item);\n      });\n      return names.join(' ') || undefined;\n    } else {\n      return generateConditionalClassNames(obj);\n    }\n  } else {\n    return obj;\n  }\n}\n","var hyperdom = require('.');\nvar Render = require('./render');\nvar rendering = require('./rendering');\n\nfunction refreshOutOfRender() {\n  throw new Error('Please assign hyperdom.html.refresh during a render cycle if you want to use it in event handlers. See https://github.com/featurist/hyperdom#refresh-outside-render-cycle');\n}\n\nmodule.exports = function(mount, fn) {\n  var render = new Render(mount);\n\n  try {\n    hyperdom._currentRender = render;\n\n    rendering.html._currentRender = render;\n    rendering.html._refresh = rendering.createEventResultHandler(mount);\n\n    fn();\n  } finally {\n    render.finished.fulfill();\n    hyperdom._currentRender = undefined;\n\n    rendering.html._refresh = refreshOutOfRender;\n    rendering.html._currentRender = undefined;\n  }\n};\n","if (typeof Set === 'function') {\n  module.exports = Set;\n} else {\n  module.exports = function() {\n    this.items = [];\n  };\n\n  module.exports.prototype.add = function(widget) {\n    if (this.items.indexOf(widget) == -1) {\n      this.items.push(widget);\n    }\n  };\n\n  module.exports.prototype.delete = function(widget) {\n    var i = this.items.indexOf(widget);\n    if (i !== -1) {\n      this.items.splice(i, 1);\n    }\n  };\n\n  module.exports.prototype.forEach = function(fn) {\n    for(var n = 0; n < this.items.length; n++) {\n      fn(this.items[n]);\n    }\n  };\n}\n","function SimplePromise () {\n  this.listeners = [];\n}\n\nSimplePromise.prototype.fulfill = function (value) {\n  if (!this.isFulfilled) {\n    this.isFulfilled = true;\n    this.value = value;\n    this.listeners.forEach(function (listener) {\n      listener();\n    });\n  }\n};\n\nSimplePromise.prototype.then = function (success) {\n  if (this.isFulfilled) {\n    var self = this;\n    setTimeout(function () {\n      success(self.value);\n    });\n  } else {\n    this.listeners.push(success);\n  }\n};\n\nmodule.exports = function () {\n  return new SimplePromise();\n};\n","var vtext = require(\"virtual-dom/vnode/vtext.js\")\nvar rendering = require('./rendering');\nvar isVdom = require('./isVdom');\n\nfunction toVdom(object) {\n  if (object === undefined || object === null) {\n    return new vtext('');\n  } else if (typeof(object) != 'object') {\n    return new vtext(String(object));\n  } else if (object instanceof Date) {\n    return new vtext(String(object));\n  } else if (object instanceof Error) {\n    return new vtext(object.toString());\n  } else if (isVdom(object)) {\n    return object;\n  } else if (typeof object.render === 'function') {\n    return new rendering.ViewModel(object);\n  } else {\n    return new vtext(JSON.stringify(object));\n  }\n}\n\nmodule.exports = toVdom;\n\nfunction addChild(children, child) {\n  if (child instanceof Array) {\n    for (var n = 0; n < child.length; n++) {\n      addChild(children, child[n]);\n    }\n  } else {\n    children.push(toVdom(child));\n  }\n}\n\nmodule.exports.recursive = function (child) {\n  var children = [];\n  addChild(children, child);\n  return children;\n};\n","'use strict';\n\nvar VNode = require('virtual-dom/vnode/vnode.js');\nvar isHook = require('virtual-dom/vnode/is-vhook');\n\nvar softSetHook = require('virtual-dom/virtual-hyperscript/hooks/soft-set-hook.js');\n\nmodule.exports = h;\n\nfunction h(tagName, props, children) {\n  var tag = tagName;\n\n  // support keys\n  if (props.hasOwnProperty('key')) {\n    var key = props.key;\n    props.key = undefined;\n  }\n\n  // support namespace\n  if (props.hasOwnProperty('namespace')) {\n    var namespace = props.namespace;\n    props.namespace = undefined;\n  }\n\n  // fix cursor bug\n  if (tag.toLowerCase() === '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  return new VNode(tag, props, children, key, namespace);\n}\n","var domComponent = require('./domComponent');\nvar hyperdomMeta = require('./meta');\nvar hyperdom = require('.');\n\nfunction ViewModel(model) {\n  var currentRender = hyperdom.currentRender();\n\n  this.currentRender = currentRender;\n  this.model = model;\n  this.key = model.renderKey;\n  this.component = undefined;\n  this.mount = currentRender.mount;\n}\n\nViewModel.prototype.type = 'Widget';\n\nViewModel.prototype.init = function () {\n  var self = this;\n\n  var vdom = this.render();\n\n  var meta = hyperdomMeta(this.model);\n  meta.widgets.add(this);\n\n  this.component = domComponent();\n  var element = this.component.create(vdom);\n\n  if (self.model.onadd) {\n    this.currentRender.finished.then(function () {\n      self.model.onadd(element);\n    });\n  }\n\n  if (self.model.detached) {\n    return document.createTextNode('');\n  } else {\n    return element;\n  }\n};\n\nViewModel.prototype.update = function (previous) {\n  var self = this;\n\n  if (self.model.onupdate) {\n    this.currentRender.finished.then(function () {\n      self.model.onupdate(self.component.element);\n    });\n  }\n\n  this.component = previous.component;\n\n  var element = this.component.update(this.render());\n\n  if (self.model.detached) {\n    return document.createTextNode('');\n  } else {\n    return element;\n  }\n};\n\nViewModel.prototype.render = function () {\n  return this.mount.renderViewModel(this.model);\n};\n\nViewModel.prototype.rerender = function () {\n  this.component.update(this.render());\n  if (this.model.onupdate) {\n    this.model.onupdate(this.component.element);\n  }\n};\n\nViewModel.prototype.destroy = function (element) {\n  var self = this;\n\n  var meta = hyperdomMeta(this.model);\n  meta.widgets.delete(this);\n\n  if (self.model.onremove) {\n    this.currentRender.finished.then(function () {\n      self.model.onremove(element);\n    });\n  }\n\n  this.component.destroy();\n};\n\nmodule.exports = ViewModel;\n","var domComponent = require('./domComponent');\nvar rendering = require('./rendering');\nvar VText = require(\"virtual-dom/vnode/vtext.js\")\n\nfunction WindowWidget(attributes) {\n  this.attributes = attributes;\n  this.vdom = new VText('');\n  this.component = domComponent();\n\n  var self = this;\n  this.cache = {};\n  Object.keys(this.attributes).forEach(function (key) {\n    self.cache[key] = rendering.html.refreshify(self.attributes[key]);\n  });\n}\n\nWindowWidget.prototype.type = 'Widget';\n\nWindowWidget.prototype.init = function () {\n  applyPropertyDiffs(window, {}, this.attributes, {}, this.cache);\n  return this.element = document.createTextNode('');\n};\n\nfunction uniq(array) {\n  var sortedArray = array.slice();\n  sortedArray.sort();\n\n  var last;\n\n  for(var n = 0; n < sortedArray.length;) {\n    var current = sortedArray[n];\n\n    if (last === current) {\n      sortedArray.splice(n, 1);\n    } else {\n      n++;\n    }\n    last = current;\n  }\n\n  return sortedArray;\n}\n\nfunction applyPropertyDiffs(element, previous, current, previousCache, currentCache) {\n  uniq(Object.keys(previous).concat(Object.keys(current))).forEach(function (key) {\n    if (/^on/.test(key)) {\n      var event = key.slice(2);\n\n      var prev = previous[key];\n      var curr = current[key];\n      var refreshPrev = previousCache[key];\n      var refreshCurr = currentCache[key];\n\n      if (prev !== undefined && curr === undefined) {\n        element.removeEventListener(event, refreshPrev);\n      } else if (prev !== undefined && curr !== undefined && prev !== curr) {\n        element.removeEventListener(event, refreshPrev);\n        element.addEventListener(event, refreshCurr);\n      } else if (prev === undefined && curr !== undefined) {\n        element.addEventListener(event, refreshCurr);\n      }\n    }\n  });\n}\n\nWindowWidget.prototype.update = function (previous) {\n  applyPropertyDiffs(window, previous.attributes, this.attributes, previous.cache, this.cache);\n  this.component = previous.component;\n  return this.element;\n};\n\nWindowWidget.prototype.destroy = function () {\n  applyPropertyDiffs(window, this.attributes, {}, this.cache, {});\n};\n\nmodule.exports = function (attributes) {\n  return new WindowWidget(attributes);\n};\n","if (typeof window === 'object') {\n  console.log('\\n\\ncreated with \\uD83D\\uDE80 using https://github.com/featurist/hyperdom\\n\\n\\n');\n}\n\nvar rendering = require('./rendering');\nvar deprecations = require('./deprecations');\n\nexports.html = rendering.html;\nexports.jsx = rendering.jsx;\nexports.attach = rendering.attach;\nexports.replace = rendering.replace;\nexports.append = rendering.append;\nexports.appendVDom = rendering.appendVDom;\nexports.merge = rendering.merge;\nexports.binding = rendering.binding;\nexports.meta = rendering.html.meta;\nexports.refreshify = rendering.html.refreshify;\nexports.norefresh = rendering.html.norefresh;\n\nvar windowEvents = require('./windowEvents');\n\nexports.html.window = function (attributes) {\n  deprecations.window('hyperdom.window is deprecated');\n  return windowEvents(attributes);\n};\n\nexports.html.component = require('./component');\n\nexports.currentRender = function () {\n  return exports._currentRender;\n};\n"]}
var hyperdom = require('hyperdom')
var h = hyperdom.html
class App {
render() {
return h('.container',
h('#example',
h('div.foo div', h('input[type=submit]'))
),
h.component({
onadd: function(pre) {
pre.innerText = document.querySelector('#example').innerHTML
}
}, h('pre'))
)
}
}
hyperdom.append(document.body, new App())
;}, 0)
{
"name": "requirebin-sketch",
"version": "1.0.0",
"dependencies": {
"hyperdom": "0.2.0"
}
}
<!-- contents of this file will be placed inside the <body> -->
<!-- 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