| /******/ (function(modules) { // webpackBootstrap |
| /******/ // The module cache |
| /******/ var installedModules = {}; |
| |
| /******/ // The require function |
| /******/ function __webpack_require__(moduleId) { |
| |
| /******/ // Check if module is in cache |
| /******/ if(installedModules[moduleId]) |
| /******/ return installedModules[moduleId].exports; |
| |
| /******/ // Create a new module (and put it into the cache) |
| /******/ var module = installedModules[moduleId] = { |
| /******/ exports: {}, |
| /******/ id: moduleId, |
| /******/ loaded: false |
| /******/ }; |
| |
| /******/ // Execute the module function |
| /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); |
| |
| /******/ // Flag the module as loaded |
| /******/ module.loaded = true; |
| |
| /******/ // Return the exports of the module |
| /******/ return module.exports; |
| /******/ } |
| |
| |
| /******/ // expose the modules object (__webpack_modules__) |
| /******/ __webpack_require__.m = modules; |
| |
| /******/ // expose the module cache |
| /******/ __webpack_require__.c = installedModules; |
| |
| /******/ // __webpack_public_path__ |
| /******/ __webpack_require__.p = "dist"; |
| |
| /******/ // Load entry module and return exports |
| /******/ return __webpack_require__(0); |
| /******/ }) |
| /************************************************************************/ |
| /******/ ([ |
| /* 0 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict'; |
| |
| var _inferno = __webpack_require__(1); |
| |
| var _inferno2 = _interopRequireDefault(_inferno); |
| |
| var _infernoComponent = __webpack_require__(3); |
| |
| var _infernoComponent2 = _interopRequireDefault(_infernoComponent); |
| |
| var _share = __webpack_require__(5); |
| |
| var _base = __webpack_require__(6); |
| |
| var _model = __webpack_require__(7); |
| |
| var _model2 = _interopRequireDefault(_model); |
| |
| var _item = __webpack_require__(8); |
| |
| var _item2 = _interopRequireDefault(_item); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
| |
| function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
| |
| function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } |
| |
| function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } |
| |
| var render = _inferno2.default.render; |
| |
| var model = new _model2.default(); |
| |
| var App = function (_Component) { |
| _inherits(App, _Component); |
| |
| function App() { |
| var _temp, _this, _ret; |
| |
| _classCallCheck(this, App); |
| |
| for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { |
| args[_key] = arguments[_key]; |
| } |
| |
| return _ret = (_temp = (_this = _possibleConstructorReturn(this, _Component.call.apply(_Component, [this].concat(args))), _this), _this.state = { |
| route: (0, _share.read)(), |
| todos: model.get() |
| }, _this.update = function (arr) { |
| return _this.setState({ todos: arr }); |
| }, _this.componentWillMount = function () { |
| window.onhashchange = function () { |
| return _this.setState({ route: (0, _share.read)() }); |
| }; |
| }, _this.add = function (e) { |
| if (e.which !== _share.ENTER) return; |
| |
| var val = e.target.value.trim(); |
| if (!val) return; |
| |
| e.target.value = ''; |
| _this.update(model.add(val)); |
| }, _this.edit = function (todo, val) { |
| val = val.trim(); |
| if (val.length) { |
| _this.update(model.put(todo, { title: val, editing: 0 })); |
| } else { |
| _this.remove(todo); |
| } |
| }, _this.focus = function (todo) { |
| return _this.update(model.put(todo, { editing: 1 })); |
| }, _this.blur = function (todo) { |
| return _this.update(model.put(todo, { editing: 0 })); |
| }, _this.remove = function (todo) { |
| return _this.update(model.del(todo)); |
| }, _this.toggleOne = function (todo) { |
| return _this.update(model.toggle(todo)); |
| }, _this.toggleAll = function (ev) { |
| return _this.update(model.toggleAll(ev.target.checked)); |
| }, _this.clearCompleted = function () { |
| return _this.update(model.clearCompleted()); |
| }, _temp), _possibleConstructorReturn(_this, _ret); |
| } |
| |
| App.prototype.render = function render(_, _ref) { |
| var _this2 = this; |
| |
| var todos = _ref.todos, |
| route = _ref.route; |
| |
| var num = todos.length; |
| var shown = todos.filter(_share.filters[route]); |
| var numDone = todos.filter(_share.filters.completed).length; |
| var numAct = num - numDone; |
| |
| return _inferno2.default.createVNode(2, 'div', null, [_inferno2.default.createVNode(16, _base.Head, { |
| 'onEnter': this.add |
| }), num ? _inferno2.default.createVNode(2, 'section', { |
| 'className': 'main' |
| }, [_inferno2.default.createVNode(512, 'input', { |
| 'className': 'toggle-all', |
| 'type': 'checkbox', |
| 'checked': numAct === 0 |
| }, null, { |
| 'onClick': this.toggleAll |
| }), _inferno2.default.createVNode(2, 'ul', { |
| 'className': 'todo-list' |
| }, shown.map(function (t) { |
| return _inferno2.default.createVNode(16, _item2.default, { |
| 'data': t, |
| 'onBlur': function onBlur() { |
| return _this2.blur(t); |
| }, |
| 'onFocus': function onFocus() { |
| return _this2.focus(t); |
| }, |
| 'doDelete': function doDelete() { |
| return _this2.remove(t); |
| }, |
| 'doSave': function doSave(val) { |
| return _this2.edit(t, val); |
| }, |
| 'doToggle': function doToggle() { |
| return _this2.toggleOne(t); |
| } |
| }); |
| }))]) : null, numAct || numDone ? _inferno2.default.createVNode(16, _base.Foot, { |
| 'onClear': this.clearCompleted, |
| 'left': numAct, |
| 'done': numDone, |
| 'route': route |
| }) : null]); |
| }; |
| |
| return App; |
| }(_infernoComponent2.default); |
| |
| render(_inferno2.default.createVNode(16, App), document.getElementById('app')); |
| |
| /***/ }, |
| /* 1 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| module.exports = __webpack_require__(2); |
| |
| |
| /***/ }, |
| /* 2 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /*! |
| * inferno v1.0.0-beta32 |
| * (c) 2016 Dominic Gannaway |
| * Released under the MIT License. |
| */ |
| (function (global, factory) { |
| true ? factory(exports) : |
| typeof define === 'function' && define.amd ? define(['exports'], factory) : |
| (factory((global.Inferno = global.Inferno || {}))); |
| }(this, (function (exports) { 'use strict'; |
| |
| var NO_OP = '$NO_OP'; |
| var ERROR_MSG = 'a runtime error occured! Use Inferno in development environment to find the error.'; |
| var isBrowser = typeof window !== 'undefined' && window.document; |
| |
| // this is MUCH faster than .constructor === Array and instanceof Array |
| // in Node 7 and the later versions of V8, slower in older versions though |
| var isArray = Array.isArray; |
| function isStatefulComponent(o) { |
| return !isUndefined(o.prototype) && !isUndefined(o.prototype.render); |
| } |
| function isStringOrNumber(obj) { |
| return isString(obj) || isNumber(obj); |
| } |
| function isNullOrUndef(obj) { |
| return isUndefined(obj) || isNull(obj); |
| } |
| function isInvalid(obj) { |
| return isNull(obj) || obj === false || isTrue(obj) || isUndefined(obj); |
| } |
| function isFunction(obj) { |
| return typeof obj === 'function'; |
| } |
| function isAttrAnEvent(attr) { |
| return attr[0] === 'o' && attr[1] === 'n' && attr.length > 3; |
| } |
| function isString(obj) { |
| return typeof obj === 'string'; |
| } |
| function isNumber(obj) { |
| return typeof obj === 'number'; |
| } |
| function isNull(obj) { |
| return obj === null; |
| } |
| function isTrue(obj) { |
| return obj === true; |
| } |
| function isUndefined(obj) { |
| return obj === undefined; |
| } |
| function isObject(o) { |
| return typeof o === 'object'; |
| } |
| function throwError(message) { |
| if (!message) { |
| message = ERROR_MSG; |
| } |
| throw new Error(("Inferno Error: " + message)); |
| } |
| function warning(condition, message) { |
| if (!condition) { |
| console.error(message); |
| } |
| } |
| var EMPTY_OBJ = {}; |
| |
| function cloneVNode(vNodeToClone, props) { |
| var _children = [], len = arguments.length - 2; |
| while ( len-- > 0 ) _children[ len ] = arguments[ len + 2 ]; |
| |
| var children = _children; |
| if (_children.length > 0 && !isNull(_children[0])) { |
| if (!props) { |
| props = {}; |
| } |
| if (_children.length === 1) { |
| children = _children[0]; |
| } |
| if (isUndefined(props.children)) { |
| props.children = children; |
| } |
| else { |
| if (isArray(children)) { |
| if (isArray(props.children)) { |
| props.children = props.children.concat(children); |
| } |
| else { |
| props.children = [props.children].concat(children); |
| } |
| } |
| else { |
| if (isArray(props.children)) { |
| props.children.push(children); |
| } |
| else { |
| props.children = [props.children]; |
| props.children.push(children); |
| } |
| } |
| } |
| } |
| children = null; |
| var flags = vNodeToClone.flags; |
| var events = vNodeToClone.events || (props && props.events) || null; |
| var newVNode; |
| if (isArray(vNodeToClone)) { |
| newVNode = vNodeToClone.map(function (vNode) { return cloneVNode(vNode); }); |
| } |
| else if (isNullOrUndef(props) && isNullOrUndef(children)) { |
| newVNode = Object.assign({}, vNodeToClone); |
| } |
| else { |
| var key = !isNullOrUndef(vNodeToClone.key) ? vNodeToClone.key : props.key; |
| var ref = vNodeToClone.ref || props.ref; |
| if (flags & 28 /* Component */) { |
| newVNode = createVNode(flags, vNodeToClone.type, Object.assign({}, vNodeToClone.props, props), null, events, key, ref, true); |
| } |
| else if (flags & 3970 /* Element */) { |
| children = (props && props.children) || vNodeToClone.children; |
| newVNode = createVNode(flags, vNodeToClone.type, Object.assign({}, vNodeToClone.props, props), children, events, key, ref, !children); |
| } |
| } |
| if (flags & 28 /* Component */) { |
| var newProps = newVNode.props; |
| if (newProps) { |
| var newChildren = newProps.children; |
| // we need to also clone component children that are in props |
| // as the children may also have been hoisted |
| if (newChildren) { |
| if (isArray(newChildren)) { |
| for (var i = 0; i < newChildren.length; i++) { |
| var child = newChildren[i]; |
| if (!isInvalid(child) && isVNode(child)) { |
| newProps.children[i] = cloneVNode(child); |
| } |
| } |
| } |
| else if (isVNode(newChildren)) { |
| newProps.children = cloneVNode(newChildren); |
| } |
| } |
| } |
| newVNode.children = null; |
| } |
| newVNode.dom = null; |
| return newVNode; |
| } |
| |
| function _normalizeVNodes(nodes, result, i) { |
| for (; i < nodes.length; i++) { |
| var n = nodes[i]; |
| if (!isInvalid(n)) { |
| if (Array.isArray(n)) { |
| _normalizeVNodes(n, result, 0); |
| } |
| else { |
| if (isStringOrNumber(n)) { |
| n = createTextVNode(n); |
| } |
| else if (isVNode(n) && n.dom) { |
| n = cloneVNode(n); |
| } |
| result.push(n); |
| } |
| } |
| } |
| } |
| function normalizeVNodes(nodes) { |
| var newNodes; |
| // we assign $ which basically means we've flagged this array for future note |
| // if it comes back again, we need to clone it, as people are using it |
| // in an immutable way |
| // tslint:disable |
| if (nodes['$']) { |
| nodes = nodes.slice(); |
| } |
| else { |
| nodes['$'] = true; |
| } |
| // tslint:enable |
| for (var i = 0; i < nodes.length; i++) { |
| var n = nodes[i]; |
| if (isInvalid(n)) { |
| if (!newNodes) { |
| newNodes = nodes.slice(0, i); |
| } |
| newNodes.push(n); |
| } |
| else if (Array.isArray(n)) { |
| var result = (newNodes || nodes).slice(0, i); |
| _normalizeVNodes(nodes, result, i); |
| return result; |
| } |
| else if (isStringOrNumber(n)) { |
| if (!newNodes) { |
| newNodes = nodes.slice(0, i); |
| } |
| newNodes.push(createTextVNode(n)); |
| } |
| else if (isVNode(n) && n.dom) { |
| if (!newNodes) { |
| newNodes = nodes.slice(0, i); |
| } |
| newNodes.push(cloneVNode(n)); |
| } |
| else if (newNodes) { |
| newNodes.push(cloneVNode(n)); |
| } |
| } |
| return newNodes || nodes; |
| } |
| function normalizeChildren(children) { |
| if (isArray(children)) { |
| return normalizeVNodes(children); |
| } |
| else if (isVNode(children) && children.dom) { |
| return cloneVNode(children); |
| } |
| return children; |
| } |
| function normalizeProps(vNode, props, children) { |
| if (!(vNode.flags & 28 /* Component */) && isNullOrUndef(children) && !isNullOrUndef(props.children)) { |
| vNode.children = props.children; |
| } |
| if (props.ref) { |
| vNode.ref = props.ref; |
| } |
| if (props.events) { |
| vNode.events = props.events; |
| } |
| if (!isNullOrUndef(props.key)) { |
| vNode.key = props.key; |
| } |
| } |
| function normalize(vNode) { |
| var props = vNode.props; |
| var children = vNode.children; |
| // convert a wrongly created type back to element |
| if (isString(vNode.type) && (vNode.flags & 28 /* Component */)) { |
| vNode.flags = 3970 /* Element */; |
| } |
| if (props) { |
| normalizeProps(vNode, props, children); |
| } |
| if (!isInvalid(children)) { |
| vNode.children = normalizeChildren(children); |
| } |
| if (props && !isInvalid(props.children)) { |
| props.children = normalizeChildren(props.children); |
| } |
| } |
| function createVNode(flags, type, props, children, events, key, ref, noNormalise) { |
| if (flags & 16 /* ComponentUnknown */) { |
| flags = isStatefulComponent(type) ? 4 /* ComponentClass */ : 8 /* ComponentFunction */; |
| } |
| var vNode = { |
| children: isUndefined(children) ? null : children, |
| dom: null, |
| events: events || null, |
| flags: flags || 0, |
| key: key === undefined ? null : key, |
| props: props || null, |
| ref: ref || null, |
| type: type |
| }; |
| if (!noNormalise) { |
| normalize(vNode); |
| } |
| return vNode; |
| } |
| function createVoidVNode() { |
| return createVNode(4096 /* Void */); |
| } |
| function createTextVNode(text) { |
| return createVNode(1 /* Text */, null, null, text); |
| } |
| function isVNode(o) { |
| return !!o.flags; |
| } |
| |
| var devToolsStatus = { |
| connected: false |
| }; |
| var internalIncrementer = { |
| id: 0 |
| }; |
| var componentIdMap = new Map(); |
| function getIncrementalId() { |
| return internalIncrementer.id++; |
| } |
| function sendToDevTools(global, data) { |
| var event = new CustomEvent('inferno.client.message', { |
| detail: JSON.stringify(data, function (key, val) { |
| if (!isNull(val) && !isUndefined(val)) { |
| if (key === '_vComponent' || !isUndefined(val.nodeType)) { |
| return; |
| } |
| else if (isFunction(val)) { |
| return ("$$f:" + (val.name)); |
| } |
| } |
| return val; |
| }) |
| }); |
| global.dispatchEvent(event); |
| } |
| function rerenderRoots() { |
| for (var i = 0; i < roots.length; i++) { |
| var root = roots[i]; |
| render(root.input, root.dom); |
| } |
| } |
| function initDevToolsHooks(global) { |
| global.__INFERNO_DEVTOOLS_GLOBAL_HOOK__ = roots; |
| global.addEventListener('inferno.devtools.message', function (message) { |
| var detail = JSON.parse(message.detail); |
| var type = detail.type; |
| switch (type) { |
| case 'get-roots': |
| if (!devToolsStatus.connected) { |
| devToolsStatus.connected = true; |
| rerenderRoots(); |
| sendRoots(global); |
| } |
| break; |
| default: |
| // TODO:? |
| break; |
| } |
| }); |
| } |
| function sendRoots(global) { |
| sendToDevTools(global, { type: 'roots', data: roots }); |
| } |
| |
| var Lifecycle = function Lifecycle() { |
| this.listeners = []; |
| this.fastUnmount = true; |
| }; |
| Lifecycle.prototype.addListener = function addListener (callback) { |
| this.listeners.push(callback); |
| }; |
| Lifecycle.prototype.trigger = function trigger () { |
| var this$1 = this; |
| |
| for (var i = 0; i < this.listeners.length; i++) { |
| this$1.listeners[i](); |
| } |
| }; |
| |
| function constructDefaults(string, object, value) { |
| /* eslint no-return-assign: 0 */ |
| string.split(',').forEach(function (i) { return object[i] = value; }); |
| } |
| var xlinkNS = 'http://www.w3.org/1999/xlink'; |
| var xmlNS = 'http://www.w3.org/XML/1998/namespace'; |
| var svgNS = 'http://www.w3.org/2000/svg'; |
| var strictProps = {}; |
| var booleanProps = {}; |
| var namespaces = {}; |
| var isUnitlessNumber = {}; |
| var skipProps = {}; |
| var dehyphenProps = { |
| textAnchor: 'text-anchor' |
| }; |
| var delegatedProps = {}; |
| constructDefaults('xlink:href,xlink:arcrole,xlink:actuate,xlink:role,xlink:titlef,xlink:type', namespaces, xlinkNS); |
| constructDefaults('xml:base,xml:lang,xml:space', namespaces, xmlNS); |
| constructDefaults('volume,defaultValue,defaultChecked', strictProps, true); |
| constructDefaults('children,ref,key,selected,checked,value,multiple', skipProps, true); |
| constructDefaults('onClick,onMouseDown,onMouseUp,onMouseMove', delegatedProps, true); |
| constructDefaults('muted,scoped,loop,open,checked,default,capture,disabled,readonly,required,autoplay,controls,seamless,reversed,allowfullscreen,novalidate', booleanProps, true); |
| constructDefaults('animationIterationCount,borderImageOutset,borderImageSlice,borderImageWidth,boxFlex,boxFlexGroup,boxOrdinalGroup,columnCount,flex,flexGrow,flexPositive,flexShrink,flexNegative,flexOrder,gridRow,gridColumn,fontWeight,lineClamp,lineHeight,opacity,order,orphans,tabSize,widows,zIndex,zoom,fillOpacity,floodOpacity,stopOpacity,strokeDasharray,strokeDashoffset,strokeMiterlimit,strokeOpacity,strokeWidth,', isUnitlessNumber, true); |
| |
| var delegatedEvents = new Map(); |
| function handleEvent(name, lastEvent, nextEvent, dom) { |
| var delegatedRoots = delegatedEvents.get(name); |
| if (nextEvent) { |
| if (!delegatedRoots) { |
| delegatedRoots = { items: new Map(), count: 0, docEvent: null }; |
| var docEvent = attachEventToDocument(name, delegatedRoots); |
| delegatedRoots.docEvent = docEvent; |
| delegatedEvents.set(name, delegatedRoots); |
| } |
| if (!lastEvent) { |
| delegatedRoots.count++; |
| } |
| delegatedRoots.items.set(dom, nextEvent); |
| } |
| else if (delegatedRoots) { |
| if (delegatedRoots.items.has(dom)) { |
| delegatedRoots.count--; |
| delegatedRoots.items.delete(dom); |
| if (delegatedRoots.count === 0) { |
| document.removeEventListener(normalizeEventName(name), delegatedRoots.docEvent); |
| delegatedEvents.delete(name); |
| } |
| } |
| } |
| } |
| function dispatchEvent(event, dom, items, count, eventData) { |
| var eventsToTrigger = items.get(dom); |
| if (eventsToTrigger) { |
| count--; |
| // linkEvent object |
| eventData.dom = dom; |
| if (eventsToTrigger.event) { |
| eventsToTrigger.event(eventsToTrigger.data, event); |
| } |
| else { |
| eventsToTrigger(event); |
| } |
| if (eventData.stopPropagation) { |
| return; |
| } |
| } |
| var parentDom = dom.parentNode; |
| if (count > 0 && (parentDom || parentDom === document.body)) { |
| dispatchEvent(event, parentDom, items, count, eventData); |
| } |
| } |
| function normalizeEventName(name) { |
| return name.substr(2).toLowerCase(); |
| } |
| function attachEventToDocument(name, delegatedRoots) { |
| var docEvent = function (event) { |
| var eventData = { |
| stopPropagation: false, |
| dom: document |
| }; |
| // we have to do this as some browsers recycle the same Event between calls |
| // so we need to make the property configurable |
| Object.defineProperty(event, 'currentTarget', { |
| configurable: true, |
| get: function get() { |
| return eventData.dom; |
| } |
| }); |
| event.stopPropagation = function () { |
| eventData.stopPropagation = true; |
| }; |
| var count = delegatedRoots.count; |
| if (count > 0) { |
| dispatchEvent(event, event.target, delegatedRoots.items, count, eventData); |
| } |
| }; |
| document.addEventListener(normalizeEventName(name), docEvent); |
| return docEvent; |
| } |
| |
| function isCheckedType(type) { |
| return type === 'checkbox' || type === 'radio'; |
| } |
| function isControlled(props) { |
| var usesChecked = isCheckedType(props.type); |
| return usesChecked ? !isNullOrUndef(props.checked) : !isNullOrUndef(props.value); |
| } |
| function onTextInputChange(e) { |
| var vNode = this.vNode; |
| var events = vNode.events || EMPTY_OBJ; |
| var dom = vNode.dom; |
| if (events.onInput) { |
| events.onInput(e); |
| } |
| else if (events.oninput) { |
| events.oninput(e); |
| } |
| // the user may have updated the vNode from the above onInput events |
| // so we need to get it from the context of `this` again |
| applyValue(this.vNode, dom); |
| } |
| function onCheckboxChange(e) { |
| var vNode = this.vNode; |
| var events = vNode.events || EMPTY_OBJ; |
| var dom = vNode.dom; |
| if (events.onClick) { |
| events.onClick(e); |
| } |
| else if (events.onclick) { |
| events.onclick(e); |
| } |
| // the user may have updated the vNode from the above onClick events |
| // so we need to get it from the context of `this` again |
| applyValue(this.vNode, dom); |
| } |
| function handleAssociatedRadioInputs(name) { |
| var inputs = document.querySelectorAll(("input[type=\"radio\"][name=\"" + name + "\"]")); |
| [].forEach.call(inputs, function (dom) { |
| var inputWrapper = wrappers.get(dom); |
| if (inputWrapper) { |
| var props = inputWrapper.vNode.props; |
| if (props) { |
| dom.checked = inputWrapper.vNode.props.checked; |
| } |
| } |
| }); |
| } |
| function processInput(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| applyValue(vNode, dom); |
| if (isControlled(props)) { |
| var inputWrapper = wrappers.get(dom); |
| if (!inputWrapper) { |
| inputWrapper = { |
| vNode: vNode |
| }; |
| if (isCheckedType(props.type)) { |
| dom.onclick = onCheckboxChange.bind(inputWrapper); |
| dom.onclick.wrapped = true; |
| } |
| else { |
| dom.oninput = onTextInputChange.bind(inputWrapper); |
| dom.oninput.wrapped = true; |
| } |
| wrappers.set(dom, inputWrapper); |
| } |
| inputWrapper.vNode = vNode; |
| } |
| } |
| function applyValue(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| var type = props.type; |
| var value = props.value; |
| var checked = props.checked; |
| if (type !== dom.type && type) { |
| dom.type = type; |
| } |
| if (props.multiple !== dom.multiple) { |
| dom.multiple = props.multiple; |
| } |
| if (isCheckedType(type)) { |
| if (!isNullOrUndef(value)) { |
| dom.value = value; |
| } |
| dom.checked = checked; |
| if (type === 'radio' && props.name) { |
| handleAssociatedRadioInputs(props.name); |
| } |
| } |
| else { |
| if (!isNullOrUndef(value) && dom.value !== value) { |
| dom.value = value; |
| } |
| else if (!isNullOrUndef(checked)) { |
| dom.checked = checked; |
| } |
| } |
| } |
| |
| function isControlled$1(props) { |
| return !isNullOrUndef(props.value); |
| } |
| function updateChildOption(vNode, value) { |
| var props = vNode.props || EMPTY_OBJ; |
| var dom = vNode.dom; |
| // we do this as multiple may have changed |
| dom.value = props.value; |
| if ((isArray(value) && value.indexOf(props.value) !== -1) || props.value === value) { |
| dom.selected = true; |
| } |
| else { |
| dom.selected = props.selected || false; |
| } |
| } |
| function onSelectChange(e) { |
| var vNode = this.vNode; |
| var events = vNode.events || EMPTY_OBJ; |
| var dom = vNode.dom; |
| if (events.onChange) { |
| events.onChange(e); |
| } |
| else if (events.onchange) { |
| events.onchange(e); |
| } |
| // the user may have updated the vNode from the above onChange events |
| // so we need to get it from the context of `this` again |
| applyValue$1(this.vNode, dom); |
| } |
| function processSelect(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| applyValue$1(vNode, dom); |
| if (isControlled$1(props)) { |
| var selectWrapper = wrappers.get(dom); |
| if (!selectWrapper) { |
| selectWrapper = { |
| vNode: vNode |
| }; |
| dom.onchange = onSelectChange.bind(selectWrapper); |
| dom.onchange.wrapped = true; |
| wrappers.set(dom, selectWrapper); |
| } |
| selectWrapper.vNode = vNode; |
| } |
| } |
| function applyValue$1(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| if (props.multiple !== dom.multiple) { |
| dom.multiple = props.multiple; |
| } |
| var children = vNode.children; |
| var value = props.value; |
| if (isArray(children)) { |
| for (var i = 0; i < children.length; i++) { |
| updateChildOption(children[i], value); |
| } |
| } |
| else if (isVNode(children)) { |
| updateChildOption(children, value); |
| } |
| } |
| |
| function isControlled$2(props) { |
| return !isNullOrUndef(props.value); |
| } |
| function onTextareaInputChange(e) { |
| var vNode = this.vNode; |
| var events = vNode.events || EMPTY_OBJ; |
| var dom = vNode.dom; |
| if (events.onInput) { |
| events.onInput(e); |
| } |
| else if (events.oninput) { |
| events.oninput(e); |
| } |
| // the user may have updated the vNode from the above onInput events |
| // so we need to get it from the context of `this` again |
| applyValue$2(this.vNode, dom); |
| } |
| function processTextarea(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| applyValue$2(vNode, dom); |
| var textareaWrapper = wrappers.get(dom); |
| if (isControlled$2(props)) { |
| if (!textareaWrapper) { |
| textareaWrapper = { |
| vNode: vNode |
| }; |
| dom.oninput = onTextareaInputChange.bind(textareaWrapper); |
| dom.oninput.wrapped = true; |
| wrappers.set(dom, textareaWrapper); |
| } |
| textareaWrapper.vNode = vNode; |
| } |
| } |
| function applyValue$2(vNode, dom) { |
| var props = vNode.props || EMPTY_OBJ; |
| var value = props.value; |
| if (dom.value !== value) { |
| dom.value = value; |
| } |
| } |
| |
| var wrappers = new Map(); |
| function processElement(flags, vNode, dom) { |
| if (flags & 512 /* InputElement */) { |
| processInput(vNode, dom); |
| } |
| else if (flags & 2048 /* SelectElement */) { |
| processSelect(vNode, dom); |
| } |
| else if (flags & 1024 /* TextareaElement */) { |
| processTextarea(vNode, dom); |
| } |
| } |
| |
| function unmount(vNode, parentDom, lifecycle, canRecycle, shallowUnmount, isRecycling) { |
| var flags = vNode.flags; |
| if (flags & 28 /* Component */) { |
| unmountComponent(vNode, parentDom, lifecycle, canRecycle, shallowUnmount, isRecycling); |
| } |
| else if (flags & 3970 /* Element */) { |
| unmountElement(vNode, parentDom, lifecycle, canRecycle, shallowUnmount, isRecycling); |
| } |
| else if (flags & (1 /* Text */ | 4096 /* Void */)) { |
| unmountVoidOrText(vNode, parentDom); |
| } |
| } |
| function unmountVoidOrText(vNode, parentDom) { |
| if (parentDom) { |
| removeChild(parentDom, vNode.dom); |
| } |
| } |
| function unmountComponent(vNode, parentDom, lifecycle, canRecycle, shallowUnmount, isRecycling) { |
| var instance = vNode.children; |
| var flags = vNode.flags; |
| var isStatefulComponent$$1 = flags & 4; |
| var ref = vNode.ref; |
| var dom = vNode.dom; |
| if (!isRecycling) { |
| if (!shallowUnmount) { |
| if (isStatefulComponent$$1) { |
| var subLifecycle = instance._lifecycle; |
| if (!subLifecycle.fastUnmount) { |
| unmount(instance._lastInput, null, lifecycle, false, shallowUnmount, isRecycling); |
| } |
| } |
| else { |
| if (!lifecycle.fastUnmount) { |
| unmount(instance, null, lifecycle, false, shallowUnmount, isRecycling); |
| } |
| } |
| } |
| if (isStatefulComponent$$1) { |
| instance._ignoreSetState = true; |
| instance.componentWillUnmount(); |
| if (ref && !isRecycling) { |
| ref(null); |
| } |
| instance._unmounted = true; |
| findDOMNodeEnabled && componentToDOMNodeMap.delete(instance); |
| } |
| else if (!isNullOrUndef(ref)) { |
| if (!isNullOrUndef(ref.onComponentWillUnmount)) { |
| ref.onComponentWillUnmount(dom); |
| } |
| } |
| } |
| if (parentDom) { |
| var lastInput = instance._lastInput; |
| if (isNullOrUndef(lastInput)) { |
| lastInput = instance; |
| } |
| removeChild(parentDom, dom); |
| } |
| if (recyclingEnabled && !isStatefulComponent$$1 && (parentDom || canRecycle)) { |
| poolComponent(vNode); |
| } |
| } |
| function unmountElement(vNode, parentDom, lifecycle, canRecycle, shallowUnmount, isRecycling) { |
| var dom = vNode.dom; |
| var ref = vNode.ref; |
| var events = vNode.events; |
| if (!shallowUnmount && !lifecycle.fastUnmount) { |
| if (ref && !isRecycling) { |
| unmountRef(ref); |
| } |
| var children = vNode.children; |
| if (!isNullOrUndef(children)) { |
| unmountChildren$1(children, lifecycle, shallowUnmount, isRecycling); |
| } |
| } |
| if (!isNull(events)) { |
| for (var name in events) { |
| // do not add a hasOwnProperty check here, it affects performance |
| patchEvent(name, events[name], null, dom, lifecycle); |
| events[name] = null; |
| } |
| } |
| if (parentDom) { |
| removeChild(parentDom, dom); |
| } |
| if (recyclingEnabled && (parentDom || canRecycle)) { |
| poolElement(vNode); |
| } |
| } |
| function unmountChildren$1(children, lifecycle, shallowUnmount, isRecycling) { |
| if (isArray(children)) { |
| for (var i = 0; i < children.length; i++) { |
| var child = children[i]; |
| if (!isInvalid(child) && isObject(child)) { |
| unmount(child, null, lifecycle, false, shallowUnmount, isRecycling); |
| } |
| } |
| } |
| else if (isObject(children)) { |
| unmount(children, null, lifecycle, false, shallowUnmount, isRecycling); |
| } |
| } |
| function unmountRef(ref) { |
| if (isFunction(ref)) { |
| ref(null); |
| } |
| else { |
| if (isInvalid(ref)) { |
| return; |
| } |
| if (false) { |
| throwError('string "refs" are not supported in Inferno 1.0. Use callback "refs" instead.'); |
| } |
| throwError(); |
| } |
| } |
| |
| function patch(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling) { |
| if (lastVNode !== nextVNode) { |
| var lastFlags = lastVNode.flags; |
| var nextFlags = nextVNode.flags; |
| if (nextFlags & 28 /* Component */) { |
| if (lastFlags & 28 /* Component */) { |
| patchComponent(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, nextFlags & 4 /* ComponentClass */, isRecycling); |
| } |
| else { |
| replaceVNode(parentDom, mountComponent(nextVNode, null, lifecycle, context, isSVG, nextFlags & 4 /* ComponentClass */), lastVNode, lifecycle, isRecycling); |
| } |
| } |
| else if (nextFlags & 3970 /* Element */) { |
| if (lastFlags & 3970 /* Element */) { |
| patchElement(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling); |
| } |
| else { |
| replaceVNode(parentDom, mountElement(nextVNode, null, lifecycle, context, isSVG), lastVNode, lifecycle, isRecycling); |
| } |
| } |
| else if (nextFlags & 1 /* Text */) { |
| if (lastFlags & 1 /* Text */) { |
| patchText(lastVNode, nextVNode); |
| } |
| else { |
| replaceVNode(parentDom, mountText(nextVNode, null), lastVNode, lifecycle, isRecycling); |
| } |
| } |
| else if (nextFlags & 4096 /* Void */) { |
| if (lastFlags & 4096 /* Void */) { |
| patchVoid(lastVNode, nextVNode); |
| } |
| else { |
| replaceVNode(parentDom, mountVoid(nextVNode, null), lastVNode, lifecycle, isRecycling); |
| } |
| } |
| else { |
| // Error case: mount new one replacing old one |
| replaceLastChildAndUnmount(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling); |
| } |
| } |
| } |
| function unmountChildren(children, dom, lifecycle, isRecycling) { |
| if (isVNode(children)) { |
| unmount(children, dom, lifecycle, true, false, isRecycling); |
| } |
| else if (isArray(children)) { |
| removeAllChildren(dom, children, lifecycle, false, isRecycling); |
| } |
| else { |
| dom.textContent = ''; |
| } |
| } |
| function patchElement(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling) { |
| var nextTag = nextVNode.type; |
| var lastTag = lastVNode.type; |
| if (lastTag !== nextTag) { |
| replaceWithNewNode(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling); |
| } |
| else { |
| var dom = lastVNode.dom; |
| var lastProps = lastVNode.props; |
| var nextProps = nextVNode.props; |
| var lastChildren = lastVNode.children; |
| var nextChildren = nextVNode.children; |
| var lastFlags = lastVNode.flags; |
| var nextFlags = nextVNode.flags; |
| var lastRef = lastVNode.ref; |
| var nextRef = nextVNode.ref; |
| var lastEvents = lastVNode.events; |
| var nextEvents = nextVNode.events; |
| nextVNode.dom = dom; |
| if (isSVG || (nextFlags & 128 /* SvgElement */)) { |
| isSVG = true; |
| } |
| if (lastChildren !== nextChildren) { |
| patchChildren(lastFlags, nextFlags, lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling); |
| } |
| if (!(nextFlags & 2 /* HtmlElement */)) { |
| processElement(nextFlags, nextVNode, dom); |
| } |
| if (lastProps !== nextProps) { |
| patchProps(lastProps, nextProps, dom, lifecycle, context, isSVG); |
| } |
| if (lastEvents !== nextEvents) { |
| patchEvents(lastEvents, nextEvents, dom, lifecycle); |
| } |
| if (nextRef) { |
| if (lastRef !== nextRef || isRecycling) { |
| mountRef(dom, nextRef, lifecycle); |
| } |
| } |
| } |
| } |
| function patchChildren(lastFlags, nextFlags, lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling) { |
| var patchArray = false; |
| var patchKeyed = false; |
| if (nextFlags & 64 /* HasNonKeyedChildren */) { |
| patchArray = true; |
| } |
| else if ((lastFlags & 32 /* HasKeyedChildren */) && (nextFlags & 32 /* HasKeyedChildren */)) { |
| patchKeyed = true; |
| patchArray = true; |
| } |
| else if (isInvalid(nextChildren)) { |
| unmountChildren(lastChildren, dom, lifecycle, isRecycling); |
| } |
| else if (isInvalid(lastChildren)) { |
| if (isStringOrNumber(nextChildren)) { |
| setTextContent(dom, nextChildren); |
| } |
| else { |
| if (isArray(nextChildren)) { |
| mountArrayChildren(nextChildren, dom, lifecycle, context, isSVG); |
| } |
| else { |
| mount(nextChildren, dom, lifecycle, context, isSVG); |
| } |
| } |
| } |
| else if (isStringOrNumber(nextChildren)) { |
| if (isStringOrNumber(lastChildren)) { |
| updateTextContent(dom, nextChildren); |
| } |
| else { |
| unmountChildren(lastChildren, dom, lifecycle, isRecycling); |
| setTextContent(dom, nextChildren); |
| } |
| } |
| else if (isArray(nextChildren)) { |
| if (isArray(lastChildren)) { |
| patchArray = true; |
| if (isKeyed(lastChildren, nextChildren)) { |
| patchKeyed = true; |
| } |
| } |
| else { |
| unmountChildren(lastChildren, dom, lifecycle, isRecycling); |
| mountArrayChildren(nextChildren, dom, lifecycle, context, isSVG); |
| } |
| } |
| else if (isArray(lastChildren)) { |
| removeAllChildren(dom, lastChildren, lifecycle, false, isRecycling); |
| mount(nextChildren, dom, lifecycle, context, isSVG); |
| } |
| else if (isVNode(nextChildren)) { |
| if (isVNode(lastChildren)) { |
| patch(lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling); |
| } |
| else { |
| unmountChildren(lastChildren, dom, lifecycle, isRecycling); |
| mount(nextChildren, dom, lifecycle, context, isSVG); |
| } |
| } |
| else if (isVNode(lastChildren)) { |
| } |
| else { |
| } |
| if (patchArray) { |
| if (patchKeyed) { |
| patchKeyedChildren(lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling); |
| } |
| else { |
| patchNonKeyedChildren(lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling); |
| } |
| } |
| } |
| function patchComponent(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isClass, isRecycling) { |
| var lastType = lastVNode.type; |
| var nextType = nextVNode.type; |
| var nextProps = nextVNode.props || EMPTY_OBJ; |
| var lastKey = lastVNode.key; |
| var nextKey = nextVNode.key; |
| if (lastType !== nextType) { |
| if (isClass) { |
| replaceWithNewNode(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling); |
| } |
| else { |
| var lastInput = lastVNode.children._lastInput || lastVNode.children; |
| var nextInput = createStatelessComponentInput(nextVNode, nextType, nextProps, context); |
| patch(lastInput, nextInput, parentDom, lifecycle, context, isSVG, isRecycling); |
| var dom = nextVNode.dom = nextInput.dom; |
| nextVNode.children = nextInput; |
| mountStatelessComponentCallbacks(nextVNode.ref, dom, lifecycle); |
| unmount(lastVNode, null, lifecycle, false, true, isRecycling); |
| } |
| } |
| else { |
| if (isClass) { |
| if (lastKey !== nextKey) { |
| replaceWithNewNode(lastVNode, nextVNode, parentDom, lifecycle, context, isSVG, isRecycling); |
| return false; |
| } |
| var instance = lastVNode.children; |
| if (instance._unmounted) { |
| if (isNull(parentDom)) { |
| return true; |
| } |
| replaceChild(parentDom, mountComponent(nextVNode, null, lifecycle, context, isSVG, nextVNode.flags & 4 /* ComponentClass */), lastVNode.dom); |
| } |
| else { |
| var defaultProps = nextType.defaultProps; |
| var lastProps = instance.props; |
| if (instance._devToolsStatus.connected && !instance._devToolsId) { |
| componentIdMap.set(instance._devToolsId = getIncrementalId(), instance); |
| } |
| lifecycle.fastUnmount = false; |
| if (!isUndefined(defaultProps)) { |
| copyPropsTo(lastProps, nextProps); |
| nextVNode.props = nextProps; |
| } |
| var lastState = instance.state; |
| var nextState = instance.state; |
| var childContext = instance.getChildContext(); |
| nextVNode.children = instance; |
| instance._isSVG = isSVG; |
| if (!isNullOrUndef(childContext)) { |
| childContext = Object.assign({}, context, childContext); |
| } |
| else { |
| childContext = context; |
| } |
| var lastInput$1 = instance._lastInput; |
| var nextInput$1 = instance._updateComponent(lastState, nextState, lastProps, nextProps, context, false); |
| var didUpdate = true; |
| instance._childContext = childContext; |
| if (isInvalid(nextInput$1)) { |
| nextInput$1 = createVoidVNode(); |
| } |
| else if (isArray(nextInput$1)) { |
| if (false) { |
| throwError('a valid Inferno VNode (or null) must be returned from a component render. You may have returned an array or an invalid object.'); |
| } |
| throwError(); |
| } |
| else if (nextInput$1 === NO_OP) { |
| nextInput$1 = lastInput$1; |
| didUpdate = false; |
| } |
| else if (isObject(nextInput$1) && nextInput$1.dom) { |
| nextInput$1 = cloneVNode(nextInput$1); |
| } |
| if (nextInput$1.flags & 28 /* Component */) { |
| nextInput$1.parentVNode = nextVNode; |
| } |
| else if (lastInput$1.flags & 28 /* Component */) { |
| lastInput$1.parentVNode = nextVNode; |
| } |
| instance._lastInput = nextInput$1; |
| instance._vNode = nextVNode; |
| if (didUpdate) { |
| var fastUnmount = lifecycle.fastUnmount; |
| var subLifecycle = instance._lifecycle; |
| lifecycle.fastUnmount = subLifecycle.fastUnmount; |
| patch(lastInput$1, nextInput$1, parentDom, lifecycle, childContext, isSVG, isRecycling); |
| subLifecycle.fastUnmount = lifecycle.unmount; |
| lifecycle.fastUnmount = fastUnmount; |
| instance.componentDidUpdate(lastProps, lastState); |
| findDOMNodeEnabled && componentToDOMNodeMap.set(instance, nextInput$1.dom); |
| } |
| nextVNode.dom = nextInput$1.dom; |
| } |
| } |
| else { |
| var shouldUpdate = true; |
| var lastProps$1 = lastVNode.props; |
| var nextHooks = nextVNode.ref; |
| var nextHooksDefined = !isNullOrUndef(nextHooks); |
| var lastInput$2 = lastVNode.children; |
| var nextInput$2 = lastInput$2; |
| nextVNode.dom = lastVNode.dom; |
| nextVNode.children = lastInput$2; |
| if (lastKey !== nextKey) { |
| shouldUpdate = true; |
| } |
| else { |
| if (nextHooksDefined && !isNullOrUndef(nextHooks.onComponentShouldUpdate)) { |
| shouldUpdate = nextHooks.onComponentShouldUpdate(lastProps$1, nextProps); |
| } |
| } |
| if (shouldUpdate !== false) { |
| if (nextHooksDefined && !isNullOrUndef(nextHooks.onComponentWillUpdate)) { |
| lifecycle.fastUnmount = false; |
| nextHooks.onComponentWillUpdate(lastProps$1, nextProps); |
| } |
| nextInput$2 = nextType(nextProps, context); |
| if (isInvalid(nextInput$2)) { |
| nextInput$2 = createVoidVNode(); |
| } |
| else if (isArray(nextInput$2)) { |
| if (false) { |
| throwError('a valid Inferno VNode (or null) must be returned from a component render. You may have returned an array or an invalid object.'); |
| } |
| throwError(); |
| } |
| else if (isObject(nextInput$2) && nextInput$2.dom) { |
| nextInput$2 = cloneVNode(nextInput$2); |
| } |
| if (nextInput$2 !== NO_OP) { |
| patch(lastInput$2, nextInput$2, parentDom, lifecycle, context, isSVG, isRecycling); |
| nextVNode.children = nextInput$2; |
| if (nextHooksDefined && !isNullOrUndef(nextHooks.onComponentDidUpdate)) { |
| lifecycle.fastUnmount = false; |
| nextHooks.onComponentDidUpdate(lastProps$1, nextProps); |
| } |
| nextVNode.dom = nextInput$2.dom; |
| } |
| } |
| if (nextInput$2.flags & 28 /* Component */) { |
| nextInput$2.parentVNode = nextVNode; |
| } |
| else if (lastInput$2.flags & 28 /* Component */) { |
| lastInput$2.parentVNode = nextVNode; |
| } |
| } |
| } |
| return false; |
| } |
| function patchText(lastVNode, nextVNode) { |
| var nextText = nextVNode.children; |
| var dom = lastVNode.dom; |
| nextVNode.dom = dom; |
| if (lastVNode.children !== nextText) { |
| dom.nodeValue = nextText; |
| } |
| } |
| function patchVoid(lastVNode, nextVNode) { |
| nextVNode.dom = lastVNode.dom; |
| } |
| function patchNonKeyedChildren(lastChildren, nextChildren, dom, lifecycle, context, isSVG, isRecycling) { |
| var lastChildrenLength = lastChildren.length; |
| var nextChildrenLength = nextChildren.length; |
| var commonLength = lastChildrenLength > nextChildrenLength ? nextChildrenLength : lastChildrenLength; |
| var i; |
| var nextNode = null; |
| var newNode; |
| // Loop backwards so we can use insertBefore |
| if (lastChildrenLength < nextChildrenLength) { |
| for (i = nextChildrenLength - 1; i >= commonLength; i--) { |
| var child = nextChildren[i]; |
| if (!isInvalid(child)) { |
| if (child.dom) { |
| nextChildren[i] = child = cloneVNode(child); |
| } |
| newNode = mount(child, null, lifecycle, context, isSVG); |
| insertOrAppend(dom, newNode, nextNode); |
| nextNode = newNode; |
| } |
| } |
| } |
| else if (nextChildrenLength === 0) { |
| removeAllChildren(dom, lastChildren, lifecycle, false, isRecycling); |
| } |
| else if (lastChildrenLength > nextChildrenLength) { |
| for (i = commonLength; i < lastChildrenLength; i++) { |
| var child$1 = lastChildren[i]; |
| if (!isInvalid(child$1)) { |
| unmount(lastChildren[i], dom, lifecycle, false, false, isRecycling); |
| } |
| } |
| } |
| for (i = commonLength - 1; i >= 0; i--) { |
| var lastChild = lastChildren[i]; |
| var nextChild = nextChildren[i]; |
| if (isInvalid(nextChild)) { |
| if (!isInvalid(lastChild)) { |
| unmount(lastChild, dom, lifecycle, true, false, isRecycling); |
| } |
| } |
| else { |
| if (nextChild.dom) { |
| nextChildren[i] = nextChild = cloneVNode(nextChild); |
| } |
| if (isInvalid(lastChild)) { |
| newNode = mount(nextChild, null, lifecycle, context, isSVG); |
| insertOrAppend(dom, newNode, nextNode); |
| nextNode = newNode; |
| } |
| else { |
| patch(lastChild, nextChild, dom, lifecycle, context, isSVG, isRecycling); |
| nextNode = nextChild.dom; |
| } |
| } |
| } |
| } |
| function patchKeyedChildren(a, b, dom, lifecycle, context, isSVG, isRecycling) { |
| var aLength = a.length; |
| var bLength = b.length; |
| var aEnd = aLength - 1; |
| var bEnd = bLength - 1; |
| var aStart = 0; |
| var bStart = 0; |
| var i; |
| var j; |
| var aNode; |
| var bNode; |
| var nextNode; |
| var nextPos; |
| var node; |
| if (aLength === 0) { |
| if (bLength !== 0) { |
| mountArrayChildren(b, dom, lifecycle, context, isSVG); |
| } |
| return; |
| } |
| else if (bLength === 0) { |
| removeAllChildren(dom, a, lifecycle, false, isRecycling); |
| return; |
| } |
| var aStartNode = a[aStart]; |
| var bStartNode = b[bStart]; |
| var aEndNode = a[aEnd]; |
| var bEndNode = b[bEnd]; |
| if (bStartNode.dom) { |
| b[bStart] = bStartNode = cloneVNode(bStartNode); |
| } |
| if (bEndNode.dom) { |
| b[bEnd] = bEndNode = cloneVNode(bEndNode); |
| } |
| // Step 1 |
| /* eslint no-constant-condition: 0 */ |
| outer: while (true) { |
| // Sync nodes with the same key at the beginning. |
| while (aStartNode.key === bStartNode.key) { |
| patch(aStartNode, bStartNode, dom, lifecycle, context, isSVG, isRecycling); |
| aStart++; |
| bStart++; |
| if (aStart > aEnd || bStart > bEnd) { |
| break outer; |
| } |
| aStartNode = a[aStart]; |
| bStartNode = b[bStart]; |
| if (bStartNode.dom) { |
| b[bStart] = bStartNode = cloneVNode(bStartNode); |
| } |
| } |
| // Sync nodes with the same key at the end. |
| while (aEndNode.key === bEndNode.key) { |
| patch(aEndNode, bEndNode, dom, lifecycle, context, isSVG, isRecycling); |
| aEnd--; |
| bEnd--; |
| if (aStart > aEnd || bStart > bEnd) { |
| break outer; |
| } |
| aEndNode = a[aEnd]; |
| bEndNode = b[bEnd]; |
| if (bEndNode.dom) { |
| b[bEnd] = bEndNode = cloneVNode(bEndNode); |
| } |
| } |
| // Move and sync nodes from right to left. |
| if (aEndNode.key === bStartNode.key) { |
| patch(aEndNode, bStartNode, dom, lifecycle, context, isSVG, isRecycling); |
| insertOrAppend(dom, bStartNode.dom, aStartNode.dom); |
| aEnd--; |
| bStart++; |
| aEndNode = a[aEnd]; |
| bStartNode = b[bStart]; |
| if (bStartNode.dom) { |
| b[bStart] = bStartNode = cloneVNode(bStartNode); |
| } |
| continue; |
| } |
| // Move and sync nodes from left to right. |
| if (aStartNode.key === bEndNode.key) { |
| patch(aStartNode, bEndNode, dom, lifecycle, context, isSVG, isRecycling); |
| nextPos = bEnd + 1; |
| nextNode = nextPos < b.length ? b[nextPos].dom : null; |
| insertOrAppend(dom, bEndNode.dom, nextNode); |
| aStart++; |
| bEnd--; |
| aStartNode = a[aStart]; |
| bEndNode = b[bEnd]; |
| if (bEndNode.dom) { |
| b[bEnd] = bEndNode = cloneVNode(bEndNode); |
| } |
| continue; |
| } |
| break; |
| } |
| if (aStart > aEnd) { |
| if (bStart <= bEnd) { |
| nextPos = bEnd + 1; |
| nextNode = nextPos < b.length ? b[nextPos].dom : null; |
| while (bStart <= bEnd) { |
| node = b[bStart]; |
| if (node.dom) { |
| b[bStart] = node = cloneVNode(node); |
| } |
| bStart++; |
| insertOrAppend(dom, mount(node, null, lifecycle, context, isSVG), nextNode); |
| } |
| } |
| } |
| else if (bStart > bEnd) { |
| while (aStart <= aEnd) { |
| unmount(a[aStart++], dom, lifecycle, false, false, isRecycling); |
| } |
| } |
| else { |
| aLength = aEnd - aStart + 1; |
| bLength = bEnd - bStart + 1; |
| var aNullable = a; |
| var sources = new Array(bLength); |
| // Mark all nodes as inserted. |
| for (i = 0; i < bLength; i++) { |
| sources[i] = -1; |
| } |
| var moved = false; |
| var pos = 0; |
| var patched = 0; |
| if ((bLength <= 4) || (aLength * bLength <= 16)) { |
| for (i = aStart; i <= aEnd; i++) { |
| aNode = a[i]; |
| if (patched < bLength) { |
| for (j = bStart; j <= bEnd; j++) { |
| bNode = b[j]; |
| if (aNode.key === bNode.key) { |
| sources[j - bStart] = i; |
| if (pos > j) { |
| moved = true; |
| } |
| else { |
| pos = j; |
| } |
| if (bNode.dom) { |
| b[j] = bNode = cloneVNode(bNode); |
| } |
| patch(aNode, bNode, dom, lifecycle, context, isSVG, isRecycling); |
| patched++; |
| aNullable[i] = null; |
| break; |
| } |
| } |
| } |
| } |
| } |
| else { |
| var keyIndex = new Map(); |
| for (i = bStart; i <= bEnd; i++) { |
| node = b[i]; |
| keyIndex.set(node.key, i); |
| } |
| for (i = aStart; i <= aEnd; i++) { |
| aNode = a[i]; |
| if (patched < bLength) { |
| j = keyIndex.get(aNode.key); |
| if (!isUndefined(j)) { |
| bNode = b[j]; |
| sources[j - bStart] = i; |
| if (pos > j) { |
| moved = true; |
| } |
| else { |
| pos = j; |
| } |
| if (bNode.dom) { |
| b[j] = bNode = cloneVNode(bNode); |
| } |
| patch(aNode, bNode, dom, lifecycle, context, isSVG, isRecycling); |
| patched++; |
| aNullable[i] = null; |
| } |
| } |
| } |
| } |
| if (aLength === a.length && patched === 0) { |
| removeAllChildren(dom, a, lifecycle, false, isRecycling); |
| while (bStart < bLength) { |
| node = b[bStart]; |
| if (node.dom) { |
| b[bStart] = node = cloneVNode(node); |
| } |
| bStart++; |
| insertOrAppend(dom, mount(node, null, lifecycle, context, isSVG), null); |
| } |
| } |
| else { |
| i = aLength - patched; |
| while (i > 0) { |
| aNode = aNullable[aStart++]; |
| if (!isNull(aNode)) { |
| unmount(aNode, dom, lifecycle, false, false, isRecycling); |
| i--; |
| } |
| } |
| if (moved) { |
| var seq = lis_algorithm(sources); |
| j = seq.length - 1; |
| for (i = bLength - 1; i >= 0; i--) { |
| if (sources[i] === -1) { |
| pos = i + bStart; |
| node = b[pos]; |
| if (node.dom) { |
| b[pos] = node = cloneVNode(node); |
| } |
| nextPos = pos + 1; |
| nextNode = nextPos < b.length ? b[nextPos].dom : null; |
| insertOrAppend(dom, mount(node, dom, lifecycle, context, isSVG), nextNode); |
| } |
| else { |
| if (j < 0 || i !== seq[j]) { |
| pos = i + bStart; |
| node = b[pos]; |
| nextPos = pos + 1; |
| nextNode = nextPos < b.length ? b[nextPos].dom : null; |
| insertOrAppend(dom, node.dom, nextNode); |
| } |
| else { |
| j--; |
| } |
| } |
| } |
| } |
| else if (patched !== bLength) { |
| for (i = bLength - 1; i >= 0; i--) { |
| if (sources[i] === -1) { |
| pos = i + bStart; |
| node = b[pos]; |
| if (node.dom) { |
| b[pos] = node = cloneVNode(node); |
| } |
| nextPos = pos + 1; |
| nextNode = nextPos < b.length ? b[nextPos].dom : null; |
| insertOrAppend(dom, mount(node, null, lifecycle, context, isSVG), nextNode); |
| } |
| } |
| } |
| } |
| } |
| } |
| // // https://en.wikipedia.org/wiki/Longest_increasing_subsequence |
| function lis_algorithm(a) { |
| var p = a.slice(0); |
| var result = []; |
| result.push(0); |
| var i; |
| var j; |
| var u; |
| var v; |
| var c; |
| for (i = 0; i < a.length; i++) { |
| if (a[i] === -1) { |
| continue; |
| } |
| j = result[result.length - 1]; |
| if (a[j] < a[i]) { |
| p[i] = j; |
| result.push(i); |
| continue; |
| } |
| u = 0; |
| v = result.length - 1; |
| while (u < v) { |
| c = ((u + v) / 2) | 0; |
| if (a[result[c]] < a[i]) { |
| u = c + 1; |
| } |
| else { |
| v = c; |
| } |
| } |
| if (a[i] < a[result[u]]) { |
| if (u > 0) { |
| p[i] = result[u - 1]; |
| } |
| result[u] = i; |
| } |
| } |
| u = result.length; |
| v = result[u - 1]; |
| while (u-- > 0) { |
| result[u] = v; |
| v = p[v]; |
| } |
| return result; |
| } |
| function patchProp(prop, lastValue, nextValue, dom, isSVG, lifecycle) { |
| if (skipProps[prop]) { |
| return; |
| } |
| if (booleanProps[prop]) { |
| dom[prop] = nextValue ? true : false; |
| } |
| else if (strictProps[prop]) { |
| var value = isNullOrUndef(nextValue) ? '' : nextValue; |
| if (dom[prop] !== value) { |
| dom[prop] = value; |
| } |
| } |
| else if (isAttrAnEvent(prop)) { |
| patchEvent(prop, lastValue, nextValue, dom, lifecycle); |
| } |
| else if (lastValue !== nextValue) { |
| if (isNullOrUndef(nextValue)) { |
| dom.removeAttribute(prop); |
| } |
| else if (prop === 'className') { |
| if (isSVG) { |
| dom.setAttribute('class', nextValue); |
| } |
| else { |
| dom.className = nextValue; |
| } |
| } |
| else if (prop === 'style') { |
| patchStyle(lastValue, nextValue, dom); |
| } |
| else if (prop === 'dangerouslySetInnerHTML') { |
| var lastHtml = lastValue && lastValue.__html; |
| var nextHtml = nextValue && nextValue.__html; |
| if (lastHtml !== nextHtml) { |
| if (!isNullOrUndef(nextHtml)) { |
| dom.innerHTML = nextHtml; |
| } |
| } |
| } |
| else if (prop !== 'childrenType' && prop !== 'ref' && prop !== 'key') { |
| var dehyphenProp = dehyphenProps[prop]; |
| var ns = namespaces[prop]; |
| if (ns) { |
| dom.setAttributeNS(ns, dehyphenProp || prop, nextValue); |
| } |
| else { |
| dom.setAttribute(dehyphenProp || prop, nextValue); |
| } |
| } |
| } |
| } |
| function patchEvents(lastEvents, nextEvents, dom, lifecycle) { |
| lastEvents = lastEvents || EMPTY_OBJ; |
| nextEvents = nextEvents || EMPTY_OBJ; |
| if (nextEvents !== EMPTY_OBJ) { |
| for (var name in nextEvents) { |
| // do not add a hasOwnProperty check here, it affects performance |
| patchEvent(name, lastEvents[name], nextEvents[name], dom, lifecycle); |
| } |
| } |
| if (lastEvents !== EMPTY_OBJ) { |
| for (var name$1 in lastEvents) { |
| // do not add a hasOwnProperty check here, it affects performance |
| if (isNullOrUndef(nextEvents[name$1])) { |
| patchEvent(name$1, lastEvents[name$1], null, dom, lifecycle); |
| } |
| } |
| } |
| } |
| function patchEvent(name, lastValue, nextValue, dom, lifecycle) { |
| if (lastValue !== nextValue) { |
| var nameLowerCase = name.toLowerCase(); |
| var domEvent = dom[nameLowerCase]; |
| // if the function is wrapped, that means it's been controlled by a wrapper |
| if (domEvent && domEvent.wrapped) { |
| return; |
| } |
| if (delegatedProps[name]) { |
| lifecycle.fastUnmount = false; |
| handleEvent(name, lastValue, nextValue, dom); |
| } |
| else { |
| dom[nameLowerCase] = nextValue; |
| } |
| } |
| } |
| function patchProps(lastProps, nextProps, dom, lifecycle, context, isSVG) { |
| lastProps = lastProps || EMPTY_OBJ; |
| nextProps = nextProps || EMPTY_OBJ; |
| if (nextProps !== EMPTY_OBJ) { |
| for (var prop in nextProps) { |
| // do not add a hasOwnProperty check here, it affects performance |
| var nextValue = nextProps[prop]; |
| var lastValue = lastProps[prop]; |
| if (isNullOrUndef(nextValue)) { |
| removeProp(prop, dom); |
| } |
| else { |
| patchProp(prop, lastValue, nextValue, dom, isSVG, lifecycle); |
| } |
| } |
| } |
| if (lastProps !== EMPTY_OBJ) { |
| for (var prop$1 in lastProps) { |
| // do not add a hasOwnProperty check here, it affects performance |
| if (isNullOrUndef(nextProps[prop$1])) { |
| removeProp(prop$1, dom); |
| } |
| } |
| } |
| } |
| // We are assuming here that we come from patchProp routine |
| // -nextAttrValue cannot be null or undefined |
| function patchStyle(lastAttrValue, nextAttrValue, dom) { |
| if (isString(nextAttrValue)) { |
| dom.style.cssText = nextAttrValue; |
| return; |
| } |
| for (var style in nextAttrValue) { |
| // do not add a hasOwnProperty check here, it affects performance |
| var value = nextAttrValue[style]; |
| if (isNumber(value) && !isUnitlessNumber[style]) { |
| dom.style[style] = value + 'px'; |
| } |
| else { |
| dom.style[style] = value; |
| } |
| } |
| if (!isNullOrUndef(lastAttrValue)) { |
| for (var style$1 in lastAttrValue) { |
| if (isNullOrUndef(nextAttrValue[style$1])) { |
| dom.style[style$1] = ''; |
| } |
| } |
| } |
| } |
| function removeProp(prop, dom) { |
| if (prop === 'className') { |
| dom.removeAttribute('class'); |
| } |
| else if (prop === 'value') { |
| dom.value = ''; |
| } |
| else if (prop === 'style') { |
| dom.style.cssText = null; |
| dom.removeAttribute('style'); |
| } |
| else if (delegatedProps[prop]) { |
| handleEvent(prop, null, null, dom); |
| } |
| else { |
| dom.removeAttribute(prop); |
| } |
| } |
| |
| var recyclingEnabled = true; |
| var componentPools = new Map(); |
| var elementPools = new Map(); |
| function disableRecycling() { |
| recyclingEnabled = false; |
| componentPools.clear(); |
| elementPools.clear(); |
| } |
| |
| function recycleElement(vNode, lifecycle, context, isSVG) { |
| var tag = vNode.type; |
| var key = vNode.key; |
| var pools = elementPools.get(tag); |
| if (!isUndefined(pools)) { |
| var pool = key === null ? pools.nonKeyed : pools.keyed.get(key); |
| if (!isUndefined(pool)) { |
| var recycledVNode = pool.pop(); |
| if (!isUndefined(recycledVNode)) { |
| patchElement(recycledVNode, vNode, null, lifecycle, context, isSVG, true); |
| return vNode.dom; |
| } |
| } |
| } |
| return null; |
| } |
| function poolElement(vNode) { |
| var tag = vNode.type; |
| var key = vNode.key; |
| var pools = elementPools.get(tag); |
| if (isUndefined(pools)) { |
| pools = { |
| nonKeyed: [], |
| keyed: new Map() |
| }; |
| elementPools.set(tag, pools); |
| } |
| if (isNull(key)) { |
| pools.nonKeyed.push(vNode); |
| } |
| else { |
| var pool = pools.keyed.get(key); |
| if (isUndefined(pool)) { |
| pool = []; |
| pools.keyed.set(key, pool); |
| } |
| pool.push(vNode); |
| } |
| } |
| function recycleComponent(vNode, lifecycle, context, isSVG) { |
| var type = vNode.type; |
| var key = vNode.key; |
| var pools = componentPools.get(type); |
| if (!isUndefined(pools)) { |
| var pool = key === null ? pools.nonKeyed : pools.keyed.get(key); |
| if (!isUndefined(pool)) { |
| var recycledVNode = pool.pop(); |
| if (!isUndefined(recycledVNode)) { |
| var flags = vNode.flags; |
| var failed = patchComponent(recycledVNode, vNode, null, lifecycle, context, isSVG, flags & 4 /* ComponentClass */, true); |
| if (!failed) { |
| return vNode.dom; |
| } |
| } |
| } |
| } |
| return null; |
| } |
| function poolComponent(vNode) { |
| var type = vNode.type; |
| var key = vNode.key; |
| var hooks = vNode.ref; |
| var nonRecycleHooks = hooks && (hooks.onComponentWillMount || |
| hooks.onComponentWillUnmount || |
| hooks.onComponentDidMount || |
| hooks.onComponentWillUpdate || |
| hooks.onComponentDidUpdate); |
| if (nonRecycleHooks) { |
| return; |
| } |
| var pools = componentPools.get(type); |
| if (isUndefined(pools)) { |
| pools = { |
| nonKeyed: [], |
| keyed: new Map() |
| }; |
| componentPools.set(type, pools); |
| } |
| if (isNull(key)) { |
| pools.nonKeyed.push(vNode); |
| } |
| else { |
| var pool = pools.keyed.get(key); |
| if (isUndefined(pool)) { |
| pool = []; |
| pools.keyed.set(key, pool); |
| } |
| pool.push(vNode); |
| } |
| } |
| |
| function mount(vNode, parentDom, lifecycle, context, isSVG) { |
| var flags = vNode.flags; |
| if (flags & 3970 /* Element */) { |
| return mountElement(vNode, parentDom, lifecycle, context, isSVG); |
| } |
| else if (flags & 28 /* Component */) { |
| return mountComponent(vNode, parentDom, lifecycle, context, isSVG, flags & 4 /* ComponentClass */); |
| } |
| else if (flags & 4096 /* Void */) { |
| return mountVoid(vNode, parentDom); |
| } |
| else if (flags & 1 /* Text */) { |
| return mountText(vNode, parentDom); |
| } |
| else { |
| if (false) { |
| throwError(("mount() expects a valid VNode, instead it received an object with the type \"" + (typeof vNode) + "\".")); |
| } |
| throwError(); |
| } |
| } |
| function mountText(vNode, parentDom) { |
| var dom = document.createTextNode(vNode.children); |
| vNode.dom = dom; |
| if (parentDom) { |
| appendChild(parentDom, dom); |
| } |
| return dom; |
| } |
| function mountVoid(vNode, parentDom) { |
| var dom = document.createTextNode(''); |
| vNode.dom = dom; |
| if (parentDom) { |
| appendChild(parentDom, dom); |
| } |
| return dom; |
| } |
| function mountElement(vNode, parentDom, lifecycle, context, isSVG) { |
| if (recyclingEnabled) { |
| var dom$1 = recycleElement(vNode, lifecycle, context, isSVG); |
| if (!isNull(dom$1)) { |
| if (!isNull(parentDom)) { |
| appendChild(parentDom, dom$1); |
| } |
| return dom$1; |
| } |
| } |
| var tag = vNode.type; |
| var flags = vNode.flags; |
| if (isSVG || (flags & 128 /* SvgElement */)) { |
| isSVG = true; |
| } |
| var dom = documentCreateElement(tag, isSVG); |
| var children = vNode.children; |
| var props = vNode.props; |
| var events = vNode.events; |
| var ref = vNode.ref; |
| vNode.dom = dom; |
| if (!isNull(children)) { |
| if (isStringOrNumber(children)) { |
| setTextContent(dom, children); |
| } |
| else if (isArray(children)) { |
| mountArrayChildren(children, dom, lifecycle, context, isSVG); |
| } |
| else if (isVNode(children)) { |
| mount(children, dom, lifecycle, context, isSVG); |
| } |
| } |
| if (!(flags & 2 /* HtmlElement */)) { |
| processElement(flags, vNode, dom); |
| } |
| if (!isNull(props)) { |
| for (var prop in props) { |
| // do not add a hasOwnProperty check here, it affects performance |
| patchProp(prop, null, props[prop], dom, isSVG, lifecycle); |
| } |
| } |
| if (!isNull(events)) { |
| for (var name in events) { |
| // do not add a hasOwnProperty check here, it affects performance |
| patchEvent(name, null, events[name], dom, lifecycle); |
| } |
| } |
| if (!isNull(ref)) { |
| mountRef(dom, ref, lifecycle); |
| } |
| if (!isNull(parentDom)) { |
| appendChild(parentDom, dom); |
| } |
| return dom; |
| } |
| function mountArrayChildren(children, dom, lifecycle, context, isSVG) { |
| for (var i = 0; i < children.length; i++) { |
| var child = children[i]; |
| if (!isInvalid(child)) { |
| if (child.dom) { |
| children[i] = child = cloneVNode(child); |
| } |
| mount(children[i], dom, lifecycle, context, isSVG); |
| } |
| } |
| } |
| function mountComponent(vNode, parentDom, lifecycle, context, isSVG, isClass) { |
| if (recyclingEnabled) { |
| var dom$1 = recycleComponent(vNode, lifecycle, context, isSVG); |
| if (!isNull(dom$1)) { |
| if (!isNull(parentDom)) { |
| appendChild(parentDom, dom$1); |
| } |
| return dom$1; |
| } |
| } |
| var type = vNode.type; |
| var props = vNode.props || EMPTY_OBJ; |
| var ref = vNode.ref; |
| var dom; |
| if (isClass) { |
| var defaultProps = type.defaultProps; |
| lifecycle.fastUnmount = false; |
| if (!isUndefined(defaultProps)) { |
| copyPropsTo(defaultProps, props); |
| vNode.props = props; |
| } |
| var instance = createStatefulComponentInstance(vNode, type, props, context, isSVG, devToolsStatus); |
| var input = instance._lastInput; |
| var fastUnmount = lifecycle.fastUnmount; |
| // we store the fastUnmount value, but we set it back to true on the lifecycle |
| // we do this so we can determine if the component render has a fastUnmount or not |
| lifecycle.fastUnmount = true; |
| instance._vNode = vNode; |
| vNode.dom = dom = mount(input, null, lifecycle, instance._childContext, isSVG); |
| // we now create a lifecycle for this component and store the fastUnmount value |
| var subLifecycle = instance._lifecycle = new Lifecycle(); |
| subLifecycle.fastUnmount = lifecycle.fastUnmount; |
| // we then set the lifecycle fastUnmount value back to what it was before the mount |
| lifecycle.fastUnmount = fastUnmount; |
| if (!isNull(parentDom)) { |
| appendChild(parentDom, dom); |
| } |
| mountStatefulComponentCallbacks(ref, instance, lifecycle); |
| findDOMNodeEnabled && componentToDOMNodeMap.set(instance, dom); |
| vNode.children = instance; |
| } |
| else { |
| var input$1 = createStatelessComponentInput(vNode, type, props, context); |
| vNode.dom = dom = mount(input$1, null, lifecycle, context, isSVG); |
| vNode.children = input$1; |
| mountStatelessComponentCallbacks(ref, dom, lifecycle); |
| if (!isNull(parentDom)) { |
| appendChild(parentDom, dom); |
| } |
| } |
| return dom; |
| } |
| function mountStatefulComponentCallbacks(ref, instance, lifecycle) { |
| if (ref) { |
| if (isFunction(ref)) { |
| ref(instance); |
| } |
| else { |
| if (false) { |
| throwError('string "refs" are not supported in Inferno 1.0. Use callback "refs" instead.'); |
| } |
| throwError(); |
| } |
| } |
| if (!isNull(instance.componentDidMount)) { |
| lifecycle.addListener(function () { |
| instance.componentDidMount(); |
| }); |
| } |
| } |
| function mountStatelessComponentCallbacks(ref, dom, lifecycle) { |
| if (ref) { |
| if (!isNullOrUndef(ref.onComponentWillMount)) { |
| lifecycle.fastUnmount = false; |
| ref.onComponentWillMount(); |
| } |
| if (!isNullOrUndef(ref.onComponentDidMount)) { |
| lifecycle.fastUnmount = false; |
| lifecycle.addListener(function () { return ref.onComponentDidMount(dom); }); |
| } |
| } |
| } |
| function mountRef(dom, value, lifecycle) { |
| if (isFunction(value)) { |
| lifecycle.fastUnmount = false; |
| lifecycle.addListener(function () { return value(dom); }); |
| } |
| else { |
| if (isInvalid(value)) { |
| return; |
| } |
| if (false) { |
| throwError('string "refs" are not supported in Inferno 1.0. Use callback "refs" instead.'); |
| } |
| throwError(); |
| } |
| } |
| |
| function copyPropsTo(copyFrom, copyTo) { |
| for (var prop in copyFrom) { |
| if (isUndefined(copyTo[prop])) { |
| copyTo[prop] = copyFrom[prop]; |
| } |
| } |
| } |
| function createStatefulComponentInstance(vNode, Component, props, context, isSVG, devToolsStatus) { |
| if (isUndefined(context)) { |
| context = {}; |
| } |
| var instance = new Component(props, context); |
| instance.context = context; |
| if (instance.props === EMPTY_OBJ) { |
| instance.props = props; |
| } |
| instance._patch = patch; |
| instance._devToolsStatus = devToolsStatus; |
| if (findDOMNodeEnabled) { |
| instance._componentToDOMNodeMap = componentToDOMNodeMap; |
| } |
| var childContext = instance.getChildContext(); |
| if (!isNullOrUndef(childContext)) { |
| instance._childContext = Object.assign({}, context, childContext); |
| } |
| else { |
| instance._childContext = context; |
| } |
| instance._unmounted = false; |
| instance._pendingSetState = true; |
| instance._isSVG = isSVG; |
| instance.componentWillMount(); |
| instance._beforeRender && instance._beforeRender(); |
| var input = instance.render(props, instance.state, context); |
| instance._afterRender && instance._afterRender(); |
| if (isArray(input)) { |
| if (false) { |
| throwError('a valid Inferno VNode (or null) must be returned from a component render. You may have returned an array or an invalid object.'); |
| } |
| throwError(); |
| } |
| else if (isInvalid(input)) { |
| input = createVoidVNode(); |
| } |
| else { |
| if (input.dom) { |
| input = cloneVNode(input); |
| } |
| if (input.flags & 28 /* Component */) { |
| // if we have an input that is also a component, we run into a tricky situation |
| // where the root vNode needs to always have the correct DOM entry |
| // so we break monomorphism on our input and supply it our vNode as parentVNode |
| // we can optimise this in the future, but this gets us out of a lot of issues |
| input.parentVNode = vNode; |
| } |
| } |
| instance._pendingSetState = false; |
| instance._lastInput = input; |
| return instance; |
| } |
| function replaceLastChildAndUnmount(lastInput, nextInput, parentDom, lifecycle, context, isSVG, isRecycling) { |
| replaceVNode(parentDom, mount(nextInput, null, lifecycle, context, isSVG), lastInput, lifecycle, isRecycling); |
| } |
| function replaceVNode(parentDom, dom, vNode, lifecycle, isRecycling) { |
| var shallowUnmount = false; |
| // we cannot cache nodeType here as vNode might be re-assigned below |
| if (vNode.flags & 28 /* Component */) { |
| // if we are accessing a stateful or stateless component, we want to access their last rendered input |
| // accessing their DOM node is not useful to us here |
| unmount(vNode, null, lifecycle, false, false, isRecycling); |
| vNode = vNode.children._lastInput || vNode.children; |
| shallowUnmount = true; |
| } |
| replaceChild(parentDom, dom, vNode.dom); |
| unmount(vNode, null, lifecycle, false, shallowUnmount, isRecycling); |
| } |
| function createStatelessComponentInput(vNode, component, props, context) { |
| var input = component(props, context); |
| if (isArray(input)) { |
| if (false) { |
| throwError('a valid Inferno VNode (or null) must be returned from a component render. You may have returned an array or an invalid object.'); |
| } |
| throwError(); |
| } |
| else if (isInvalid(input)) { |
| input = createVoidVNode(); |
| } |
| else { |
| if (input.dom) { |
| input = cloneVNode(input); |
| } |
| if (input.flags & 28 /* Component */) { |
| // if we have an input that is also a component, we run into a tricky situation |
| // where the root vNode needs to always have the correct DOM entry |
| // so we break monomorphism on our input and supply it our vNode as parentVNode |
| // we can optimise this in the future, but this gets us out of a lot of issues |
| input.parentVNode = vNode; |
| } |
| } |
| return input; |
| } |
| function setTextContent(dom, text) { |
| if (text !== '') { |
| dom.textContent = text; |
| } |
| else { |
| dom.appendChild(document.createTextNode('')); |
| } |
| } |
| function updateTextContent(dom, text) { |
| dom.firstChild.nodeValue = text; |
| } |
| function appendChild(parentDom, dom) { |
| parentDom.appendChild(dom); |
| } |
| function insertOrAppend(parentDom, newNode, nextNode) { |
| if (isNullOrUndef(nextNode)) { |
| appendChild(parentDom, newNode); |
| } |
| else { |
| parentDom.insertBefore(newNode, nextNode); |
| } |
| } |
| function documentCreateElement(tag, isSVG) { |
| if (isSVG === true) { |
| return document.createElementNS(svgNS, tag); |
| } |
| else { |
| return document.createElement(tag); |
| } |
| } |
| function replaceWithNewNode(lastNode, nextNode, parentDom, lifecycle, context, isSVG, isRecycling) { |
| unmount(lastNode, null, lifecycle, false, false, isRecycling); |
| var dom = mount(nextNode, null, lifecycle, context, isSVG); |
| nextNode.dom = dom; |
| replaceChild(parentDom, dom, lastNode.dom); |
| } |
| function replaceChild(parentDom, nextDom, lastDom) { |
| if (!parentDom) { |
| parentDom = lastDom.parentNode; |
| } |
| parentDom.replaceChild(nextDom, lastDom); |
| } |
| function removeChild(parentDom, dom) { |
| parentDom.removeChild(dom); |
| } |
| function removeAllChildren(dom, children, lifecycle, shallowUnmount, isRecycling) { |
| dom.textContent = ''; |
| if (!lifecycle.fastUnmount) { |
| removeChildren(null, children, lifecycle, shallowUnmount, isRecycling); |
| } |
| } |
| function removeChildren(dom, children, lifecycle, shallowUnmount, isRecycling) { |
| for (var i = 0; i < children.length; i++) { |
| var child = children[i]; |
| if (!isInvalid(child)) { |
| unmount(child, dom, lifecycle, true, shallowUnmount, isRecycling); |
| } |
| } |
| } |
| function isKeyed(lastChildren, nextChildren) { |
| return nextChildren.length && !isNullOrUndef(nextChildren[0]) && !isNullOrUndef(nextChildren[0].key) |
| && lastChildren.length && !isNullOrUndef(lastChildren[0]) && !isNullOrUndef(lastChildren[0].key); |
| } |
| |
| function normaliseChildNodes(dom) { |
| var rawChildNodes = dom.childNodes; |
| var length = rawChildNodes.length; |
| var i = 0; |
| while (i < length) { |
| var rawChild = rawChildNodes[i]; |
| if (rawChild.nodeType === 8) { |
| if (rawChild.data === '!') { |
| var placeholder = document.createTextNode(''); |
| dom.replaceChild(placeholder, rawChild); |
| i++; |
| } |
| else { |
| dom.removeChild(rawChild); |
| length--; |
| } |
| } |
| else { |
| i++; |
| } |
| } |
| } |
| function hydrateComponent(vNode, dom, lifecycle, context, isSVG, isClass) { |
| var type = vNode.type; |
| var props = vNode.props || {}; |
| var ref = vNode.ref; |
| vNode.dom = dom; |
| if (isClass) { |
| var _isSVG = dom.namespaceURI === svgNS; |
| var defaultProps = type.defaultProps; |
| lifecycle.fastUnmount = false; |
| if (!isUndefined(defaultProps)) { |
| copyPropsTo(defaultProps, props); |
| vNode.props = props; |
| } |
| var instance = createStatefulComponentInstance(vNode, type, props, context, _isSVG, devToolsStatus); |
| var input = instance._lastInput; |
| var fastUnmount = lifecycle.fastUnmount; |
| // we store the fastUnmount value, but we set it back to true on the lifecycle |
| // we do this so we can determine if the component render has a fastUnmount or not |
| lifecycle.fastUnmount = true; |
| instance._vComponent = vNode; |
| instance._vNode = vNode; |
| hydrate(input, dom, lifecycle, instance._childContext, _isSVG); |
| var subLifecycle = instance._lifecycle = new Lifecycle(); |
| subLifecycle.fastUnmount = lifecycle.fastUnmount; |
| // we then set the lifecycle fastUnmount value back to what it was before the mount |
| lifecycle.fastUnmount = fastUnmount; |
| mountStatefulComponentCallbacks(ref, instance, lifecycle); |
| findDOMNodeEnabled && componentToDOMNodeMap.set(instance, dom); |
| vNode.children = instance; |
| } |
| else { |
| var input$1 = createStatelessComponentInput(vNode, type, props, context); |
| hydrate(input$1, dom, lifecycle, context, isSVG); |
| vNode.children = input$1; |
| vNode.dom = input$1.dom; |
| mountStatelessComponentCallbacks(ref, dom, lifecycle); |
| } |
| } |
| function hydrateElement(vNode, dom, lifecycle, context, isSVG) { |
| var tag = vNode.type; |
| var children = vNode.children; |
| var props = vNode.props; |
| var events = vNode.events; |
| var flags = vNode.flags; |
| if (isSVG || (flags & 128 /* SvgElement */)) { |
| isSVG = true; |
| } |
| if (dom.nodeType !== 1 || dom.tagName.toLowerCase() !== tag) { |
| var newDom = mountElement(vNode, null, lifecycle, context, isSVG); |
| vNode.dom = newDom; |
| replaceChild(dom.parentNode, newDom, dom); |
| } |
| else { |
| vNode.dom = dom; |
| if (children) { |
| hydrateChildren(children, dom, lifecycle, context, isSVG); |
| } |
| if (!(flags & 2 /* HtmlElement */)) { |
| processElement(flags, vNode, dom); |
| } |
| for (var prop in props) { |
| patchProp(prop, null, props[prop], dom, isSVG, lifecycle); |
| } |
| for (var name in events) { |
| patchEvent(name, null, events[name], dom, lifecycle); |
| } |
| } |
| } |
| function hydrateChildren(children, dom, lifecycle, context, isSVG) { |
| normaliseChildNodes(dom); |
| var domNodes = Array.prototype.slice.call(dom.childNodes); |
| var childNodeIndex = 0; |
| if (isArray(children)) { |
| for (var i = 0; i < children.length; i++) { |
| var child = children[i]; |
| if (isObject(child) && !isNull(child)) { |
| hydrate(child, domNodes[childNodeIndex++], lifecycle, context, isSVG); |
| } |
| } |
| } |
| else if (isObject(children)) { |
| hydrate(children, dom.firstChild, lifecycle, context, isSVG); |
| } |
| } |
| function hydrateText(vNode, dom) { |
| if (dom.nodeType === 3) { |
| var newDom = mountText(vNode, null); |
| vNode.dom = newDom; |
| replaceChild(dom.parentNode, newDom, dom); |
| } |
| else { |
| vNode.dom = dom; |
| } |
| } |
| function hydrateVoid(vNode, dom) { |
| vNode.dom = dom; |
| } |
| function hydrate(vNode, dom, lifecycle, context, isSVG) { |
| if (false) { |
| if (isInvalid(dom)) { |
| throwError("failed to hydrate. The server-side render doesn't match client side."); |
| } |
| } |
| var flags = vNode.flags; |
| if (flags & 28 /* Component */) { |
| return hydrateComponent(vNode, dom, lifecycle, context, isSVG, flags & 4 /* ComponentClass */); |
| } |
| else if (flags & 3970 /* Element */) { |
| return hydrateElement(vNode, dom, lifecycle, context, isSVG); |
| } |
| else if (flags & 1 /* Text */) { |
| return hydrateText(vNode, dom); |
| } |
| else if (flags & 4096 /* Void */) { |
| return hydrateVoid(vNode, dom); |
| } |
| else { |
| if (false) { |
| throwError(("hydrate() expects a valid VNode, instead it received an object with the type \"" + (typeof vNode) + "\".")); |
| } |
| throwError(); |
| } |
| } |
| function hydrateRoot(input, parentDom, lifecycle) { |
| if (parentDom && parentDom.nodeType === 1 && parentDom.firstChild) { |
| hydrate(input, parentDom.firstChild, lifecycle, {}, false); |
| return true; |
| } |
| return false; |
| } |
| |
| // rather than use a Map, like we did before, we can use an array here |
| // given there shouldn't be THAT many roots on the page, the difference |
| // in performance is huge: https://esbench.com/bench/5802a691330ab09900a1a2da |
| var roots = []; |
| var componentToDOMNodeMap = new Map(); |
| var findDOMNodeEnabled = false; |
| function enableFindDOMNode() { |
| findDOMNodeEnabled = true; |
| } |
| function findDOMNode(ref) { |
| if (!findDOMNodeEnabled) { |
| if (false) { |
| throwError('findDOMNode() has been disabled, use enableFindDOMNode() enabled findDOMNode(). Warning this can significantly impact performance!'); |
| } |
| throwError(); |
| } |
| var dom = ref && ref.nodeType ? ref : null; |
| return componentToDOMNodeMap.get(ref) || dom; |
| } |
| function getRoot(dom) { |
| for (var i = 0; i < roots.length; i++) { |
| var root = roots[i]; |
| if (root.dom === dom) { |
| return root; |
| } |
| } |
| return null; |
| } |
| function setRoot(dom, input, lifecycle) { |
| roots.push({ |
| dom: dom, |
| input: input, |
| lifecycle: lifecycle |
| }); |
| } |
| function removeRoot(root) { |
| for (var i = 0; i < roots.length; i++) { |
| if (roots[i] === root) { |
| roots.splice(i, 1); |
| return; |
| } |
| } |
| } |
| var documentBody = isBrowser ? document.body : null; |
| function render(input, parentDom) { |
| if (documentBody === parentDom) { |
| if (false) { |
| throwError('you cannot render() to the "document.body". Use an empty element as a container instead.'); |
| } |
| throwError(); |
| } |
| if (input === NO_OP) { |
| return; |
| } |
| var root = getRoot(parentDom); |
| if (isNull(root)) { |
| var lifecycle = new Lifecycle(); |
| if (!isInvalid(input)) { |
| if (input.dom) { |
| input = cloneVNode(input); |
| } |
| if (!hydrateRoot(input, parentDom, lifecycle)) { |
| mount(input, parentDom, lifecycle, {}, false); |
| } |
| lifecycle.trigger(); |
| setRoot(parentDom, input, lifecycle); |
| } |
| } |
| else { |
| var lifecycle$1 = root.lifecycle; |
| lifecycle$1.listeners = []; |
| if (isNullOrUndef(input)) { |
| unmount(root.input, parentDom, lifecycle$1, false, false, false); |
| removeRoot(root); |
| } |
| else { |
| if (input.dom) { |
| input = cloneVNode(input); |
| } |
| patch(root.input, input, parentDom, lifecycle$1, {}, false, false); |
| } |
| lifecycle$1.trigger(); |
| root.input = input; |
| } |
| if (devToolsStatus.connected) { |
| sendRoots(window); |
| } |
| } |
| function createRenderer() { |
| var parentDom; |
| return function renderer(lastInput, nextInput) { |
| if (!parentDom) { |
| parentDom = lastInput; |
| } |
| render(nextInput, parentDom); |
| }; |
| } |
| |
| function linkEvent(data, event) { |
| return { data: data, event: event }; |
| } |
| |
| if (isBrowser) { |
| window.process = { |
| env: { |
| NODE_ENV: 'development' |
| } |
| }; |
| initDevToolsHooks(window); |
| } |
| |
| if (false) { |
| var testFunc = function testFn() {}; |
| warning( |
| (testFunc.name || testFunc.toString()).indexOf('testFn') !== -1, |
| 'It looks like you\'re using a minified copy of the development build ' + |
| 'of Inferno. When deploying Inferno apps to production, make sure to use ' + |
| 'the production build which skips development warnings and is faster. ' + |
| 'See http://infernojs.org for more details.' |
| ); |
| } |
| |
| // we duplicate it so it plays nicely with different module loading systems |
| var index = { |
| linkEvent: linkEvent, |
| // core shapes |
| createVNode: createVNode, |
| |
| // cloning |
| cloneVNode: cloneVNode, |
| |
| // used to shared common items between Inferno libs |
| NO_OP: NO_OP, |
| EMPTY_OBJ: EMPTY_OBJ, |
| |
| //DOM |
| render: render, |
| findDOMNode: findDOMNode, |
| createRenderer: createRenderer, |
| disableRecycling: disableRecycling, |
| enableFindDOMNode: enableFindDOMNode |
| }; |
| |
| exports['default'] = index; |
| exports.linkEvent = linkEvent; |
| exports.createVNode = createVNode; |
| exports.cloneVNode = cloneVNode; |
| exports.NO_OP = NO_OP; |
| exports.EMPTY_OBJ = EMPTY_OBJ; |
| exports.render = render; |
| exports.findDOMNode = findDOMNode; |
| exports.createRenderer = createRenderer; |
| exports.disableRecycling = disableRecycling; |
| exports.enableFindDOMNode = enableFindDOMNode; |
| |
| Object.defineProperty(exports, '__esModule', { value: true }); |
| |
| }))); |
| |
| |
| /***/ }, |
| /* 3 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| module.exports = __webpack_require__(4); |
| |
| |
| /***/ }, |
| /* 4 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /*! |
| * inferno-component v1.0.0-beta32 |
| * (c) 2016 Dominic Gannaway |
| * Released under the MIT License. |
| */ |
| (function (global, factory) { |
| true ? module.exports = factory(__webpack_require__(2)) : |
| typeof define === 'function' && define.amd ? define(['inferno'], factory) : |
| (global.Inferno = global.Inferno || {}, global.Inferno.Component = factory(global.Inferno)); |
| }(this, (function (inferno) { 'use strict'; |
| |
| var ERROR_MSG = 'a runtime error occured! Use Inferno in development environment to find the error.'; |
| |
| |
| // this is MUCH faster than .constructor === Array and instanceof Array |
| // in Node 7 and the later versions of V8, slower in older versions though |
| var isArray = Array.isArray; |
| |
| |
| function isNullOrUndef(obj) { |
| return isUndefined(obj) || isNull(obj); |
| } |
| function isInvalid(obj) { |
| return isNull(obj) || obj === false || isTrue(obj) || isUndefined(obj); |
| } |
| function isFunction(obj) { |
| return typeof obj === 'function'; |
| } |
| |
| |
| |
| function isNull(obj) { |
| return obj === null; |
| } |
| function isTrue(obj) { |
| return obj === true; |
| } |
| function isUndefined(obj) { |
| return obj === undefined; |
| } |
| |
| function throwError(message) { |
| if (!message) { |
| message = ERROR_MSG; |
| } |
| throw new Error(("Inferno Error: " + message)); |
| } |
| |
| var Lifecycle = function Lifecycle() { |
| this.listeners = []; |
| this.fastUnmount = true; |
| }; |
| Lifecycle.prototype.addListener = function addListener (callback) { |
| this.listeners.push(callback); |
| }; |
| Lifecycle.prototype.trigger = function trigger () { |
| var this$1 = this; |
| |
| for (var i = 0; i < this.listeners.length; i++) { |
| this$1.listeners[i](); |
| } |
| }; |
| |
| var noOp = ERROR_MSG; |
| if (false) { |
| noOp = 'Inferno Error: Can only update a mounted or mounting component. This usually means you called setState() or forceUpdate() on an unmounted component. This is a no-op.'; |
| } |
| var componentCallbackQueue = new Map(); |
| // when a components root VNode is also a component, we can run into issues |
| // this will recursively look for vNode.parentNode if the VNode is a component |
| function updateParentComponentVNodes(vNode, dom) { |
| if (vNode.flags & 28 /* Component */) { |
| var parentVNode = vNode.parentVNode; |
| if (parentVNode) { |
| parentVNode.dom = dom; |
| updateParentComponentVNodes(parentVNode, dom); |
| } |
| } |
| } |
| // this is in shapes too, but we don't want to import from shapes as it will pull in a duplicate of createVNode |
| function createVoidVNode() { |
| return inferno.createVNode(4096 /* Void */); |
| } |
| function addToQueue(component, force, callback) { |
| // TODO this function needs to be revised and improved on |
| var queue = componentCallbackQueue.get(component); |
| if (!queue) { |
| queue = []; |
| componentCallbackQueue.set(component, queue); |
| Promise.resolve().then(function () { |
| applyState(component, force, function () { |
| for (var i = 0; i < queue.length; i++) { |
| queue[i](); |
| } |
| }); |
| componentCallbackQueue.delete(component); |
| component._processingSetState = false; |
| }); |
| } |
| if (callback) { |
| queue.push(callback); |
| } |
| } |
| function queueStateChanges(component, newState, callback) { |
| if (isFunction(newState)) { |
| newState = newState(component.state); |
| } |
| for (var stateKey in newState) { |
| component._pendingState[stateKey] = newState[stateKey]; |
| } |
| if (!component._pendingSetState) { |
| if (component._processingSetState || callback) { |
| addToQueue(component, false, callback); |
| } |
| else { |
| component._pendingSetState = true; |
| component._processingSetState = true; |
| applyState(component, false, callback); |
| component._processingSetState = false; |
| } |
| } |
| else { |
| component.state = Object.assign({}, component.state, component._pendingState); |
| component._pendingState = {}; |
| } |
| } |
| function applyState(component, force, callback) { |
| if ((!component._deferSetState || force) && !component._blockRender) { |
| component._pendingSetState = false; |
| var pendingState = component._pendingState; |
| var prevState = component.state; |
| var nextState = Object.assign({}, prevState, pendingState); |
| var props = component.props; |
| var context = component.context; |
| component._pendingState = {}; |
| var nextInput = component._updateComponent(prevState, nextState, props, props, context, force); |
| var didUpdate = true; |
| if (isInvalid(nextInput)) { |
| nextInput = createVoidVNode(); |
| } |
| else if (isArray(nextInput)) { |
| if (false) { |
| throwError('a valid Inferno VNode (or null) must be returned from a component render. You may have returned an array or an invalid object.'); |
| } |
| throwError(); |
| } |
| else if (nextInput === inferno.NO_OP) { |
| nextInput = component._lastInput; |
| didUpdate = false; |
| } |
| var lastInput = component._lastInput; |
| var parentDom = lastInput.dom.parentNode; |
| component._lastInput = nextInput; |
| if (didUpdate) { |
| var subLifecycle = component._lifecycle; |
| if (!subLifecycle) { |
| subLifecycle = new Lifecycle(); |
| } |
| else { |
| subLifecycle.listeners = []; |
| } |
| component._lifecycle = subLifecycle; |
| var childContext = component.getChildContext(); |
| if (!isNullOrUndef(childContext)) { |
| childContext = Object.assign({}, context, component._childContext, childContext); |
| } |
| else { |
| childContext = Object.assign({}, context, component._childContext); |
| } |
| component._patch(lastInput, nextInput, parentDom, subLifecycle, childContext, component._isSVG, false); |
| subLifecycle.trigger(); |
| component.componentDidUpdate(props, prevState); |
| } |
| var vNode = component._vNode; |
| var dom = vNode.dom = nextInput.dom; |
| var componentToDOMNodeMap = component._componentToDOMNodeMap; |
| componentToDOMNodeMap && componentToDOMNodeMap.set(component, nextInput.dom); |
| updateParentComponentVNodes(vNode, dom); |
| if (!isNullOrUndef(callback)) { |
| callback(); |
| } |
| } |
| } |
| var Component$1 = function Component$1(props, context) { |
| this.state = {}; |
| this.refs = {}; |
| this._processingSetState = false; |
| this._blockRender = false; |
| this._ignoreSetState = false; |
| this._blockSetState = false; |
| this._deferSetState = false; |
| this._pendingSetState = false; |
| this._pendingState = {}; |
| this._lastInput = null; |
| this._vNode = null; |
| this._unmounted = true; |
| this._devToolsStatus = null; |
| this._devToolsId = null; |
| this._lifecycle = null; |
| this._childContext = null; |
| this._patch = null; |
| this._isSVG = false; |
| this._componentToDOMNodeMap = null; |
| /** @type {object} */ |
| this.props = props || inferno.EMPTY_OBJ; |
| /** @type {object} */ |
| this.context = context || {}; |
| if (!this.componentDidMount) { |
| this.componentDidMount = null; |
| } |
| }; |
| Component$1.prototype.render = function render (nextProps, nextState, nextContext) { |
| }; |
| Component$1.prototype.forceUpdate = function forceUpdate (callback) { |
| if (this._unmounted) { |
| throw Error(noOp); |
| } |
| applyState(this, true, callback); |
| }; |
| Component$1.prototype.setState = function setState (newState, callback) { |
| if (this._unmounted) { |
| throw Error(noOp); |
| } |
| if (!this._blockSetState) { |
| if (!this._ignoreSetState) { |
| queueStateChanges(this, newState, callback); |
| } |
| } |
| else { |
| if (false) { |
| throwError('cannot update state via setState() in componentWillUpdate().'); |
| } |
| throwError(); |
| } |
| }; |
| Component$1.prototype.componentWillMount = function componentWillMount () { |
| }; |
| Component$1.prototype.componentDidMount = function componentDidMount () { |
| }; |
| Component$1.prototype.componentWillUnmount = function componentWillUnmount () { |
| }; |
| Component$1.prototype.componentDidUpdate = function componentDidUpdate (prevProps, prevState, prevContext) { |
| }; |
| Component$1.prototype.shouldComponentUpdate = function shouldComponentUpdate (nextProps, nextState, context) { |
| return true; |
| }; |
| Component$1.prototype.componentWillReceiveProps = function componentWillReceiveProps (nextProps, context) { |
| }; |
| Component$1.prototype.componentWillUpdate = function componentWillUpdate (nextProps, nextState, nextContext) { |
| }; |
| Component$1.prototype.getChildContext = function getChildContext () { |
| }; |
| Component$1.prototype._updateComponent = function _updateComponent (prevState, nextState, prevProps, nextProps, context, force) { |
| if (this._unmounted === true) { |
| if (false) { |
| throwError(noOp); |
| } |
| throwError(); |
| } |
| if ((prevProps !== nextProps || nextProps === inferno.EMPTY_OBJ) || prevState !== nextState || force) { |
| if (prevProps !== nextProps || nextProps === inferno.EMPTY_OBJ) { |
| this._blockRender = true; |
| this.componentWillReceiveProps(nextProps, context); |
| this._blockRender = false; |
| if (this._pendingSetState) { |
| nextState = Object.assign({}, nextState, this._pendingState); |
| this._pendingSetState = false; |
| this._pendingState = {}; |
| } |
| } |
| var shouldUpdate = this.shouldComponentUpdate(nextProps, nextState, context); |
| if (shouldUpdate !== false || force) { |
| this._blockSetState = true; |
| this.componentWillUpdate(nextProps, nextState, context); |
| this._blockSetState = false; |
| this.props = nextProps; |
| var state = this.state = nextState; |
| this.context = context; |
| this._beforeRender && this._beforeRender(); |
| var render = this.render(nextProps, state, context); |
| this._afterRender && this._afterRender(); |
| return render; |
| } |
| } |
| return inferno.NO_OP; |
| }; |
| |
| return Component$1; |
| |
| }))); |
| |
| |
| /***/ }, |
| /* 5 */ |
| /***/ function(module, exports) { |
| |
| 'use strict'; |
| |
| exports.__esModule = true; |
| exports.read = read; |
| exports.assign = assign; |
| exports.isEqual = isEqual; |
| /** |
| * Shared funcs/values |
| */ |
| |
| var ENTER = exports.ENTER = 13; |
| var ESCAPE = exports.ESCAPE = 27; |
| |
| var filters = exports.filters = { |
| all: function all(t) { |
| return true; |
| }, |
| active: function active(t) { |
| return !t.completed; |
| }, |
| completed: function completed(t) { |
| return t.completed; |
| } |
| }; |
| |
| /** |
| * Read the `location.hash` value |
| * @return {String} |
| */ |
| function read() { |
| return location.hash.replace('#/', '') || 'all'; |
| } |
| |
| /** |
| * Modified `Object.assign` shim |
| * - always writes to new object |
| * @return {Object} |
| */ |
| function assign() { |
| var src = void 0; |
| var tar = {}; |
| for (var s = 0; s < arguments.length; s++) { |
| src = Object(arguments[s]); |
| for (var k in src) { |
| tar[k] = src[k]; |
| } |
| } |
| return tar; |
| } |
| |
| /** |
| * Are two Objects equal values? |
| * @param {Object} a |
| * @param {Object} b |
| * @return {Boolean} |
| */ |
| function isEqual(a, b) { |
| // Create arrays of property names |
| var aProps = Object.getOwnPropertyNames(a); |
| var bProps = Object.getOwnPropertyNames(b); |
| |
| if (aProps.length !== bProps.length) return false; |
| |
| for (var i = 0; i < aProps.length; i++) { |
| var k = aProps[i]; |
| if (a[k] !== b[k]) return false; |
| } |
| |
| return true; |
| } |
| |
| /***/ }, |
| /* 6 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict'; |
| |
| exports.__esModule = true; |
| exports.links = undefined; |
| exports.Head = Head; |
| exports.Foot = Foot; |
| |
| var _inferno = __webpack_require__(1); |
| |
| var _inferno2 = _interopRequireDefault(_inferno); |
| |
| var _share = __webpack_require__(5); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
| |
| /** |
| * Stateless Header component |
| */ |
| function Head(_ref) { |
| var onEnter = _ref.onEnter; |
| |
| return _inferno2.default.createVNode(2, 'header', { |
| 'className': 'header' |
| }, [_inferno2.default.createVNode(2, 'h1', null, 'todos'), _inferno2.default.createVNode(512, 'input', { |
| 'className': 'new-todo', |
| 'autofocus': true, |
| 'autocomplete': 'off', |
| 'placeholder': 'What needs to be done?' |
| }, null, { |
| 'onkeydown': onEnter |
| })]); |
| } |
| |
| var links = exports.links = [{ hash: '#/', name: 'All' }, { hash: '#/active', name: 'Active' }, { hash: '#/completed', name: 'Completed' }]; |
| |
| /** |
| * Stateless Footer component |
| */ |
| function Foot(_ref2) { |
| var left = _ref2.left, |
| done = _ref2.done, |
| route = _ref2.route, |
| onClear = _ref2.onClear; |
| |
| return _inferno2.default.createVNode(2, 'footer', { |
| 'className': 'footer' |
| }, [_inferno2.default.createVNode(2, 'span', { |
| 'className': 'todo-count' |
| }, [_inferno2.default.createVNode(2, 'strong', null, left), ' ', left > 1 ? 'items' : 'item', ' left']), _inferno2.default.createVNode(2, 'ul', { |
| 'className': 'filters' |
| }, links.map(function (_ref3) { |
| var hash = _ref3.hash, |
| name = _ref3.name; |
| return _inferno2.default.createVNode(2, 'li', null, _inferno2.default.createVNode(2, 'a', { |
| 'href': hash, |
| 'className': name.toLowerCase() === route ? 'selected' : '' |
| }, name)); |
| })), done > 0 ? _inferno2.default.createVNode(2, 'button', { |
| 'className': 'clear-completed' |
| }, 'Clear completed', { |
| 'onClick': onClear |
| }) : null]); |
| } |
| |
| /***/ }, |
| /* 7 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict'; |
| |
| exports.__esModule = true; |
| |
| var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; |
| |
| var _share = __webpack_require__(5); |
| |
| function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
| |
| var STOR = {}; |
| var STOR_ID = 'todos-inferno'; |
| |
| var Model = function Model() { |
| var _this = this; |
| |
| _classCallCheck(this, Model); |
| |
| this.get = function () { |
| return _this.data = JSON.parse(STOR[STOR_ID] || '[]'); |
| }; |
| |
| this.set = function (arr) { |
| _this.data = arr || _this.data || []; |
| STOR[STOR_ID] = JSON.stringify(_this.data); |
| return _this.data; |
| }; |
| |
| this.add = function (str) { |
| return _this.set(_this.data.concat({ title: str, completed: false })); |
| }; |
| |
| this.put = function (todo, obj) { |
| return _this.set(_this.data.map(function (t) { |
| return (0, _share.isEqual)(t, todo) ? (0, _share.assign)(todo, obj) : t; |
| })); |
| }; |
| |
| this.del = function (todo) { |
| return _this.set(_this.data.filter(function (t) { |
| return !(0, _share.isEqual)(t, todo); |
| })); |
| }; |
| |
| this.toggle = function (todo) { |
| return _this.put(todo, { completed: !todo.completed }); |
| }; |
| |
| this.toggleAll = function (completed) { |
| return _this.set(_this.data.map(function (t) { |
| return _extends({}, t, { completed: completed }); |
| })); |
| }; |
| |
| this.clearCompleted = function () { |
| return _this.set(_this.data.filter(function (t) { |
| return !t.completed; |
| })); |
| }; |
| }; |
| |
| exports.default = Model; |
| |
| /***/ }, |
| /* 8 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict'; |
| |
| exports.__esModule = true; |
| |
| var _inferno = __webpack_require__(1); |
| |
| var _inferno2 = _interopRequireDefault(_inferno); |
| |
| var _infernoComponent = __webpack_require__(3); |
| |
| var _infernoComponent2 = _interopRequireDefault(_infernoComponent); |
| |
| var _share = __webpack_require__(5); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
| |
| function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } |
| |
| function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
| |
| function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } |
| |
| function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } |
| |
| var Item = function (_Component) { |
| _inherits(Item, _Component); |
| |
| function Item(_ref) { |
| var data = _ref.data, |
| props = _objectWithoutProperties(_ref, ['data']); |
| |
| _classCallCheck(this, Item); |
| |
| var _this = _possibleConstructorReturn(this, _Component.call(this, props)); |
| |
| _initialiseProps.call(_this); |
| |
| _this.todo = data; |
| _this.state = { text: data.title }; |
| _this.editor = null; |
| return _this; |
| } |
| |
| Item.prototype.render = function render(_ref2, _ref3) { |
| var _this2 = this; |
| |
| var doToggle = _ref2.doToggle, |
| doDelete = _ref2.doDelete, |
| doSave = _ref2.doSave, |
| onBlur = _ref2.onBlur, |
| onFocus = _ref2.onFocus; |
| var text = _ref3.text; |
| var _todo = this.todo, |
| title = _todo.title, |
| completed = _todo.completed, |
| editing = _todo.editing; |
| |
| |
| var cls = []; |
| editing && cls.push('editing'); |
| completed && cls.push('completed'); |
| |
| var handleKeydown = function handleKeydown(e) { |
| if (e.which === _share.ESCAPE) return onBlur(); |
| if (e.which === _share.ENTER) return doSave(text); |
| }; |
| |
| // tmp fix |
| var handleBlur = function handleBlur() { |
| return doSave(text); |
| }; |
| var handleInput = function handleInput(e) { |
| return _this2.setText(e.target.value); |
| }; |
| |
| return _inferno2.default.createVNode(2, 'li', { |
| 'className': cls.join(' ') |
| }, [_inferno2.default.createVNode(2, 'div', { |
| 'className': 'view' |
| }, [_inferno2.default.createVNode(512, 'input', { |
| 'className': 'toggle', |
| 'type': 'checkbox', |
| 'checked': completed |
| }, null, { |
| 'onClick': doToggle |
| }), _inferno2.default.createVNode(2, 'label', null, title, { |
| 'ondblclick': onFocus |
| }), _inferno2.default.createVNode(2, 'button', { |
| 'className': 'destroy' |
| }, null, { |
| 'onClick': doDelete |
| })]), _inferno2.default.createVNode(512, 'input', { |
| 'className': 'edit', |
| 'value': editing && text |
| }, null, { |
| 'onblur': handleBlur, |
| 'oninput': handleInput, |
| 'onkeydown': handleKeydown |
| }, null, function (el) { |
| _this2.editor = el; |
| })]); |
| }; |
| |
| return Item; |
| }(_infernoComponent2.default); |
| |
| var _initialiseProps = function _initialiseProps() { |
| var _this3 = this; |
| |
| this.componentWillReceiveProps = function (_ref4) { |
| var data = _ref4.data; |
| return _this3.setText(data.title); |
| }; |
| |
| this.shouldComponentUpdate = function (_ref5, _ref6) { |
| var data = _ref5.data; |
| var text = _ref6.text; |
| return !((0, _share.isEqual)(data, _this3.todo) && text === _this3.state.text); |
| }; |
| |
| this.componentWillUpdate = function (_ref7) { |
| var data = _ref7.data; |
| return _this3.todo = data; |
| }; |
| |
| this.componentDidUpdate = function () { |
| return _this3.editor.focus(); |
| }; |
| |
| this.setText = function (text) { |
| return _this3.setState({ text: text }); |
| }; |
| }; |
| |
| exports.default = Item; |
| |
| /***/ } |
| /******/ ]); |