Comparing version 0.1.4 to 0.2.0
328
lib/karet.js
@@ -12,6 +12,2 @@ "use strict"; | ||
var _ramda = require("ramda"); | ||
var R = _interopRequireWildcard(_ramda); | ||
var _react = require("react"); | ||
@@ -25,4 +21,2 @@ | ||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } | ||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } | ||
@@ -38,2 +32,12 @@ | ||
var emptyArray = []; | ||
var dissoc = function dissoc(k, o) { | ||
var r = Object.assign({}, o); | ||
delete r[k]; | ||
return r; | ||
}; | ||
// | ||
var LiftedComponent = function (_React$Component) { | ||
@@ -45,6 +49,3 @@ _inherits(LiftedComponent, _React$Component); | ||
var _this = _possibleConstructorReturn(this, (LiftedComponent.__proto__ || Object.getPrototypeOf(LiftedComponent)).call(this, props)); | ||
_this.state = _this.theInitialState(); | ||
return _this; | ||
return _possibleConstructorReturn(this, (LiftedComponent.__proto__ || Object.getPrototypeOf(LiftedComponent)).call(this, props)); | ||
} | ||
@@ -61,21 +62,9 @@ | ||
value: function componentWillMount() { | ||
this.doUnsubscribe(); | ||
this.doSubscribe(this.props); | ||
} | ||
}, { | ||
key: "shouldComponentUpdate", | ||
value: function shouldComponentUpdate(np, ns) { | ||
return ns.rendered !== this.state.rendered; | ||
} | ||
}, { | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
this.doUnsubscribe(); | ||
this.setState(this.theInitialState()); | ||
} | ||
}, { | ||
key: "render", | ||
value: function render() { | ||
return this.state.rendered; | ||
} | ||
}]); | ||
@@ -88,5 +77,2 @@ | ||
var FromKefirEnd = { callback: null }; | ||
var FromKefirNull = { callback: null, rendered: null }; | ||
var FromKefir = function (_LiftedComponent) { | ||
@@ -98,15 +84,13 @@ _inherits(FromKefir, _LiftedComponent); | ||
return _possibleConstructorReturn(this, (FromKefir.__proto__ || Object.getPrototypeOf(FromKefir)).call(this, props)); | ||
var _this2 = _possibleConstructorReturn(this, (FromKefir.__proto__ || Object.getPrototypeOf(FromKefir)).call(this, props)); | ||
_this2.callback = null; | ||
_this2.rendered = null; | ||
return _this2; | ||
} | ||
_createClass(FromKefir, [{ | ||
key: "theInitialState", | ||
value: function theInitialState() { | ||
return FromKefirNull; | ||
} | ||
}, { | ||
key: "doUnsubscribe", | ||
value: function doUnsubscribe() { | ||
var callback = this.state.callback; | ||
var callback = this.callback; | ||
if (callback) this.props.observable.offAny(callback); | ||
@@ -125,3 +109,4 @@ } | ||
case "value": | ||
_this3.setState({ rendered: e.value }); | ||
_this3.rendered = e.value; | ||
_this3.forceUpdate(); | ||
break; | ||
@@ -131,12 +116,16 @@ case "error": | ||
case "end": | ||
_this3.setState(FromKefirEnd); | ||
break; | ||
_this3.callback = null; | ||
} | ||
}; | ||
this.callback = callback; | ||
observable.onAny(callback); | ||
this.setState({ callback: callback }); | ||
} else { | ||
this.setState({ rendered: observable }); | ||
this.rendered = observable; | ||
} | ||
} | ||
}, { | ||
key: "render", | ||
value: function render() { | ||
return this.rendered; | ||
} | ||
}]); | ||
@@ -190,5 +179,3 @@ | ||
var empty = []; | ||
function render(props, values) { | ||
function _render(props, values) { | ||
var type = void 0; | ||
@@ -251,3 +238,3 @@ var newProps = null; | ||
} | ||
return _react2.default.createElement.apply(_react2.default, [type, newProps].concat(_toConsumableArray(newChildren || empty))); | ||
return _react2.default.createElement.apply(_react2.default, [type, newProps].concat(_toConsumableArray(newChildren || emptyArray))); | ||
} | ||
@@ -257,125 +244,2 @@ | ||
function FakeComponent(state, props) { | ||
this.props = props; | ||
this.state = state; | ||
} | ||
FakeComponent.prototype.setState = function (newState) { | ||
if ("renderer" in newState) this.state.renderer = newState.renderer; | ||
if ("rendered" in newState) this.state.rendered = newState.rendered; | ||
}; | ||
// | ||
function Renderer1(component, newProps) { | ||
var _this4 = this; | ||
var state = { renderer: this, rendered: component.state.rendered }; | ||
this.component = new FakeComponent(state, newProps); | ||
this.handler = function (e) { | ||
return _this4.doHandle(e); | ||
}; | ||
forEach(newProps, function (observable) { | ||
return observable.onAny(_this4.handler); | ||
}); | ||
this.component = component; | ||
component.setState(state); | ||
} | ||
Renderer1.prototype.unsubscribe = function () { | ||
var handler = this.handler; | ||
if (handler) forEach(this.component.props, function (observable) { | ||
return observable.offAny(handler); | ||
}); | ||
}; | ||
Renderer1.prototype.doHandle = function (e) { | ||
switch (e.type) { | ||
case "value": | ||
{ | ||
var component = this.component; | ||
var rendered = render(component.props, [e.value]); | ||
if (!R.equals(component.state.rendered, rendered)) component.setState({ rendered: rendered }); | ||
return; | ||
} | ||
case "error": | ||
throw e.value; | ||
default: | ||
this.handler = null; | ||
this.component.setState(FromClassEnd); | ||
return; | ||
} | ||
}; | ||
// | ||
function RendererN(component, newProps, n) { | ||
var _this5 = this; | ||
var state = { renderer: this, rendered: component.state.rendered }; | ||
this.component = new FakeComponent(state, newProps); | ||
this.handlers = []; | ||
this.values = Array(n); | ||
for (var i = 0; i < n; ++i) { | ||
this.values[i] = this; | ||
}forEach(newProps, function (observable) { | ||
var i = _this5.handlers.length; | ||
var handler = function handler(e) { | ||
return _this5.doHandle(i, e); | ||
}; | ||
_this5.handlers.push(handler); | ||
observable.onAny(handler); | ||
}); | ||
this.component = component; | ||
component.setState(state); | ||
} | ||
RendererN.prototype.unsubscribe = function () { | ||
var _this6 = this; | ||
var i = -1; | ||
forEach(this.component.props, function (observable) { | ||
var handler = _this6.handlers[++i]; | ||
if (handler) observable.offAny(handler); | ||
}); | ||
}; | ||
RendererN.prototype.doHandle = function (idx, e) { | ||
switch (e.type) { | ||
case "value": | ||
{ | ||
this.values[idx] = e.value; | ||
for (var i = this.values.length - 1; 0 <= i; --i) { | ||
if (this.values[i] === this) return; | ||
}var component = this.component; | ||
var rendered = render(component.props, this.values); | ||
if (!R.equals(component.state.rendered, rendered)) component.setState({ rendered: rendered }); | ||
return; | ||
} | ||
case "error": | ||
throw e.value; | ||
default: | ||
{ | ||
this.handlers[idx] = null; | ||
var n = this.handlers.length; | ||
if (n !== this.values.length) return; | ||
for (var _i2 = 0; _i2 < n; ++_i2) { | ||
if (this.handlers[_i2]) return; | ||
}this.component.setState(FromClassEnd); | ||
return; | ||
} | ||
} | ||
}; | ||
// | ||
var FromClassEnd = { renderer: null }; | ||
var FromClassNull = { renderer: null, rendered: null }; | ||
var FromClass = function (_LiftedComponent2) { | ||
@@ -387,16 +251,30 @@ _inherits(FromClass, _LiftedComponent2); | ||
return _possibleConstructorReturn(this, (FromClass.__proto__ || Object.getPrototypeOf(FromClass)).call(this, props)); | ||
var _this4 = _possibleConstructorReturn(this, (FromClass.__proto__ || Object.getPrototypeOf(FromClass)).call(this, props)); | ||
_this4.values = _this4; | ||
_this4.handlers = null; | ||
return _this4; | ||
} | ||
_createClass(FromClass, [{ | ||
key: "theInitialState", | ||
value: function theInitialState() { | ||
return FromClassNull; | ||
} | ||
}, { | ||
key: "doUnsubscribe", | ||
value: function doUnsubscribe() { | ||
var renderer = this.state.renderer; | ||
var _this5 = this; | ||
if (renderer) renderer.unsubscribe(); | ||
var handlers = this.handlers; | ||
if (handlers) { | ||
if (handlers instanceof Function) { | ||
forEach(this.props, function (obs) { | ||
return obs.offAny(handlers); | ||
}); | ||
} else { | ||
(function () { | ||
var i = -1; | ||
forEach(_this5.props, function (obs) { | ||
var handler = handlers[++i]; | ||
if (handler) obs.offAny(handler); | ||
}); | ||
})(); | ||
} | ||
} | ||
} | ||
@@ -406,16 +284,102 @@ }, { | ||
value: function doSubscribe(props) { | ||
var _this6 = this; | ||
var n = 0; | ||
forEach(props, function () { | ||
return n += 1; | ||
return ++n; | ||
}); | ||
switch (n) { | ||
case 1: | ||
new Renderer1(this, props); | ||
break; | ||
if (n === 1) { | ||
(function () { | ||
_this6.values = _this6; | ||
var handlers = function handlers(e) { | ||
return _this6.doHandle1(e); | ||
}; | ||
_this6.handlers = handlers; | ||
forEach(props, function (obs) { | ||
return obs.onAny(handlers); | ||
}); | ||
})(); | ||
} else { | ||
this.values = Array(n).fill(this); | ||
this.handlers = []; | ||
forEach(props, function (obs) { | ||
var handler = function handler(e) { | ||
return _this6.doHandleN(handler, e); | ||
}; | ||
_this6.handlers.push(handler); | ||
obs.onAny(handler); | ||
}); | ||
} | ||
} | ||
}, { | ||
key: "doHandle1", | ||
value: function doHandle1(e) { | ||
switch (e.type) { | ||
case "value": | ||
{ | ||
var value = e.value; | ||
if (this.values !== value) { | ||
this.values = value; | ||
this.forceUpdate(); | ||
} | ||
break; | ||
} | ||
case "error": | ||
throw e.value; | ||
default: | ||
new RendererN(this, props, n); | ||
break; | ||
{ | ||
this.values = [this.values]; | ||
this.handlers = null; | ||
} | ||
} | ||
} | ||
}, { | ||
key: "doHandleN", | ||
value: function doHandleN(handler, e) { | ||
var handlers = this.handlers; | ||
var idx = 0; | ||
while (handlers[idx] !== handler) { | ||
++idx; | ||
}switch (e.type) { | ||
case "value": | ||
{ | ||
var value = e.value; | ||
var values = this.values; | ||
if (values[idx] !== value) { | ||
values[idx] = value; | ||
this.forceUpdate(); | ||
} | ||
break; | ||
} | ||
case "error": | ||
throw e.value; | ||
default: | ||
{ | ||
handlers[idx] = null; | ||
var n = handlers.length; | ||
if (n !== this.values.length) return; | ||
for (var i = 0; i < n; ++i) { | ||
if (handlers[i]) return; | ||
}this.handlers = null; | ||
} | ||
} | ||
} | ||
}, { | ||
key: "render", | ||
value: function render() { | ||
if (this.handlers instanceof Function) { | ||
var value = this.values; | ||
if (value === this) return null; | ||
return _render(this.props, [value]); | ||
} else { | ||
var values = this.values; | ||
for (var i = 0, n = values.length; i < n; ++i) { | ||
if (values[i] === this) return null; | ||
}return _render(this.props, values); | ||
} | ||
} | ||
}]); | ||
@@ -455,3 +419,3 @@ | ||
} else { | ||
return _react2.default.createElement.apply(_react2.default, [type, R.dissoc("karet-lift", props)].concat(children)); | ||
return _react2.default.createElement.apply(_react2.default, [type, dissoc("karet-lift", props)].concat(children)); | ||
} | ||
@@ -465,2 +429,2 @@ } else { | ||
exports.default = client; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/karet.js"],"names":["R","LiftedComponent","props","state","theInitialState","nextProps","doUnsubscribe","doSubscribe","np","ns","rendered","setState","Component","FromKefirEnd","callback","FromKefirNull","FromKefir","observable","offAny","e","type","value","onAny","fromKefir","createElement","hasObs","key","val","k","valK","forEach","fn","children","constructor","Array","i","length","empty","render","values","newProps","newChildren","n","valI","ref","valO","newStyle","j","style","FakeComponent","prototype","newState","renderer","Renderer1","component","handler","doHandle","unsubscribe","equals","FromClassEnd","RendererN","handlers","push","idx","FromClassNull","FromClass","hasAnyObs","find","x","filterProps","client","dissoc"],"mappings":"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","file":"karet.js","sourcesContent":["import * as R       from \"ramda\"\nimport React        from \"react\"\nimport {Observable} from \"kefir\"\n\n//\n\nclass LiftedComponent extends React.Component {\n  constructor(props) {\n    super(props)\n    this.state = this.theInitialState()\n  }\n  componentWillReceiveProps(nextProps) {\n    this.doUnsubscribe()\n    this.doSubscribe(nextProps)\n  }\n  componentWillMount() {\n    this.doUnsubscribe()\n    this.doSubscribe(this.props)\n  }\n  shouldComponentUpdate(np, ns) {\n    return ns.rendered !== this.state.rendered\n  }\n  componentWillUnmount() {\n    this.doUnsubscribe()\n    this.setState(this.theInitialState())\n  }\n  render() {\n    return this.state.rendered\n  }\n}\n\n//\n\nconst FromKefirEnd = {callback: null}\nconst FromKefirNull = {callback: null, rendered: null}\n\nclass FromKefir extends LiftedComponent {\n  constructor(props) {\n    super(props)\n  }\n  theInitialState() {\n    return FromKefirNull\n  }\n  doUnsubscribe() {\n    const {callback} = this.state\n    if (callback)\n      this.props.observable.offAny(callback)\n  }\n  doSubscribe({observable}) {\n    if (observable instanceof Observable) {\n      const callback = e => {\n        switch (e.type) {\n          case \"value\":\n            this.setState({rendered: e.value})\n            break\n          case \"error\":\n            throw e.value\n          case \"end\":\n            this.setState(FromKefirEnd)\n            break\n        }\n      }\n      observable.onAny(callback)\n      this.setState({callback})\n    } else {\n      this.setState({rendered: observable})\n    }\n  }\n}\n\nexport const fromKefir = observable =>\n  React.createElement(FromKefir, {observable})\n\n//\n\nfunction hasObs(props) {\n  for (const key in props) {\n    const val = props[key]\n    if (val instanceof Observable) {\n      return true\n    } else if (\"style\" === key) {\n      for (const k in val) {\n        const valK = val[k]\n        if (valK instanceof Observable)\n          return true\n      }\n    }\n  }\n  return false\n}\n\nfunction forEach(props, fn) {\n  for (const key in props) {\n    const val = props[key]\n    if (val instanceof Observable) {\n      fn(val)\n    } else if (\"children\" === key) {\n      const children = props[key]\n      if (children.constructor === Array) {\n        for (let i=0; i<children.length; ++i) {\n          const val = children[i]\n          if (val instanceof Observable)\n            fn(val)\n        }\n      }\n    } else if (\"style\" === key) {\n      for (const k in val) {\n        const valK = val[k]\n        if (valK instanceof Observable)\n          fn(valK)\n      }\n    }\n  }\n}\n\nconst empty = []\n\nfunction render(props, values) {\n  let type\n  let newProps = null\n  let newChildren\n\n  let k = -1\n\n  for (const key in props) {\n    const val = props[key]\n    if (\"children\" === key) {\n      if (val instanceof Observable) {\n        newChildren = [values[++k]]\n      } else if (val.constructor === Array) {\n        newChildren = Array(val.length)\n        for (let i=0, n=val.length; i<n; ++i) {\n          const valI = val[i]\n          if (valI instanceof Observable)\n            newChildren[i] = values[++k]\n          else\n            newChildren[i] = valI\n        }\n      } else  {\n        newChildren = [val]\n      }\n    } else if (\"$$ref\" === key) {\n      if (!newProps) newProps = {}\n      if (val instanceof Observable) {\n        newProps.ref = values[++k]\n      } else {\n        newProps.ref = val\n      }\n    } else if (val instanceof Observable) {\n      const valO = values[++k]\n      if (!newProps) newProps = {}\n      newProps[key] = valO\n    } else if (\"style\" === key) {\n      let newStyle\n      for (const i in val) {\n        const valI = val[i]\n        if (valI instanceof Observable) {\n          if (!newStyle) {\n            newStyle = {}\n            for (const j in val) {\n              if (j === i)\n                break\n              newStyle[j] = val[j]\n            }\n          }\n          newStyle[i] = values[++k]\n        } else if (newStyle) {\n          newStyle[i] = valI\n        }\n      }\n      if (!newProps) newProps = {}\n      newProps.style = newStyle || val\n    } else if (\"$$type\" === key) {\n      type = props[key]\n    } else {\n      if (!newProps) newProps = {}\n      newProps[key] = val\n    }\n  }\n  return React.createElement(type, newProps, ...(newChildren || empty))\n}\n\n//\n\nfunction FakeComponent(state, props) {\n  this.props = props\n  this.state = state\n}\n\nFakeComponent.prototype.setState = function (newState) {\n  if (\"renderer\" in newState)\n    this.state.renderer = newState.renderer\n  if (\"rendered\" in newState)\n    this.state.rendered = newState.rendered\n}\n\n//\n\nfunction Renderer1(component, newProps) {\n  const state = {renderer: this, rendered: component.state.rendered}\n  this.component = new FakeComponent(state, newProps)\n  this.handler = e => this.doHandle(e)\n  forEach(newProps, observable => observable.onAny(this.handler))\n  this.component = component\n  component.setState(state)\n}\n\nRenderer1.prototype.unsubscribe = function () {\n  const handler = this.handler\n  if (handler)\n    forEach(this.component.props, observable => observable.offAny(handler))\n}\n\nRenderer1.prototype.doHandle = function (e) {\n  switch (e.type) {\n    case \"value\": {\n      const component = this.component\n      const rendered = render(component.props, [e.value])\n      if (!R.equals(component.state.rendered, rendered))\n        component.setState({rendered})\n      return\n    }\n    case \"error\":\n      throw e.value\n    default:\n      this.handler = null\n      this.component.setState(FromClassEnd)\n      return\n  }\n}\n\n//\n\nfunction RendererN(component, newProps, n) {\n  const state = {renderer: this, rendered: component.state.rendered}\n  this.component = new FakeComponent(state, newProps)\n  this.handlers = []\n  this.values = Array(n)\n\n  for (let i=0; i<n; ++i)\n    this.values[i] = this\n\n  forEach(newProps, observable => {\n    const i = this.handlers.length\n    const handler = e => this.doHandle(i, e)\n    this.handlers.push(handler)\n    observable.onAny(handler)\n  })\n\n  this.component = component\n  component.setState(state)\n}\n\nRendererN.prototype.unsubscribe = function () {\n  let i = -1\n  forEach(this.component.props, observable => {\n    const handler = this.handlers[++i]\n    if (handler)\n      observable.offAny(handler)\n  })\n}\n\nRendererN.prototype.doHandle = function (idx, e) {\n  switch (e.type) {\n    case \"value\": {\n      this.values[idx] = e.value\n\n      for (let i=this.values.length-1; 0 <= i; --i)\n        if (this.values[i] === this)\n          return\n\n      const component = this.component\n      const rendered = render(component.props, this.values)\n      if (!R.equals(component.state.rendered, rendered))\n        component.setState({rendered})\n      return\n    }\n    case \"error\":\n      throw e.value\n    default: {\n      this.handlers[idx] = null\n\n      const n = this.handlers.length\n\n      if (n !== this.values.length)\n        return\n\n      for (let i=0; i < n; ++i)\n        if (this.handlers[i])\n          return\n\n      this.component.setState(FromClassEnd)\n      return\n    }\n  }\n}\n\n//\n\nconst FromClassEnd = {renderer: null}\nconst FromClassNull = {renderer: null, rendered: null}\n\nclass FromClass extends LiftedComponent {\n  constructor(props) {\n    super(props)\n  }\n  theInitialState() {\n    return FromClassNull\n  }\n  doUnsubscribe() {\n    const {renderer} = this.state\n    if (renderer)\n      renderer.unsubscribe()\n  }\n  doSubscribe(props) {\n    let n = 0\n    forEach(props, () => n += 1)\n\n    switch (n) {\n      case 1:\n        new Renderer1(this, props)\n        break\n      default:\n        new RendererN(this, props, n)\n        break\n    }\n  }\n}\n\n//\n\nconst hasAnyObs = (props, children) =>\n  children.find(x => x instanceof Observable) || props && hasObs(props)\n\nconst filterProps = (type, props) => {\n  const newProps = {\"$$type\": type}\n  for (const key in props) {\n    const val = props[key]\n    if (\"ref\" === key)\n      newProps[\"$$ref\"] = val\n    else if (\"karet-lift\" !== key)\n      newProps[key] = val\n  }\n  return newProps\n}\n\nconst client = {\n  ...React,\n  createElement(type, props, ...children) {\n    if (typeof type === \"string\" && hasAnyObs(props, children)) {\n      return React.createElement(FromClass, filterProps(type, props), ...children)\n    } else if (props && props[\"karet-lift\"] === true) {\n      if (hasAnyObs(props, children)) {\n        return React.createElement(FromClass, filterProps(type, props), ...children)\n      } else {\n        return React.createElement(type, R.dissoc(\"karet-lift\", props), ...children)\n      }\n    } else {\n      return React.createElement(type, props, ...children)\n    }\n  }\n}\n\nexport default client\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/karet.js"],"names":["emptyArray","dissoc","k","o","r","Object","assign","LiftedComponent","props","nextProps","doUnsubscribe","doSubscribe","Component","FromKefir","callback","rendered","observable","offAny","e","type","value","forceUpdate","onAny","fromKefir","createElement","hasObs","key","val","valK","forEach","fn","children","constructor","Array","i","length","render","values","newProps","newChildren","n","valI","ref","valO","newStyle","j","style","FromClass","handlers","Function","obs","handler","doHandle1","fill","doHandleN","push","idx","hasAnyObs","find","x","filterProps","client"],"mappings":"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","file":"karet.js","sourcesContent":["import React        from \"react\"\nimport {Observable} from \"kefir\"\n\n//\n\nconst emptyArray = []\n\nconst dissoc = (k, o) => {\n  const r = Object.assign({}, o)\n  delete r[k]\n  return r\n}\n\n//\n\nclass LiftedComponent extends React.Component {\n  constructor(props) {\n    super(props)\n  }\n  componentWillReceiveProps(nextProps) {\n    this.doUnsubscribe()\n    this.doSubscribe(nextProps)\n  }\n  componentWillMount() {\n    this.doSubscribe(this.props)\n  }\n  componentWillUnmount() {\n    this.doUnsubscribe()\n  }\n}\n\n//\n\nclass FromKefir extends LiftedComponent {\n  constructor(props) {\n    super(props)\n    this.callback = null\n    this.rendered = null\n  }\n  doUnsubscribe() {\n    const callback = this.callback\n    if (callback)\n      this.props.observable.offAny(callback)\n  }\n  doSubscribe({observable}) {\n    if (observable instanceof Observable) {\n      const callback = e => {\n        switch (e.type) {\n          case \"value\":\n            this.rendered = e.value\n            this.forceUpdate()\n            break\n          case \"error\":\n            throw e.value\n          case \"end\":\n            this.callback = null\n        }\n      }\n      this.callback = callback\n      observable.onAny(callback)\n    } else {\n      this.rendered = observable\n    }\n  }\n  render() {\n    return this.rendered\n  }\n}\n\nexport const fromKefir = observable =>\n  React.createElement(FromKefir, {observable})\n\n//\n\nfunction hasObs(props) {\n  for (const key in props) {\n    const val = props[key]\n    if (val instanceof Observable) {\n      return true\n    } else if (\"style\" === key) {\n      for (const k in val) {\n        const valK = val[k]\n        if (valK instanceof Observable)\n          return true\n      }\n    }\n  }\n  return false\n}\n\nfunction forEach(props, fn) {\n  for (const key in props) {\n    const val = props[key]\n    if (val instanceof Observable) {\n      fn(val)\n    } else if (\"children\" === key) {\n      const children = props[key]\n      if (children.constructor === Array) {\n        for (let i=0; i<children.length; ++i) {\n          const val = children[i]\n          if (val instanceof Observable)\n            fn(val)\n        }\n      }\n    } else if (\"style\" === key) {\n      for (const k in val) {\n        const valK = val[k]\n        if (valK instanceof Observable)\n          fn(valK)\n      }\n    }\n  }\n}\n\nfunction render(props, values) {\n  let type\n  let newProps = null\n  let newChildren\n\n  let k = -1\n\n  for (const key in props) {\n    const val = props[key]\n    if (\"children\" === key) {\n      if (val instanceof Observable) {\n        newChildren = [values[++k]]\n      } else if (val.constructor === Array) {\n        newChildren = Array(val.length)\n        for (let i=0, n=val.length; i<n; ++i) {\n          const valI = val[i]\n          if (valI instanceof Observable)\n            newChildren[i] = values[++k]\n          else\n            newChildren[i] = valI\n        }\n      } else {\n        newChildren = [val]\n      }\n    } else if (\"$$ref\" === key) {\n      if (!newProps) newProps = {}\n      if (val instanceof Observable) {\n        newProps.ref = values[++k]\n      } else {\n        newProps.ref = val\n      }\n    } else if (val instanceof Observable) {\n      const valO = values[++k]\n      if (!newProps) newProps = {}\n      newProps[key] = valO\n    } else if (\"style\" === key) {\n      let newStyle\n      for (const i in val) {\n        const valI = val[i]\n        if (valI instanceof Observable) {\n          if (!newStyle) {\n            newStyle = {}\n            for (const j in val) {\n              if (j === i)\n                break\n              newStyle[j] = val[j]\n            }\n          }\n          newStyle[i] = values[++k]\n        } else if (newStyle) {\n          newStyle[i] = valI\n        }\n      }\n      if (!newProps) newProps = {}\n      newProps.style = newStyle || val\n    } else if (\"$$type\" === key) {\n      type = props[key]\n    } else {\n      if (!newProps) newProps = {}\n      newProps[key] = val\n    }\n  }\n  return React.createElement(type, newProps, ...(newChildren || emptyArray))\n}\n\n//\n\nclass FromClass extends LiftedComponent {\n  constructor(props) {\n    super(props)\n    this.values = this\n    this.handlers = null\n  }\n  doUnsubscribe() {\n    const handlers = this.handlers\n    if (handlers) {\n      if (handlers instanceof Function) {\n        forEach(this.props, obs => obs.offAny(handlers))\n      } else {\n        let i = -1\n        forEach(this.props, obs => {\n          const handler = handlers[++i]\n          if (handler)\n            obs.offAny(handler)\n        })\n      }\n    }\n  }\n  doSubscribe(props) {\n    let n = 0\n    forEach(props, () => ++n)\n\n    if (n === 1) {\n      this.values = this\n      const handlers = e => this.doHandle1(e)\n      this.handlers = handlers\n      forEach(props, obs => obs.onAny(handlers))\n    } else {\n      this.values = Array(n).fill(this)\n      this.handlers = []\n      forEach(props, obs => {\n        const handler = e => this.doHandleN(handler, e)\n        this.handlers.push(handler)\n        obs.onAny(handler)\n      })\n    }\n  }\n  doHandle1(e) {\n    switch (e.type) {\n      case \"value\": {\n        const value = e.value\n        if (this.values !== value) {\n          this.values = value\n          this.forceUpdate()\n        }\n        break\n      }\n      case \"error\": throw e.value\n      default: {\n        this.values = [this.values]\n        this.handlers = null\n      }\n    }\n  }\n  doHandleN(handler, e) {\n    const handlers = this.handlers\n    let idx=0\n    while (handlers[idx] !== handler)\n      ++idx\n    switch (e.type) {\n      case \"value\": {\n        const value = e.value\n        const values = this.values\n        if (values[idx] !== value) {\n          values[idx] = value\n          this.forceUpdate()\n        }\n        break\n      }\n      case \"error\": throw e.value\n      default: {\n        handlers[idx] = null\n\n        const n = handlers.length\n\n        if (n !== this.values.length)\n          return\n\n        for (let i=0; i < n; ++i)\n          if (handlers[i])\n            return\n\n        this.handlers = null\n      }\n    }\n  }\n  render() {\n    if (this.handlers instanceof Function) {\n      const value = this.values\n      if (value === this)\n        return null\n      return render(this.props, [value])\n    } else {\n      const values = this.values\n      for (let i=0, n=values.length; i<n; ++i)\n        if (values[i] === this)\n          return null\n      return render(this.props, values)\n    }\n  }\n}\n\n//\n\nconst hasAnyObs = (props, children) =>\n  children.find(x => x instanceof Observable) || props && hasObs(props)\n\nconst filterProps = (type, props) => {\n  const newProps = {\"$$type\": type}\n  for (const key in props) {\n    const val = props[key]\n    if (\"ref\" === key)\n      newProps[\"$$ref\"] = val\n    else if (\"karet-lift\" !== key)\n      newProps[key] = val\n  }\n  return newProps\n}\n\nconst client = {\n  ...React,\n  createElement(type, props, ...children) {\n    if (typeof type === \"string\" && hasAnyObs(props, children)) {\n      return React.createElement(FromClass, filterProps(type, props), ...children)\n    } else if (props && props[\"karet-lift\"] === true) {\n      if (hasAnyObs(props, children)) {\n        return React.createElement(FromClass, filterProps(type, props), ...children)\n      } else {\n        return React.createElement(type, dissoc(\"karet-lift\", props), ...children)\n      }\n    } else {\n      return React.createElement(type, props, ...children)\n    }\n  }\n}\n\nexport default client\n"]} |
{ | ||
"name": "karet", | ||
"version": "0.1.4", | ||
"version": "0.2.0", | ||
"description": "JSX with Kefir, healthy?", | ||
@@ -45,5 +45,4 @@ "main": "lib/karet.js", | ||
"kefir": "^3.2.1", | ||
"ramda": ">=0.20.1 <0.23.0", | ||
"react": "^15.0.1" | ||
} | ||
} |
271
src/karet.js
@@ -1,2 +0,1 @@ | ||
import * as R from "ramda" | ||
import React from "react" | ||
@@ -7,6 +6,15 @@ import {Observable} from "kefir" | ||
const emptyArray = [] | ||
const dissoc = (k, o) => { | ||
const r = Object.assign({}, o) | ||
delete r[k] | ||
return r | ||
} | ||
// | ||
class LiftedComponent extends React.Component { | ||
constructor(props) { | ||
super(props) | ||
this.state = this.theInitialState() | ||
} | ||
@@ -18,15 +26,7 @@ componentWillReceiveProps(nextProps) { | ||
componentWillMount() { | ||
this.doUnsubscribe() | ||
this.doSubscribe(this.props) | ||
} | ||
shouldComponentUpdate(np, ns) { | ||
return ns.rendered !== this.state.rendered | ||
} | ||
componentWillUnmount() { | ||
this.doUnsubscribe() | ||
this.setState(this.theInitialState()) | ||
} | ||
render() { | ||
return this.state.rendered | ||
} | ||
} | ||
@@ -36,14 +36,10 @@ | ||
const FromKefirEnd = {callback: null} | ||
const FromKefirNull = {callback: null, rendered: null} | ||
class FromKefir extends LiftedComponent { | ||
constructor(props) { | ||
super(props) | ||
this.callback = null | ||
this.rendered = null | ||
} | ||
theInitialState() { | ||
return FromKefirNull | ||
} | ||
doUnsubscribe() { | ||
const {callback} = this.state | ||
const callback = this.callback | ||
if (callback) | ||
@@ -57,3 +53,4 @@ this.props.observable.offAny(callback) | ||
case "value": | ||
this.setState({rendered: e.value}) | ||
this.rendered = e.value | ||
this.forceUpdate() | ||
break | ||
@@ -63,12 +60,14 @@ case "error": | ||
case "end": | ||
this.setState(FromKefirEnd) | ||
break | ||
this.callback = null | ||
} | ||
} | ||
this.callback = callback | ||
observable.onAny(callback) | ||
this.setState({callback}) | ||
} else { | ||
this.setState({rendered: observable}) | ||
this.rendered = observable | ||
} | ||
} | ||
render() { | ||
return this.rendered | ||
} | ||
} | ||
@@ -121,4 +120,2 @@ | ||
const empty = [] | ||
function render(props, values) { | ||
@@ -145,3 +142,3 @@ let type | ||
} | ||
} else { | ||
} else { | ||
newChildren = [val] | ||
@@ -187,3 +184,3 @@ } | ||
} | ||
return React.createElement(type, newProps, ...(newChildren || empty)) | ||
return React.createElement(type, newProps, ...(newChildren || emptyArray)) | ||
} | ||
@@ -193,145 +190,105 @@ | ||
function FakeComponent(state, props) { | ||
this.props = props | ||
this.state = state | ||
} | ||
FakeComponent.prototype.setState = function (newState) { | ||
if ("renderer" in newState) | ||
this.state.renderer = newState.renderer | ||
if ("rendered" in newState) | ||
this.state.rendered = newState.rendered | ||
} | ||
// | ||
function Renderer1(component, newProps) { | ||
const state = {renderer: this, rendered: component.state.rendered} | ||
this.component = new FakeComponent(state, newProps) | ||
this.handler = e => this.doHandle(e) | ||
forEach(newProps, observable => observable.onAny(this.handler)) | ||
this.component = component | ||
component.setState(state) | ||
} | ||
Renderer1.prototype.unsubscribe = function () { | ||
const handler = this.handler | ||
if (handler) | ||
forEach(this.component.props, observable => observable.offAny(handler)) | ||
} | ||
Renderer1.prototype.doHandle = function (e) { | ||
switch (e.type) { | ||
case "value": { | ||
const component = this.component | ||
const rendered = render(component.props, [e.value]) | ||
if (!R.equals(component.state.rendered, rendered)) | ||
component.setState({rendered}) | ||
return | ||
} | ||
case "error": | ||
throw e.value | ||
default: | ||
this.handler = null | ||
this.component.setState(FromClassEnd) | ||
return | ||
} | ||
} | ||
// | ||
function RendererN(component, newProps, n) { | ||
const state = {renderer: this, rendered: component.state.rendered} | ||
this.component = new FakeComponent(state, newProps) | ||
this.handlers = [] | ||
this.values = Array(n) | ||
for (let i=0; i<n; ++i) | ||
this.values[i] = this | ||
forEach(newProps, observable => { | ||
const i = this.handlers.length | ||
const handler = e => this.doHandle(i, e) | ||
this.handlers.push(handler) | ||
observable.onAny(handler) | ||
}) | ||
this.component = component | ||
component.setState(state) | ||
} | ||
RendererN.prototype.unsubscribe = function () { | ||
let i = -1 | ||
forEach(this.component.props, observable => { | ||
const handler = this.handlers[++i] | ||
if (handler) | ||
observable.offAny(handler) | ||
}) | ||
} | ||
RendererN.prototype.doHandle = function (idx, e) { | ||
switch (e.type) { | ||
case "value": { | ||
this.values[idx] = e.value | ||
for (let i=this.values.length-1; 0 <= i; --i) | ||
if (this.values[i] === this) | ||
return | ||
const component = this.component | ||
const rendered = render(component.props, this.values) | ||
if (!R.equals(component.state.rendered, rendered)) | ||
component.setState({rendered}) | ||
return | ||
} | ||
case "error": | ||
throw e.value | ||
default: { | ||
this.handlers[idx] = null | ||
const n = this.handlers.length | ||
if (n !== this.values.length) | ||
return | ||
for (let i=0; i < n; ++i) | ||
if (this.handlers[i]) | ||
return | ||
this.component.setState(FromClassEnd) | ||
return | ||
} | ||
} | ||
} | ||
// | ||
const FromClassEnd = {renderer: null} | ||
const FromClassNull = {renderer: null, rendered: null} | ||
class FromClass extends LiftedComponent { | ||
constructor(props) { | ||
super(props) | ||
this.values = this | ||
this.handlers = null | ||
} | ||
theInitialState() { | ||
return FromClassNull | ||
} | ||
doUnsubscribe() { | ||
const {renderer} = this.state | ||
if (renderer) | ||
renderer.unsubscribe() | ||
const handlers = this.handlers | ||
if (handlers) { | ||
if (handlers instanceof Function) { | ||
forEach(this.props, obs => obs.offAny(handlers)) | ||
} else { | ||
let i = -1 | ||
forEach(this.props, obs => { | ||
const handler = handlers[++i] | ||
if (handler) | ||
obs.offAny(handler) | ||
}) | ||
} | ||
} | ||
} | ||
doSubscribe(props) { | ||
let n = 0 | ||
forEach(props, () => n += 1) | ||
forEach(props, () => ++n) | ||
switch (n) { | ||
case 1: | ||
new Renderer1(this, props) | ||
if (n === 1) { | ||
this.values = this | ||
const handlers = e => this.doHandle1(e) | ||
this.handlers = handlers | ||
forEach(props, obs => obs.onAny(handlers)) | ||
} else { | ||
this.values = Array(n).fill(this) | ||
this.handlers = [] | ||
forEach(props, obs => { | ||
const handler = e => this.doHandleN(handler, e) | ||
this.handlers.push(handler) | ||
obs.onAny(handler) | ||
}) | ||
} | ||
} | ||
doHandle1(e) { | ||
switch (e.type) { | ||
case "value": { | ||
const value = e.value | ||
if (this.values !== value) { | ||
this.values = value | ||
this.forceUpdate() | ||
} | ||
break | ||
default: | ||
new RendererN(this, props, n) | ||
} | ||
case "error": throw e.value | ||
default: { | ||
this.values = [this.values] | ||
this.handlers = null | ||
} | ||
} | ||
} | ||
doHandleN(handler, e) { | ||
const handlers = this.handlers | ||
let idx=0 | ||
while (handlers[idx] !== handler) | ||
++idx | ||
switch (e.type) { | ||
case "value": { | ||
const value = e.value | ||
const values = this.values | ||
if (values[idx] !== value) { | ||
values[idx] = value | ||
this.forceUpdate() | ||
} | ||
break | ||
} | ||
case "error": throw e.value | ||
default: { | ||
handlers[idx] = null | ||
const n = handlers.length | ||
if (n !== this.values.length) | ||
return | ||
for (let i=0; i < n; ++i) | ||
if (handlers[i]) | ||
return | ||
this.handlers = null | ||
} | ||
} | ||
} | ||
render() { | ||
if (this.handlers instanceof Function) { | ||
const value = this.values | ||
if (value === this) | ||
return null | ||
return render(this.props, [value]) | ||
} else { | ||
const values = this.values | ||
for (let i=0, n=values.length; i<n; ++i) | ||
if (values[i] === this) | ||
return null | ||
return render(this.props, values) | ||
} | ||
} | ||
} | ||
@@ -365,3 +322,3 @@ | ||
} else { | ||
return React.createElement(type, R.dissoc("karet-lift", props), ...children) | ||
return React.createElement(type, dissoc("karet-lift", props), ...children) | ||
} | ||
@@ -368,0 +325,0 @@ } else { |
@@ -46,2 +46,6 @@ import * as Kefir from "kefir" | ||
testRender(<div>{Kefir.later(1000,0)}</div>, "") | ||
testRender(<div>{Kefir.constant(1).merge(Kefir.later(1000,0))}</div>, "<div>1</div>") | ||
testRender(<div>{Kefir.later(1000,0)} {Kefir.constant(0)}</div>, "") | ||
const Custom = ({prop, ...props}) => <div>{`${prop} ${JSON.stringify(props)}`}</div> | ||
@@ -48,0 +52,0 @@ |
2
80631
724
- Removedramda@>=0.20.1 <0.23.0
- Removedramda@0.22.1(transitive)