bacon.react.base
Advanced tools
Comparing version 3.1.1 to 3.1.2
@@ -12,3 +12,3 @@ "use strict"; | ||
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 _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); | ||
@@ -21,3 +21,3 @@ var _baconjs = require("baconjs"); | ||
var _ramda2 = _interopRequireDefault(_ramda); | ||
var R = _interopRequireWildcard(_ramda); | ||
@@ -28,4 +28,12 @@ var _react = require("react"); | ||
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 _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; } | ||
// Lifting | ||
@@ -42,29 +50,52 @@ | ||
var common = { | ||
getInitialState: function getInitialState() { | ||
return nullState; | ||
}, | ||
tryDispose: function tryDispose() { | ||
var dispose = this.state.dispose; | ||
var LiftedComponent = function (_React$Component) { | ||
_inherits(LiftedComponent, _React$Component); | ||
if (dispose) dispose(); | ||
}, | ||
componentWillReceiveProps: function componentWillReceiveProps(nextProps) { | ||
this.trySubscribe(nextProps); | ||
}, | ||
componentWillMount: function componentWillMount() { | ||
this.trySubscribe(this.props); | ||
}, | ||
shouldComponentUpdate: function shouldComponentUpdate(np, ns) { | ||
return ns.rendered !== this.state.rendered; | ||
}, | ||
componentWillUnmount: function componentWillUnmount() { | ||
this.tryDispose(); | ||
this.setState(nullState); | ||
}, | ||
render: function render() { | ||
return this.state.rendered; | ||
function LiftedComponent(props) { | ||
_classCallCheck(this, LiftedComponent); | ||
var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(LiftedComponent).call(this, props)); | ||
_this.state = nullState; | ||
return _this; | ||
} | ||
}; | ||
_createClass(LiftedComponent, [{ | ||
key: "tryDispose", | ||
value: function tryDispose() { | ||
var dispose = this.state.dispose; | ||
if (dispose) dispose(); | ||
} | ||
}, { | ||
key: "componentWillReceiveProps", | ||
value: function componentWillReceiveProps(nextProps) { | ||
this.trySubscribe(nextProps); | ||
} | ||
}, { | ||
key: "componentWillMount", | ||
value: function componentWillMount() { | ||
this.trySubscribe(this.props); | ||
} | ||
}, { | ||
key: "shouldComponentUpdate", | ||
value: function shouldComponentUpdate(np, ns) { | ||
return ns.rendered !== this.state.rendered; | ||
} | ||
}, { | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
this.tryDispose(); | ||
this.setState(nullState); | ||
} | ||
}, { | ||
key: "render", | ||
value: function render() { | ||
return this.state.rendered; | ||
} | ||
}]); | ||
return LiftedComponent; | ||
}(_react2.default.Component); | ||
var toProperty = function toProperty(obs) { | ||
@@ -74,22 +105,35 @@ return obs instanceof _baconjs2.default.EventStream ? obs.toProperty() : obs; | ||
var FromBacon = _react2.default.createClass(_extends({}, common, { | ||
trySubscribe: function trySubscribe(_ref) { | ||
var _this = this; | ||
var FromBacon = function (_LiftedComponent) { | ||
_inherits(FromBacon, _LiftedComponent); | ||
var bacon = _ref.bacon; | ||
function FromBacon(props) { | ||
_classCallCheck(this, FromBacon); | ||
this.tryDispose(); | ||
this.setState({ dispose: bacon.subscribe(function (ev) { | ||
if (ev.hasValue()) { | ||
_this.setState({ rendered: ev.value() }); | ||
} else if (ev.isError()) { | ||
config.onError(ev.error); | ||
} else { | ||
_this.setState(nullDispose); | ||
} | ||
}) }); | ||
return _possibleConstructorReturn(this, Object.getPrototypeOf(FromBacon).call(this, props)); | ||
} | ||
})); | ||
_createClass(FromBacon, [{ | ||
key: "trySubscribe", | ||
value: function trySubscribe(_ref) { | ||
var _this3 = this; | ||
var bacon = _ref.bacon; | ||
this.tryDispose(); | ||
this.setState({ dispose: bacon.subscribe(function (ev) { | ||
if (ev.hasValue()) { | ||
_this3.setState({ rendered: ev.value() }); | ||
} else if (ev.isError()) { | ||
config.onError(ev.error); | ||
} else { | ||
_this3.setState(nullDispose); | ||
} | ||
}) }); | ||
} | ||
}]); | ||
return FromBacon; | ||
}(LiftedComponent); | ||
var fromBacon = exports.fromBacon = function fromBacon(bacon) { | ||
@@ -105,62 +149,75 @@ return _react2.default.createElement(FromBacon, { bacon: bacon }); | ||
var FromClass = _react2.default.createClass(_extends({}, common, { | ||
trySubscribe: function trySubscribe(_ref2) { | ||
var _this2 = this; | ||
var FromClass = function (_LiftedComponent2) { | ||
_inherits(FromClass, _LiftedComponent2); | ||
var props = _ref2.props; | ||
function FromClass(props) { | ||
_classCallCheck(this, FromClass); | ||
this.tryDispose(); | ||
return _possibleConstructorReturn(this, Object.getPrototypeOf(FromClass).call(this, props)); | ||
} | ||
var vals = {}; | ||
var obsKeys = []; | ||
var obsStreams = []; | ||
_createClass(FromClass, [{ | ||
key: "trySubscribe", | ||
value: function trySubscribe(_ref2) { | ||
var _this5 = this; | ||
for (var key in props) { | ||
var val = props[key]; | ||
var keyOut = "mount" === key ? "ref" : key; | ||
if (val instanceof _baconjs2.default.Observable) { | ||
obsKeys.push(keyOut); | ||
obsStreams.push(val); | ||
} else if ("children" === key && val instanceof Array && val.find(function (c) { | ||
return c instanceof _baconjs2.default.Observable; | ||
})) { | ||
obsKeys.push(keyOut); | ||
obsStreams.push(_baconjs2.default.combineAsArray(val)); | ||
} else { | ||
vals[keyOut] = val; | ||
var props = _ref2.props; | ||
this.tryDispose(); | ||
var vals = {}; | ||
var obsKeys = []; | ||
var obsStreams = []; | ||
for (var key in props) { | ||
var val = props[key]; | ||
var keyOut = "mount" === key ? "ref" : key; | ||
if (val instanceof _baconjs2.default.Observable) { | ||
obsKeys.push(keyOut); | ||
obsStreams.push(val); | ||
} else if ("children" === key && val instanceof Array && val.find(function (c) { | ||
return c instanceof _baconjs2.default.Observable; | ||
})) { | ||
obsKeys.push(keyOut); | ||
obsStreams.push(_baconjs2.default.combineAsArray(val)); | ||
} else { | ||
vals[keyOut] = val; | ||
} | ||
} | ||
} | ||
this.setState({ dispose: combineAsArray(obsStreams).subscribe(function (ev) { | ||
if (ev.hasValue()) { | ||
var obsVals = ev.value(); | ||
var _props = {}; | ||
var children = null; | ||
for (var _key in vals) { | ||
var _val = vals[_key]; | ||
if ("children" === _key) { | ||
children = _val; | ||
} else { | ||
_props[_key] = _val; | ||
this.setState({ dispose: combineAsArray(obsStreams).subscribe(function (ev) { | ||
if (ev.hasValue()) { | ||
var obsVals = ev.value(); | ||
var _props = {}; | ||
var children = null; | ||
for (var _key in vals) { | ||
var _val = vals[_key]; | ||
if ("children" === _key) { | ||
children = _val; | ||
} else { | ||
_props[_key] = _val; | ||
} | ||
} | ||
} | ||
for (var i = 0, n = obsKeys.length; i < n; ++i) { | ||
var _key2 = obsKeys[i]; | ||
var _val2 = obsVals[i]; | ||
if ("children" === _key2) { | ||
children = _val2; | ||
} else { | ||
_props[_key2] = _val2; | ||
for (var i = 0, n = obsKeys.length; i < n; ++i) { | ||
var _key2 = obsKeys[i]; | ||
var _val2 = obsVals[i]; | ||
if ("children" === _key2) { | ||
children = _val2; | ||
} else { | ||
_props[_key2] = _val2; | ||
} | ||
} | ||
_this5.setState({ rendered: _react2.default.createElement(_this5.props.Class, _props, children) }); | ||
} else if (ev.isError()) { | ||
config.onError(ev.error); | ||
} else { | ||
_this5.setState(nullDispose); | ||
} | ||
_this2.setState({ rendered: _react2.default.createElement(_this2.props.Class, _props, children) }); | ||
} else if (ev.isError()) { | ||
config.onError(ev.error); | ||
} else { | ||
_this2.setState(nullDispose); | ||
} | ||
}) }); | ||
} | ||
})); | ||
}) }); | ||
} | ||
}]); | ||
return FromClass; | ||
}(LiftedComponent); | ||
var fromClass = exports.fromClass = function fromClass(Class) { | ||
@@ -224,6 +281,6 @@ return function (props) { | ||
if (2 === n) { | ||
if (arguments[0] instanceof _baconjs2.default.Observable) return toProperty(arguments[0]).map(arguments[1]).skipDuplicates(_ramda2.default.equals); | ||
if (arguments[1] instanceof _baconjs2.default.Observable) return toProperty(arguments[1]).map(arguments[0]).skipDuplicates(_ramda2.default.equals); | ||
if (arguments[0] instanceof _baconjs2.default.Observable) return toProperty(arguments[0]).map(arguments[1]).skipDuplicates(R.equals); | ||
if (arguments[1] instanceof _baconjs2.default.Observable) return toProperty(arguments[1]).map(arguments[0]).skipDuplicates(R.equals); | ||
} | ||
return _baconjs2.default.combineWith.apply(_baconjs2.default, arguments).skipDuplicates(_ramda2.default.equals); | ||
return _baconjs2.default.combineWith.apply(_baconjs2.default, arguments).skipDuplicates(R.equals); | ||
} | ||
@@ -233,2 +290,2 @@ } | ||
exports.default = B; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/bacon.react.base.js"],"names":[],"mappings":";;;;;;;;;;;;;AAAA;;;;AACA;;;;AACA;;;;;;;;AAIO,IAAM,0BAAS;AACpB,WAAS,oBAAK;AAAC,UAAM,CAAN;AAAQ;AADH,CAAf;;AAIP,IAAM,cAAc,EAAC,SAAS,IAAV,EAApB;AACA,IAAM,YAAY,EAAC,SAAS,IAAV,EAAgB,UAAU,IAA1B,EAAlB;;AAEA,IAAM,SAAS;AACb,iBADa,6BACK;AAChB,WAAO,SAAP;AACD,GAHY;AAIb,YAJa,wBAIA;AAAA,QACJ,OADI,GACO,KAAK,KADZ,CACJ,OADI;;AAEX,QAAI,OAAJ,EACE;AACH,GARY;AASb,2BATa,qCASa,SATb,EASwB;AACnC,SAAK,YAAL,CAAkB,SAAlB;AACD,GAXY;AAYb,oBAZa,gCAYQ;AACnB,SAAK,YAAL,CAAkB,KAAK,KAAvB;AACD,GAdY;AAeb,uBAfa,iCAeS,EAfT,EAea,EAfb,EAeiB;AAC5B,WAAO,GAAG,QAAH,KAAgB,KAAK,KAAL,CAAW,QAAlC;AACD,GAjBY;AAkBb,sBAlBa,kCAkBU;AACrB,SAAK,UAAL;AACA,SAAK,QAAL,CAAc,SAAd;AACD,GArBY;AAsBb,QAtBa,oBAsBJ;AACP,WAAO,KAAK,KAAL,CAAW,QAAlB;AACD;AAxBY,CAAf;;AA2BA,IAAM,aAAa,SAAb,UAAa;AAAA,SACjB,eAAe,kBAAM,WAArB,GAAmC,IAAI,UAAJ,EAAnC,GAAsD,GADrC;AAAA,CAAnB;;AAGA,IAAM,YAAY,gBAAM,WAAN,cACb,MADa;AAEhB,cAFgB,8BAEM;AAAA;;AAAA,QAAR,KAAQ,QAAR,KAAQ;;AACpB,SAAK,UAAL;;AAEA,SAAK,QAAL,CAAc,EAAC,SAAS,MAAM,SAAN,CAAgB,cAAM;AAC5C,YAAI,GAAG,QAAH,EAAJ,EAAmB;AACjB,gBAAK,QAAL,CAAc,EAAC,UAAU,GAAG,KAAH,EAAX,EAAd;AACD,SAFD,MAEO,IAAI,GAAG,OAAH,EAAJ,EAAkB;AACvB,iBAAO,OAAP,CAAe,GAAG,KAAlB;AACD,SAFM,MAEA;AACL,gBAAK,QAAL,CAAc,WAAd;AACD;AACF,OARuB,CAAV,EAAd;AASD;AAde,GAAlB;;AAiBO,IAAM,gCAAY,SAAZ,SAAY;AAAA,SACvB,gBAAM,aAAN,CAAoB,SAApB,EAA+B,EAAC,YAAD,EAA/B,CADuB;AAAA,CAAlB;;AAGP,IAAM,iBAAiB,SAAjB,cAAiB;AAAA,SACrB,IAAI,MAAJ,KAAe,CAAf,GAAmB,IAAI,CAAJ,EAAO,GAAP,CAAW;AAAA,WAAK,CAAC,CAAD,CAAL;AAAA,GAAX,CAAnB,GAA0C,kBAAM,cAAN,CAAqB,GAArB,CADrB;AAAA,CAAvB;;AAGA,IAAM,YAAY,gBAAM,WAAN,cACb,MADa;AAEhB,cAFgB,+BAEM;AAAA;;AAAA,QAAR,KAAQ,SAAR,KAAQ;;AACpB,SAAK,UAAL;;AAEA,QAAM,OAAO,EAAb;AACA,QAAM,UAAU,EAAhB;AACA,QAAM,aAAa,EAAnB;;AAEA,SAAK,IAAM,GAAX,IAAkB,KAAlB,EAAyB;AACvB,UAAM,MAAM,MAAM,GAAN,CAAZ;AACA,UAAM,SAAS,YAAY,GAAZ,GAAkB,KAAlB,GAA0B,GAAzC;AACA,UAAI,eAAe,kBAAM,UAAzB,EAAqC;AACnC,gBAAQ,IAAR,CAAa,MAAb;AACA,mBAAW,IAAX,CAAgB,GAAhB;AACD,OAHD,MAGO,IAAI,eAAe,GAAf,IACA,eAAe,KADf,IAEA,IAAI,IAAJ,CAAS;AAAA,eAAK,aAAa,kBAAM,UAAxB;AAAA,OAAT,CAFJ,EAEkD;AACvD,gBAAQ,IAAR,CAAa,MAAb;AACA,mBAAW,IAAX,CAAgB,kBAAM,cAAN,CAAqB,GAArB,CAAhB;AACD,OALM,MAKA;AACL,aAAK,MAAL,IAAe,GAAf;AACD;AACF;;AAED,SAAK,QAAL,CAAc,EAAC,SAAS,eAAe,UAAf,EAA2B,SAA3B,CAAqC,cAAM;AACjE,YAAI,GAAG,QAAH,EAAJ,EAAmB;AACjB,cAAM,UAAU,GAAG,KAAH,EAAhB;AACA,cAAM,SAAQ,EAAd;AACA,cAAI,WAAW,IAAf;AACA,eAAK,IAAM,IAAX,IAAkB,IAAlB,EAAwB;AACtB,gBAAM,OAAM,KAAK,IAAL,CAAZ;AACA,gBAAI,eAAe,IAAnB,EAAwB;AAAC,yBAAW,IAAX;AAAe,aAAxC,MAA8C;AAAC,qBAAM,IAAN,IAAa,IAAb;AAAiB;AACjE;AACD,eAAK,IAAI,IAAE,CAAN,EAAS,IAAE,QAAQ,MAAxB,EAAgC,IAAE,CAAlC,EAAqC,EAAE,CAAvC,EAA0C;AACxC,gBAAM,QAAM,QAAQ,CAAR,CAAZ;AACA,gBAAM,QAAM,QAAQ,CAAR,CAAZ;AACA,gBAAI,eAAe,KAAnB,EAAwB;AAAC,yBAAW,KAAX;AAAe,aAAxC,MAA8C;AAAC,qBAAM,KAAN,IAAa,KAAb;AAAiB;AACjE;AACD,iBAAK,QAAL,CAAc,EAAC,UAAU,gBAAM,aAAN,CAAoB,OAAK,KAAL,CAAW,KAA/B,EACoB,MADpB,EAEoB,QAFpB,CAAX,EAAd;AAGD,SAhBD,MAgBO,IAAI,GAAG,OAAH,EAAJ,EAAkB;AACvB,iBAAO,OAAP,CAAe,GAAG,KAAlB;AACD,SAFM,MAEA;AACL,iBAAK,QAAL,CAAc,WAAd;AACD;AACF,OAtBuB,CAAV,EAAd;AAuBD;AAhDe,GAAlB;;AAmDO,IAAM,gCACX,SADW,SACX;AAAA,SAAS;AAAA,WAAS,gBAAM,aAAN,CAAoB,SAApB,EAA+B,EAAC,YAAD,EAAQ,YAAR,EAA/B,CAAT;AAAA,GAAT;AAAA,CADK;;AAGA,IAAM,oCAAc,SAAd,WAAc,UAAW;AACpC,MAAM,SAAS,EAAf;AACA,OAAK,IAAM,CAAX,IAAgB,OAAhB;AACE,WAAO,CAAP,IAAY,UAAU,QAAQ,CAAR,CAAV,CAAZ;AADF,GAEA,OAAO,MAAP;AACD,CALM;;AAOA,IAAM,4BAAU,SAAV,OAAU,CAAC,GAAD,EAAM,MAAN;AAAA,SAAiB,IAAI,IAAJ,CAAS,CAAC,EAAD,EAAK,EAAL,CAAT,EAAmB,iBAAW,GAAX,EAAmB;AAAA;;AAAA,QAAjB,MAAiB;;AAC5E,QAAM,SAAS,EAAf;AACA,QAAM,QAAQ,MAAM,IAAI,MAAV,CAAd;AACA,SAAK,IAAI,IAAE,CAAN,EAAS,IAAE,IAAI,MAApB,EAA4B,IAAE,CAA9B,EAAiC,EAAE,CAAnC,EAAsC;AACpC,UAAM,KAAK,IAAI,CAAJ,CAAX;AACA,UAAM,IAAI,GAAG,QAAH,EAAV;AACA,UAAI,KAAK,MAAT,EACE,MAAM,CAAN,IAAW,OAAO,CAAP,CAAX,CADF,KAGE,OAAO,CAAP,IAAY,MAAM,CAAN,IAAW,KAAK,MAAL,GAAc,OAAO,CAAP,CAAd,GAA0B,OAAO,EAAP,CAAjD;AACH;AACD,WAAO,CAAC,MAAD,EAAS,KAAT,CAAP;AACD,GAZuC,EAYrC,GAZqC,CAYjC;AAAA,WAAK,EAAE,CAAF,CAAL;AAAA,GAZiC,CAAjB;AAAA,CAAhB;;AAcP,SAAS,CAAT,GAAa;AAAA;;AACX,MAAM,IAAI,UAAU,MAApB;AACA,MAAI,MAAM,CAAV,EAAa;AAAA;AACX,UAAM,KAAK,WAAU,CAAV,CAAX;AACA;AAAA,WAAO;AAAA,4CAAI,EAAJ;AAAI,cAAJ;AAAA;;AAAA,iBAAW,oBAAE,EAAF,SAAS,EAAT,EAAX;AAAA;AAAP;AAFW;;AAAA;AAGZ,GAHD,MAGO;AACL,SAAK,IAAI,IAAE,CAAX,EAAc,IAAE,CAAhB,EAAmB,EAAE,CAArB,EAAwB;AACtB,UAAM,IAAI,UAAU,CAAV,CAAV;AACA,UAAM,IAAI,KAAK,EAAE,WAAjB;AACA,UAAI,MAAM,MAAN,IAAgB,MAAM,KAA1B,EACE,UAAU,CAAV,IAAe,kBAAM,eAAN,CAAsB,CAAtB,CAAf;AACH;AACD,QAAI,MAAM,CAAV,EAAa;AACX,UAAI,UAAU,CAAV,aAAwB,kBAAM,UAAlC,EACE,OAAO,WAAW,UAAU,CAAV,CAAX,EAAyB,GAAzB,CAA6B,UAAU,CAAV,CAA7B,EAA2C,cAA3C,CAA0D,gBAAE,MAA5D,CAAP;AACF,UAAI,UAAU,CAAV,aAAwB,kBAAM,UAAlC,EACE,OAAO,WAAW,UAAU,CAAV,CAAX,EAAyB,GAAzB,CAA6B,UAAU,CAAV,CAA7B,EAA2C,cAA3C,CAA0D,gBAAE,MAA5D,CAAP;AACH;AACD,WAAO,kBAAM,WAAN,CAAkB,KAAlB,oBAA+B,SAA/B,EAA0C,cAA1C,CAAyD,gBAAE,MAA3D,CAAP;AACD;AACF;;kBAEc,C","file":"bacon.react.base.js","sourcesContent":["import Bacon from \"baconjs\"\nimport R     from \"ramda\"\nimport React from \"react\"\n\n// Lifting\n\nexport const config = {\n  onError: e => {throw e}\n}\n\nconst nullDispose = {dispose: null}\nconst nullState = {dispose: null, rendered: null}\n\nconst common = {\n  getInitialState() {\n    return nullState\n  },\n  tryDispose() {\n    const {dispose} = this.state\n    if (dispose)\n      dispose()\n  },\n  componentWillReceiveProps(nextProps) {\n    this.trySubscribe(nextProps)\n  },\n  componentWillMount() {\n    this.trySubscribe(this.props)\n  },\n  shouldComponentUpdate(np, ns) {\n    return ns.rendered !== this.state.rendered\n  },\n  componentWillUnmount() {\n    this.tryDispose()\n    this.setState(nullState)\n  },\n  render() {\n    return this.state.rendered\n  }\n}\n\nconst toProperty = obs =>\n  obs instanceof Bacon.EventStream ? obs.toProperty() : obs\n\nconst FromBacon = React.createClass({\n  ...common,\n  trySubscribe({bacon}) {\n    this.tryDispose()\n\n    this.setState({dispose: bacon.subscribe(ev => {\n      if (ev.hasValue()) {\n        this.setState({rendered: ev.value()})\n      } else if (ev.isError()) {\n        config.onError(ev.error)\n      } else {\n        this.setState(nullDispose)\n      }\n    })})\n  }\n})\n\nexport const fromBacon = bacon =>\n  React.createElement(FromBacon, {bacon})\n\nconst combineAsArray = obs =>\n  obs.length === 1 ? obs[0].map(x => [x]) : Bacon.combineAsArray(obs)\n\nconst FromClass = React.createClass({\n  ...common,\n  trySubscribe({props}) {\n    this.tryDispose()\n\n    const vals = {}\n    const obsKeys = []\n    const obsStreams = []\n\n    for (const key in props) {\n      const val = props[key]\n      const keyOut = \"mount\" === key ? \"ref\" : key\n      if (val instanceof Bacon.Observable) {\n        obsKeys.push(keyOut)\n        obsStreams.push(val)\n      } else if (\"children\" === key &&\n                 val instanceof Array &&\n                 val.find(c => c instanceof Bacon.Observable)) {\n        obsKeys.push(keyOut)\n        obsStreams.push(Bacon.combineAsArray(val))\n      } else {\n        vals[keyOut] = val\n      }\n    }\n\n    this.setState({dispose: combineAsArray(obsStreams).subscribe(ev => {\n      if (ev.hasValue()) {\n        const obsVals = ev.value()\n        const props = {}\n        let children = null\n        for (const key in vals) {\n          const val = vals[key]\n          if (\"children\" === key) {children = val} else {props[key] = val}\n        }\n        for (let i=0, n=obsKeys.length; i<n; ++i) {\n          const key = obsKeys[i]\n          const val = obsVals[i]\n          if (\"children\" === key) {children = val} else {props[key] = val}\n        }\n        this.setState({rendered: React.createElement(this.props.Class,\n                                                     props,\n                                                     children)})\n      } else if (ev.isError()) {\n        config.onError(ev.error)\n      } else {\n        this.setState(nullDispose)\n      }\n    })})\n  }\n})\n\nexport const fromClass =\n  Class => props => React.createElement(FromClass, {Class, props})\n\nexport const fromClasses = classes => {\n  const result = {}\n  for (const k in classes)\n    result[k] = fromClass(classes[k])\n  return result\n}\n\nexport const fromIds = (ids, fromId) => ids.scan([{}, []], ([oldIds], ids) => {\n  const newIds = {}\n  const newVs = Array(ids.length)\n  for (let i=0, n=ids.length; i<n; ++i) {\n    const id = ids[i]\n    const k = id.toString()\n    if (k in newIds)\n      newVs[i] = newIds[k]\n    else\n      newIds[k] = newVs[i] = k in oldIds ? oldIds[k] : fromId(id)\n  }\n  return [newIds, newVs]\n}).map(s => s[1])\n\nfunction B() {\n  const n = arguments.length\n  if (1 === n) {\n    const fn = arguments[0]\n    return (...xs) => B(fn, ...xs)\n  } else {\n    for (let i=0; i<n; ++i) {\n      const x = arguments[i]\n      const c = x && x.constructor\n      if (c === Object || c === Array)\n        arguments[i] = Bacon.combineTemplate(x)\n    }\n    if (2 === n) {\n      if (arguments[0] instanceof Bacon.Observable)\n        return toProperty(arguments[0]).map(arguments[1]).skipDuplicates(R.equals)\n      if (arguments[1] instanceof Bacon.Observable)\n        return toProperty(arguments[1]).map(arguments[0]).skipDuplicates(R.equals)\n    }\n    return Bacon.combineWith.apply(Bacon, arguments).skipDuplicates(R.equals)\n  }\n}\n\nexport default B\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/bacon.react.base.js"],"names":[],"mappings":"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","file":"bacon.react.base.js","sourcesContent":["import Bacon  from \"baconjs\"\nimport * as R from \"ramda\"\nimport React  from \"react\"\n\n// Lifting\n\nexport const config = {\n  onError: e => {throw e}\n}\n\nconst nullDispose = {dispose: null}\nconst nullState = {dispose: null, rendered: null}\n\nclass LiftedComponent extends React.Component {\n  constructor(props) {\n    super(props)\n    this.state = nullState\n  }\n  tryDispose() {\n    const {dispose} = this.state\n    if (dispose)\n      dispose()\n  }\n  componentWillReceiveProps(nextProps) {\n    this.trySubscribe(nextProps)\n  }\n  componentWillMount() {\n    this.trySubscribe(this.props)\n  }\n  shouldComponentUpdate(np, ns) {\n    return ns.rendered !== this.state.rendered\n  }\n  componentWillUnmount() {\n    this.tryDispose()\n    this.setState(nullState)\n  }\n  render() {\n    return this.state.rendered\n  }\n}\n\nconst toProperty = obs =>\n  obs instanceof Bacon.EventStream ? obs.toProperty() : obs\n\nclass FromBacon extends LiftedComponent {\n  constructor(props) {\n    super(props)\n  }\n  trySubscribe({bacon}) {\n    this.tryDispose()\n\n    this.setState({dispose: bacon.subscribe(ev => {\n      if (ev.hasValue()) {\n        this.setState({rendered: ev.value()})\n      } else if (ev.isError()) {\n        config.onError(ev.error)\n      } else {\n        this.setState(nullDispose)\n      }\n    })})\n  }\n}\n\nexport const fromBacon = bacon =>\n  React.createElement(FromBacon, {bacon})\n\nconst combineAsArray = obs =>\n  obs.length === 1 ? obs[0].map(x => [x]) : Bacon.combineAsArray(obs)\n\nclass FromClass extends LiftedComponent {\n  constructor(props) {\n    super(props)\n  }\n  trySubscribe({props}) {\n    this.tryDispose()\n\n    const vals = {}\n    const obsKeys = []\n    const obsStreams = []\n\n    for (const key in props) {\n      const val = props[key]\n      const keyOut = \"mount\" === key ? \"ref\" : key\n      if (val instanceof Bacon.Observable) {\n        obsKeys.push(keyOut)\n        obsStreams.push(val)\n      } else if (\"children\" === key &&\n                 val instanceof Array &&\n                 val.find(c => c instanceof Bacon.Observable)) {\n        obsKeys.push(keyOut)\n        obsStreams.push(Bacon.combineAsArray(val))\n      } else {\n        vals[keyOut] = val\n      }\n    }\n\n    this.setState({dispose: combineAsArray(obsStreams).subscribe(ev => {\n      if (ev.hasValue()) {\n        const obsVals = ev.value()\n        const props = {}\n        let children = null\n        for (const key in vals) {\n          const val = vals[key]\n          if (\"children\" === key) {children = val} else {props[key] = val}\n        }\n        for (let i=0, n=obsKeys.length; i<n; ++i) {\n          const key = obsKeys[i]\n          const val = obsVals[i]\n          if (\"children\" === key) {children = val} else {props[key] = val}\n        }\n        this.setState({rendered: React.createElement(this.props.Class,\n                                                     props,\n                                                     children)})\n      } else if (ev.isError()) {\n        config.onError(ev.error)\n      } else {\n        this.setState(nullDispose)\n      }\n    })})\n  }\n}\n\nexport const fromClass =\n  Class => props => React.createElement(FromClass, {Class, props})\n\nexport const fromClasses = classes => {\n  const result = {}\n  for (const k in classes)\n    result[k] = fromClass(classes[k])\n  return result\n}\n\nexport const fromIds = (ids, fromId) => ids.scan([{}, []], ([oldIds], ids) => {\n  const newIds = {}\n  const newVs = Array(ids.length)\n  for (let i=0, n=ids.length; i<n; ++i) {\n    const id = ids[i]\n    const k = id.toString()\n    if (k in newIds)\n      newVs[i] = newIds[k]\n    else\n      newIds[k] = newVs[i] = k in oldIds ? oldIds[k] : fromId(id)\n  }\n  return [newIds, newVs]\n}).map(s => s[1])\n\nfunction B() {\n  const n = arguments.length\n  if (1 === n) {\n    const fn = arguments[0]\n    return (...xs) => B(fn, ...xs)\n  } else {\n    for (let i=0; i<n; ++i) {\n      const x = arguments[i]\n      const c = x && x.constructor\n      if (c === Object || c === Array)\n        arguments[i] = Bacon.combineTemplate(x)\n    }\n    if (2 === n) {\n      if (arguments[0] instanceof Bacon.Observable)\n        return toProperty(arguments[0]).map(arguments[1]).skipDuplicates(R.equals)\n      if (arguments[1] instanceof Bacon.Observable)\n        return toProperty(arguments[1]).map(arguments[0]).skipDuplicates(R.equals)\n    }\n    return Bacon.combineWith.apply(Bacon, arguments).skipDuplicates(R.equals)\n  }\n}\n\nexport default B\n"]} |
{ | ||
"name": "bacon.react.base", | ||
"version": "3.1.1", | ||
"version": "3.1.2", | ||
"description": "JSX with Bacon, yummy?", | ||
@@ -5,0 +5,0 @@ "main": "lib/bacon.react.base.js", |
@@ -1,4 +0,4 @@ | ||
import Bacon from "baconjs" | ||
import R from "ramda" | ||
import React from "react" | ||
import Bacon from "baconjs" | ||
import * as R from "ramda" | ||
import React from "react" | ||
@@ -14,6 +14,7 @@ // Lifting | ||
const common = { | ||
getInitialState() { | ||
return nullState | ||
}, | ||
class LiftedComponent extends React.Component { | ||
constructor(props) { | ||
super(props) | ||
this.state = nullState | ||
} | ||
tryDispose() { | ||
@@ -23,16 +24,16 @@ const {dispose} = this.state | ||
dispose() | ||
}, | ||
} | ||
componentWillReceiveProps(nextProps) { | ||
this.trySubscribe(nextProps) | ||
}, | ||
} | ||
componentWillMount() { | ||
this.trySubscribe(this.props) | ||
}, | ||
} | ||
shouldComponentUpdate(np, ns) { | ||
return ns.rendered !== this.state.rendered | ||
}, | ||
} | ||
componentWillUnmount() { | ||
this.tryDispose() | ||
this.setState(nullState) | ||
}, | ||
} | ||
render() { | ||
@@ -46,4 +47,6 @@ return this.state.rendered | ||
const FromBacon = React.createClass({ | ||
...common, | ||
class FromBacon extends LiftedComponent { | ||
constructor(props) { | ||
super(props) | ||
} | ||
trySubscribe({bacon}) { | ||
@@ -62,3 +65,3 @@ this.tryDispose() | ||
} | ||
}) | ||
} | ||
@@ -71,4 +74,6 @@ export const fromBacon = bacon => | ||
const FromClass = React.createClass({ | ||
...common, | ||
class FromClass extends LiftedComponent { | ||
constructor(props) { | ||
super(props) | ||
} | ||
trySubscribe({props}) { | ||
@@ -121,3 +126,3 @@ this.tryDispose() | ||
} | ||
}) | ||
} | ||
@@ -124,0 +129,0 @@ export const fromClass = |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
48501
412