Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

boundless-async

Package Overview
Dependencies
Maintainers
1
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

boundless-async - npm Package Compare versions

Comparing version 1.0.0-beta.6 to 1.0.0-beta.7

build/style.css

4

build/index.js

@@ -1,2 +0,2 @@

module.exports=function(t){function e(o){if(n[o])return n[o].exports;var r=n[o]={i:o,l:!1,exports:{}};return t[o].call(r.exports,r,r.exports,e),r.l=!0,r.exports}var n={};return e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,o){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:o})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=3)}([function(t,e,n){"use strict";function o(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];return Object.keys(t).reduce(function(n,o){return e.indexOf(o)===-1&&(n[o]=t[o]),n},{})}e.a=o},function(t,e){t.exports=require("classnames")},function(t,e){t.exports=require("react")},function(t,e,n){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function r(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}Object.defineProperty(e,"__esModule",{value:!0});var c=n(2),i=n.n(c),s=n(1),u=n.n(s),l=n(0),p=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(t[o]=n[o])}return t},f=function(){function t(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}return function(e,n,o){return n&&t(e.prototype,n),o&&t(e,o),e}}(),d=function(t){function e(){var t,n,a,c;o(this,e);for(var i=arguments.length,s=Array(i),u=0;u<i;u++)s[u]=arguments[u];return n=a=r(this,(t=e.__proto__||Object.getPrototypeOf(e)).call.apply(t,[this].concat(s))),a.mounted=!1,a.state={},c=n,r(a,c)}return a(e,t),f(e,[{key:"convertDataToJSXOrWait",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.props,n=e.data;return n instanceof Promise?(this.setState({component:null}),n.then(function(e){t.mounted&&t.setState(function(t,o){return{component:o.data===n?o.convertToJSXFunc(e):t.component}})},function(){return t.setState({component:!1})})):void this.setState({component:e.convertToJSXFunc(n)})}},{key:"fireCallbackIfDataRendered",value:function(){this.state.component&&this.props.contentRenderedFunc()}},{key:"componentWillMount",value:function(){this.convertDataToJSXOrWait()}},{key:"componentDidMount",value:function(){this.mounted=!0,this.fireCallbackIfDataRendered()}},{key:"componentDidUpdate",value:function(){this.fireCallbackIfDataRendered()}},{key:"componentWillReceiveProps",value:function(t){this.convertDataToJSXOrWait(t)}},{key:"componentWillUnmount",value:function(){this.mounted=!1}},{key:"getClasses",value:function(t){return u()("b-async",this.props.className,t,{"b-async-error":this.state.component===!1,"b-async-loading":null===this.state.component})}},{key:"render",value:function(){return null===this.state.component||this.state.component===!1?i.a.createElement("div",p({},n.i(l.a)(this.props,e.internalKeys),{className:this.getClasses()}),null===this.state.component?this.props.loadingContent:this.props.errorContent):i.a.cloneElement(this.state.component,p({},n.i(l.a)(this.props,e.internalKeys),{className:this.getClasses(this.state.component.props&&this.state.component.props.className)}))}}]),e}(i.a.PureComponent);d.propTypes={contentRenderedFunc:c.PropTypes.func,convertToJSXFunc:c.PropTypes.func,data:c.PropTypes.any,errorContent:c.PropTypes.node,loadingContent:c.PropTypes.node},d.defaultProps={contentRenderedFunc:function(){},convertToJSXFunc:function(t){return t},data:null,errorContent:"⚠️",loadingContent:null},d.internalKeys=Object.keys(d.defaultProps),e.default=d}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap c36e3bd8c3e02b5b525a","webpack:///./packages/boundless-utils-omit-keys/index.js","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///external {\"commonjs2\":\"react\"}","webpack:///./packages/boundless-async/index.js"],"names":["module","exports","modules","__webpack_require__","moduleId","installedModules","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","__webpack_exports__","omitKeysFromSourceObject","source","omittedKeys","arguments","length","undefined","keys","reduce","hash","key","indexOf","require","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","create","constructor","writable","setPrototypeOf","__proto__","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1_classnames__","__WEBPACK_IMPORTED_MODULE_1_classnames___default","__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__","_extends","assign","target","_createClass","defineProperties","props","descriptor","protoProps","staticProps","Async","_React$PureComponent","_ref","_temp","_this","_ret","this","_len","args","Array","_key","getPrototypeOf","apply","concat","mounted","state","_this2","data","Promise","setState","component","then","payload","currentProps","convertToJSXFunc","contentRenderedFunc","convertDataToJSXOrWait","fireCallbackIfDataRendered","nextProps","extraClasses","className","b-async-error","b-async-loading","a","createElement","internalKeys","getClasses","loadingContent","errorContent","cloneElement","PureComponent","propTypes","func","any","node","defaultProps","x"],"mappings":"AAAAA,OAAOC,QACE,SAAUC,GCGnB,QAAAC,GAAAC,GAGA,GAAAC,EAAAD,GACA,MAAAC,GAAAD,GAAAH,OAGA,IAAAD,GAAAK,EAAAD,IACAE,EAAAF,EACAG,GAAA,EACAN,WAUA,OANAC,GAAAE,GAAAI,KAAAR,EAAAC,QAAAD,IAAAC,QAAAE,GAGAH,EAAAO,GAAA,EAGAP,EAAAC,QAvBA,GAAAI,KA+DA,OAnCAF,GAAAM,EAAAP,EAGAC,EAAAO,EAAAL,EAGAF,EAAAG,EAAA,SAAAK,GAA2C,MAAAA,IAG3CR,EAAAS,EAAA,SAAAX,EAAAY,EAAAC,GACAX,EAAAY,EAAAd,EAAAY,IACAG,OAAAC,eAAAhB,EAAAY,GACAK,cAAA,EACAC,YAAA,EACAC,IAAAN,KAMAX,EAAAkB,EAAA,SAAArB,GACA,GAAAc,GAAAd,KAAAsB,WACA,WAA2B,MAAAtB,GAAA,SAC3B,WAAiC,MAAAA,GAEjC,OADAG,GAAAS,EAAAE,EAAA,IAAAA,GACAA,GAIAX,EAAAY,EAAA,SAAAQ,EAAAC,GAAsD,MAAAR,QAAAS,UAAAC,eAAAlB,KAAAe,EAAAC,IAGtDrB,EAAAwB,EAAA,GAGAxB,IAAAyB,EAAA,KDOM,SAAU5B,EAAQ6B,EAAqB1B,GAE7C,YEtEe,SAAS2B,GAAyBC,GAA0B,GAAlBC,GAAkBC,UAAAC,OAAA,GAAAC,SAAAF,UAAA,GAAAA,UAAA,KACvE,OAAOjB,QAAOoB,KAAKL,GAAQM,OAAO,SAA8BC,EAAMC,GAKlE,MAJIP,GAAYQ,QAAQD,MAAS,IAC7BD,EAAKC,GAAOR,EAAOQ,IAGhBD,OFiEkBT,EAAuB,EAAIC,GAKtD,SAAU9B,EAAQC,GG/ExBD,EAAAC,QAAAwC,QAAA,eHqFM,SAAUzC,EAAQC,GIrFxBD,EAAAC,QAAAwC,QAAA,UJ2FM,SAAUzC,EAAQ6B,EAAqB1B,GAE7C,YAO8tB,SAASuC,GAAgBC,EAASC,GAAa,KAAKD,YAAoBC,IAAc,KAAM,IAAIC,WAAU,qCAAuC,QAASC,GAA2BC,EAAKvC,GAAM,IAAIuC,EAAM,KAAM,IAAIC,gBAAe,4DAA8D,QAAOxC,GAAqB,gBAAPA,IAA+B,kBAAPA,GAAwBuC,EAALvC,EAAW,QAASyC,GAAUC,EAASC,GAAY,GAAuB,kBAAbA,IAAsC,OAAbA,EAAmB,KAAM,IAAIN,WAAU,iEAAkEM,GAAaD,GAASzB,UAAUT,OAAOoC,OAAOD,GAAYA,EAAW1B,WAAW4B,aAAa1C,MAAMuC,EAAS/B,YAAW,EAAMmC,UAAS,EAAKpC,cAAa,KAAWiC,IAAWnC,OAAOuC,eAAevC,OAAOuC,eAAeL,EAASC,GAAYD,EAASM,UAAUL,GANhgDnC,OAAOC,eAAeY,EAAqB,cAAgBlB,OAAO,GAC7C,IAAI8C,GAAsCtD,EAAoB,GAC1DuD,EAA8CvD,EAAoBkB,EAAEoC,GACpEE,EAA2CxD,EAAoB,GAC/DyD,EAAmDzD,EAAoBkB,EAAEsC,GACzEE,EAA0D1D,EAAoB,GACnG2D,EAAS9C,OAAO+C,QAAQ,SAASC,GAAQ,IAAI,GAAI1D,GAAE,EAAEA,EAAE2B,UAAUC,OAAO5B,IAAI,CAAC,GAAIyB,GAAOE,UAAU3B,EAAG,KAAI,GAAIiC,KAAOR,GAAWf,OAAOS,UAAUC,eAAelB,KAAKuB,EAAOQ,KAAMyB,EAAOzB,GAAKR,EAAOQ,IAAQ,MAAOyB,IAAaC,EAAa,WAAW,QAASC,GAAiBF,EAAOG,GAAO,IAAI,GAAI7D,GAAE,EAAEA,EAAE6D,EAAMjC,OAAO5B,IAAI,CAAC,GAAI8D,GAAWD,EAAM7D,EAAG8D,GAAWjD,WAAWiD,EAAWjD,aAAY,EAAMiD,EAAWlD,cAAa,EAAQ,SAAUkD,KAAWA,EAAWd,UAAS,GAAKtC,OAAOC,eAAe+C,EAAOI,EAAW7B,IAAI6B,IAAc,MAAO,UAASxB,EAAYyB,EAAWC,GAAuI,MAAvHD,IAAWH,EAAiBtB,EAAYnB,UAAU4C,GAAeC,GAAYJ,EAAiBtB,EAAY0B,GAAoB1B,MKrFvrB2B,ELqFigD,SAASC,GAA4D,QAASD,KAAQ,GAAIE,GAASC,EAAMC,EAAMC,CAAKlC,GAAgBmC,KAAKN,EAAO,KAAI,GAAIO,GAAK7C,UAAUC,OAAO6C,EAAKC,MAAMF,GAAMG,EAAK,EAAEA,EAAKH,EAAKG,IAAQF,EAAKE,GAAMhD,UAAUgD,EAAO,OAAaP,GAAOC,EAAM7B,EAA2B+B,MAAMJ,EAAKF,EAAMf,WAAWxC,OAAOkE,eAAeX,IAAQ/D,KAAK2E,MAAMV,GAAMI,MAAMO,OAAOL,KAAeJ,EKzDl6DU,SAAU,ELyD46DV,EKxDt7DW,SLwD6wDV,EAAwLF,EAAO5B,EAA2B6B,EAAMC,GAA0tE,MAAtpF3B,GAAUsB,EAAMC,GAAmbP,EAAaM,IAAQhC,IAAI,yBAAyB5B,MAAM,WKtDjgE,GAAA4E,GAAAV,KAApBV,EAAoBlC,UAAAC,OAAA,GAAAC,SAAAF,UAAA,GAAAA,UAAA,GAAZ4C,KAAKV,MACzBqB,EAAQrB,EAARqB,IAEP,OAAIA,aAAgBC,UAChBZ,KAAKa,UAAUC,UAAW,OAEnBH,EAAKI,KAAK,SAACC,GACVN,EAAKF,SAELE,EAAKG,SAAS,SAACJ,EAAOQ,GAAR,OACVH,UAAWG,EAAaN,OAASA,EACpBM,EAAaC,iBAAiBF,GAC9BP,EAAMK,cAG5B,iBAAMJ,GAAKG,UAAUC,WAAW,WAGvCd,MAAKa,UAAUC,UAAWxB,EAAM4B,iBAAiBP,QLoCwgFjD,IAAI,6BAA6B5B,MAAM,WKhC5lFkE,KAAKS,MAAMK,WACXd,KAAKV,MAAM6B,yBL+BsrFzD,IAAI,qBAAqB5B,MAAM,WK3BjsFkE,KAAKoB,4BL2B4vF1D,IAAI,oBAAoB5B,MAAM,WK1B/xFkE,KAAKQ,SAAU,EAAMR,KAAKqB,gCL0B01F3D,IAAI,qBAAqB5B,MAAM,WKzBn5FkE,KAAKqB,gCLyBk9F3D,IAAI,4BAA4B5B,MAAM,SKxB1gGwF,GAAatB,KAAKoB,uBAAuBE,MLwB0jG5D,IAAI,uBAAuB5B,MAAM,WKvBvnGkE,KAAKQ,SAAU,KLuB+pG9C,IAAI,aAAa5B,MAAM,SKrBjuGyF,GACP,MAAOxC,KAAG,UAAWiB,KAAKV,MAAMkC,UAAWD,GACvCE,gBAAiBzB,KAAKS,MAAMK,aAAc,EAC1CY,kBAA4C,OAAzB1B,KAAKS,MAAMK,eLkBg7GpD,IAAI,SAAS5B,MAAM,WKbr+G,MAA6B,QAAzBkE,KAAKS,MAAMK,WAAsBd,KAAKS,MAAMK,aAAc,EAEtDjC,EAAA8C,EAAAC,cAAA,MAAA3C,KAAS3D,EAAAG,EAAAuD,EAAA,GAAKgB,KAAKV,MAAOI,EAAMmC,eAAeL,UAAWxB,KAAK8B,eACjC,OAAzB9B,KAAKS,MAAMK,UACTd,KAAKV,MAAMyC,eACX/B,KAAKV,MAAM0C,cAKnBnD,EAAA8C,EAAMM,aAAajC,KAAKS,MAAMK,UAA9B7B,KACA3D,EAAAG,EAAAuD,EAAA,GAAKgB,KAAKV,MAAOI,EAAMmC,eAC1BL,UAAWxB,KAAK8B,WAAW9B,KAAKS,MAAMK,UAAUxB,OAASU,KAAKS,MAAMK,UAAUxB,MAAMkC,kBLCknI9B,GKrF/qIb,EAAA8C,EAAMO,cAApBxC,GACVyC,WAEHhB,oBAAqBvC,EAAA,UAAUwD,KAG/BlB,iBAAkBtC,EAAA,UAAUwD,KAG5BzB,KAAM/B,EAAA,UAAUyD,IAGhBL,aAAcpD,EAAA,UAAU0D,KAGxBP,eAAgBnD,EAAA,UAAU0D,MAfb5C,EAkBV6C,cACHpB,oBAAqB,aACrBD,iBAAkB,SAACsB,GAAD,MAAOA,IACzB7B,KAAM,KACNqB,aAAc,KACdD,eAAgB,MAvBHrC,EA0BVmC,aAAe1F,OAAOoB,KAAKmC,EAAM6C,cL2Dm1JvF,EAA6B,QKrFv4J0C","file":"index.js","sourcesContent":["module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 3);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = omitKeysFromSourceObject;\nfunction omitKeysFromSourceObject(source){var omittedKeys=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];return Object.keys(source).reduce(function relocateAcceptedKeys(hash,key){if(omittedKeys.indexOf(key)===-1){hash[key]=source[key];}return hash;},{});}\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__ = __webpack_require__(0);\nvar _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;};}();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 Async=function(_React$PureComponent){_inherits(Async,_React$PureComponent);function Async(){var _ref;var _temp,_this,_ret;_classCallCheck(this,Async);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=_possibleConstructorReturn(this,(_ref=Async.__proto__||Object.getPrototypeOf(Async)).call.apply(_ref,[this].concat(args))),_this),_this.mounted=false,_this.state={},_temp),_possibleConstructorReturn(_this,_ret);}_createClass(Async,[{key:'convertDataToJSXOrWait',value:function convertDataToJSXOrWait(){var _this2=this;var props=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.props;var data=props.data;if(data instanceof Promise){this.setState({component:null});return data.then(function(payload){if(_this2.mounted){_this2.setState(function(state,currentProps){return{component:currentProps.data===data?currentProps.convertToJSXFunc(payload):state.component};});}},function(){return _this2.setState({component:false});});}this.setState({component:props.convertToJSXFunc(data)});}},{key:'fireCallbackIfDataRendered',value:function fireCallbackIfDataRendered(){if(this.state.component){this.props.contentRenderedFunc();}}},{key:'componentWillMount',value:function componentWillMount(){this.convertDataToJSXOrWait();}},{key:'componentDidMount',value:function componentDidMount(){this.mounted=true;this.fireCallbackIfDataRendered();}},{key:'componentDidUpdate',value:function componentDidUpdate(){this.fireCallbackIfDataRendered();}},{key:'componentWillReceiveProps',value:function componentWillReceiveProps(nextProps){this.convertDataToJSXOrWait(nextProps);}},{key:'componentWillUnmount',value:function componentWillUnmount(){this.mounted=false;}},{key:'getClasses',value:function getClasses(extraClasses){return __WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-async',this.props.className,extraClasses,{'b-async-error':this.state.component===false,'b-async-loading':this.state.component===null});}},{key:'render',value:function render(){if(this.state.component===null||this.state.component===false){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__[\"a\" /* default */])(this.props,Async.internalKeys),{className:this.getClasses()}),this.state.component===null?this.props.loadingContent:this.props.errorContent);}return __WEBPACK_IMPORTED_MODULE_0_react___default.a.cloneElement(this.state.component,_extends({},__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__[\"a\" /* default */])(this.props,Async.internalKeys),{className:this.getClasses(this.state.component.props&&this.state.component.props.className)}));}}]);return Async;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Async.propTypes={contentRenderedFunc:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func,convertToJSXFunc:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func,data:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].any,errorContent:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,loadingContent:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node};Async.defaultProps={contentRenderedFunc:function contentRenderedFunc(){},convertToJSXFunc:function convertToJSXFunc(x){return x;},data:null,errorContent:'⚠️',loadingContent:null};Async.internalKeys=Object.keys(Async.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Async;\n\n/***/ })\n/******/ ]);\n\n\n// WEBPACK FOOTER //\n// index.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 3);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap c36e3bd8c3e02b5b525a","/**\n * Returns a modified version of the supplied object without the given keys.\n */\nexport default function omitKeysFromSourceObject(source, omittedKeys = []) {\n    return Object.keys(source).reduce(function relocateAcceptedKeys(hash, key) {\n        if (omittedKeys.indexOf(key) === -1) {\n            hash[key] = source[key];\n        }\n\n        return hash;\n    }, {});\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-omit-keys/index.js","module.exports = require(\"classnames\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"classnames\"}\n// module id = 1\n// module chunks = 0","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"react\"}\n// module id = 2\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport omit from 'boundless-utils-omit-keys';\n\n\n/**\n * # Async\n * __A higher-order component for rendering data that isn't ready yet.__\n *\n * There are plenty of situations where you need to fetch content to be displayed, but want\n * to show some sort of loading graphic in the interim. This component helps to simplify\n * that pattern by handling common types of promises and providing a simple mechanism\n * for materializing the resolved data into JSX.\n */\nexport default class Async extends React.PureComponent {\n    static propTypes = {\n        /** a callback for when real content has been rendered; either normal passed data or when a passed promise resolves */\n        contentRenderedFunc: PropTypes.func,\n\n        /** a function that takes the resolved payload of a promise provided by `props.data` and returns renderable JSX; defaults to trying to render the resolved value of the Promise */\n        convertToJSXFunc: PropTypes.func,\n\n        /** a promise, or some other piece of data to be run through `props.convertToJSXFunc` */\n        data: PropTypes.any,\n\n        /** content to be shown if the promise is rejected */\n        errorContent: PropTypes.node,\n\n        /** content to be shown while the promise is in pending state */\n        loadingContent: PropTypes.node,\n    }\n\n    static defaultProps = {\n        contentRenderedFunc: () => {},\n        convertToJSXFunc: (x) => x,\n        data: null,\n        errorContent: '⚠️',\n        loadingContent: null,\n    }\n\n    static internalKeys = Object.keys(Async.defaultProps)\n\n    mounted = false\n    state = {}\n\n    convertDataToJSXOrWait(props = this.props) {\n        const {data} = props;\n\n        if (data instanceof Promise) {\n            this.setState({component: null});\n\n            return data.then((payload) => {\n                if (this.mounted) {\n                    // only replace if we're looking at the same promise, otherwise do nothing\n                    this.setState((state, currentProps) => ({\n                        component: currentProps.data === data\n                                   ? currentProps.convertToJSXFunc(payload)\n                                   : state.component,\n                    }));\n                }\n            }, () => this.setState({component: false}));\n        }\n\n        this.setState({component: props.convertToJSXFunc(data)});\n    }\n\n    fireCallbackIfDataRendered() {\n        if (this.state.component) {\n            this.props.contentRenderedFunc();\n        }\n    }\n\n    componentWillMount()                 { this.convertDataToJSXOrWait(); }\n    componentDidMount()                  { this.mounted = true; this.fireCallbackIfDataRendered(); }\n    componentDidUpdate()                 { this.fireCallbackIfDataRendered(); }\n    componentWillReceiveProps(nextProps) { this.convertDataToJSXOrWait(nextProps); }\n    componentWillUnmount()               { this.mounted = false; }\n\n    getClasses(extraClasses) {\n        return cx('b-async', this.props.className, extraClasses, {\n            'b-async-error': this.state.component === false,\n            'b-async-loading': this.state.component === null,\n        });\n    }\n\n    render() {\n        if (this.state.component === null || this.state.component === false) {\n            return (\n                <div {...omit(this.props, Async.internalKeys)} className={this.getClasses()}>\n                    {this.state.component === null\n                     ? this.props.loadingContent\n                     : this.props.errorContent}\n                </div>\n            );\n        }\n\n        return React.cloneElement(this.state.component, {\n            ...omit(this.props, Async.internalKeys),\n            className: this.getClasses(this.state.component.props && this.state.component.props.className),\n        });\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-async/index.js"],"sourceRoot":""}
module.exports=function(e){function n(r){if(t[r])return t[r].exports;var o=t[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}var t={};return n.m=e,n.c=t,n.i=function(e){return e},n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:r})},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},n.p="",n(n.s=3)}([function(e,n){e.exports=require("boundless-utils-omit-keys")},function(e,n){e.exports=require("classnames")},function(e,n){e.exports=require("react")},function(e,n,t){"use strict";function r(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}function o(e,n){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!n||"object"!=typeof n&&"function"!=typeof n?e:n}function i(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function, not "+typeof n);e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),n&&(Object.setPrototypeOf?Object.setPrototypeOf(e,n):e.__proto__=n)}Object.defineProperty(n,"__esModule",{value:!0});var u=t(2),l=t.n(u),s=t(1),c=t.n(s),a=t(0),p=t.n(a),f=Object.assign||function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},d=function(){function e(e,n){for(var t=0;t<n.length;t++){var r=n[t];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(n,t,r){return t&&e(n.prototype,t),r&&e(n,r),n}}(),h=function(e,n,t){return n.split(".").reduce(function(e,n){return e[n]||t},e)},y=function(e){function n(){var e,t,i,u;r(this,n);for(var l=arguments.length,s=Array(l),c=0;c<l;c++)s[c]=arguments[c];return t=i=o(this,(e=n.__proto__||Object.getPrototypeOf(n)).call.apply(e,[this].concat(s))),i.mounted=!1,i.promise=null,i.state={},u=t,o(i,u)}return i(n,e),d(n,[{key:"handlePromiseFulfillment",value:function(e,n){this.mounted&&this.setState(function(t){return this.promise===e?(this.promise=null,{component:n}):t},this.fireRenderCallback)}},{key:"handleChildren",value:function(e){var n=e;if(l.a.isValidElement(n))return this.setState({component:n},this.fireRenderCallback);if("function"==typeof n)return this.handleChildren(n(this.props));var t=this.handlePromiseFulfillment.bind(this,n);this.promise=n,this.setState({component:null},function(){return n.then(t,t)})}},{key:"fireRenderCallback",value:function(){this.state.component&&this.props.childrenDidRender()}},{key:"componentWillMount",value:function(){this.handleChildren(this.props.children)}},{key:"componentDidMount",value:function(){this.mounted=!0}},{key:"componentWillReceiveProps",value:function(e){this.handleChildren(e.children)}},{key:"componentWillUnmount",value:function(){this.mounted=!1}},{key:"render",value:function(){var e=this.props,t=this.state;return l.a.cloneElement(t.component||e.pendingContent,f({},p()(e,n.internalKeys),{className:c()("b-async",e.className,null===t.component&&h(e,"pendingContent.props.className"),t.component&&h(t,"component.props.className",""),{"b-async-pending":null===t.component})}))}}]),n}(l.a.PureComponent);y.propTypes={"*":u.PropTypes.any,children:u.PropTypes.oneOfType([u.PropTypes.func,u.PropTypes.node,u.PropTypes.instanceOf(Promise)]).isRequired,childrenDidRender:u.PropTypes.func,pendingContent:u.PropTypes.node},y.defaultProps={children:l.a.createElement("div",null),childrenDidRender:function(){},pendingContent:l.a.createElement("div",null)},y.internalKeys=Object.keys(y.defaultProps),n.default=y}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap f51f05352d0e85e3a699","webpack:///external {\"commonjs2\":\"boundless-utils-omit-keys\"}","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///external {\"commonjs2\":\"react\"}","webpack:///./packages/boundless-async/index.js"],"names":["module","exports","modules","__webpack_require__","moduleId","installedModules","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","require","__webpack_exports__","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","create","constructor","writable","setPrototypeOf","__proto__","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1_classnames__","__WEBPACK_IMPORTED_MODULE_1_classnames___default","__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__","__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys___default","_extends","assign","target","arguments","length","source","key","_createClass","defineProperties","props","descriptor","protoProps","staticProps","base","path","fallback","split","reduce","current","fragment","Async","_React$PureComponent","_ref","_temp","_this","_ret","this","_len","args","Array","_key","getPrototypeOf","apply","concat","mounted","promise","state","context","payload","setState","component","fireRenderCallback","children","content","a","isValidElement","handleChildren","boundHandler","handlePromiseFulfillment","bind","then","childrenDidRender","nextProps","cloneElement","pendingContent","internalKeys","className","b-async-pending","PureComponent","propTypes","*","any","oneOfType","func","node","instanceOf","Promise","isRequired","defaultProps","createElement","keys"],"mappings":"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","file":"index.js","sourcesContent":["module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 3);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"boundless-utils-omit-keys\");\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys__);\nvar _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;};}();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 get=function get(base,path,fallback){return path.split('.').reduce(function(current,fragment){return current[fragment]||fallback;},base);};var Async=function(_React$PureComponent){_inherits(Async,_React$PureComponent);function Async(){var _ref;var _temp,_this,_ret;_classCallCheck(this,Async);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=_possibleConstructorReturn(this,(_ref=Async.__proto__||Object.getPrototypeOf(Async)).call.apply(_ref,[this].concat(args))),_this),_this.mounted=false,_this.promise=null,_this.state={},_temp),_possibleConstructorReturn(_this,_ret);}_createClass(Async,[{key:'handlePromiseFulfillment',value:function handlePromiseFulfillment(context,payload){if(!this.mounted){return;}this.setState(function renderPayloadIfPromiseMatches(state){if(this.promise===context){this.promise=null;return{component:payload};}return state;},this.fireRenderCallback);}},{key:'handleChildren',value:function handleChildren(children){var content=children;if(__WEBPACK_IMPORTED_MODULE_0_react___default.a.isValidElement(content)){return this.setState({component:content},this.fireRenderCallback);}else if(typeof content==='function'){return this.handleChildren(content(this.props));}var boundHandler=this.handlePromiseFulfillment.bind(this,content);this.promise=content;this.setState({component:null},function(){return content.then(boundHandler,boundHandler);});}},{key:'fireRenderCallback',value:function fireRenderCallback(){if(this.state.component){this.props.childrenDidRender();}}},{key:'componentWillMount',value:function componentWillMount(){this.handleChildren(this.props.children);}},{key:'componentDidMount',value:function componentDidMount(){this.mounted=true;}},{key:'componentWillReceiveProps',value:function componentWillReceiveProps(nextProps){this.handleChildren(nextProps.children);}},{key:'componentWillUnmount',value:function componentWillUnmount(){this.mounted=false;}},{key:'render',value:function render(){var props=this.props,state=this.state;return __WEBPACK_IMPORTED_MODULE_0_react___default.a.cloneElement(state.component||props.pendingContent,_extends({},__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys___default()(props,Async.internalKeys),{className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-async',props.className,state.component===null&&get(props,'pendingContent.props.className'),state.component&&get(state,'component.props.className',''),{'b-async-pending':state.component===null})}));}}]);return Async;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Async.propTypes={'*':__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].any,children:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].instanceOf(Promise)]).isRequired,childrenDidRender:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func,pendingContent:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node};Async.defaultProps={children:__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',null),childrenDidRender:function childrenDidRender(){},pendingContent:__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',null)};Async.internalKeys=Object.keys(Async.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Async;\n\n/***/ })\n/******/ ]);\n\n\n// WEBPACK FOOTER //\n// index.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 3);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap f51f05352d0e85e3a699","module.exports = require(\"boundless-utils-omit-keys\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"boundless-utils-omit-keys\"}\n// module id = 0\n// module chunks = 0","module.exports = require(\"classnames\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"classnames\"}\n// module id = 1\n// module chunks = 0","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"react\"}\n// module id = 2\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport omit from 'boundless-utils-omit-keys';\n\nconst get = (base, path, fallback) => path.split('.').reduce((current, fragment) => current[fragment] || fallback, base);\n\n/**\n * __A higher-order component for rendering data that isn't ready yet.__\n *\n * There are plenty of situations where you need to fetch content to be displayed, but want\n * to show some sort of loading graphic in the interim. This component helps to simplify\n * that pattern by handling common types of promises and providing a simple mechanism\n * for materializing the fulfilled payload into JSX.\n */\nexport default class Async extends React.PureComponent {\n    static propTypes = {\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes)\n         */\n        '*': PropTypes.any,\n\n        /**\n         * a promise, function that returns a promise, or other type of renderable content; if a function is passed, it will\n         * be called with the current props\n         *\n         * Promise example:\n         *\n         * ```jsx\n         * const listDataPromise = fetch('/some/list/data/endpoint').then(\n         *     (response) => response.ok ? response.json() : 'Failed to receive list data',\n         *     (error) => error.message,\n         * ).then((payload) => {\n         *     if (typeof payload === 'string') {\n         *         return (<div className='error'>{payload}</div>);\n         *     }\n         *\n         *     return (\n         *         <ul>\n         *             {payload.map((item) => (<li key={item.id}>{item.content}</li>))}\n         *         </ul>\n         *     );\n         * });\n         *\n         * <Async>{listDataPromise}</Async>\n         *\n         * Function example:\n         *\n         * ```jsx\n         * const fetchListData = (props) => fetch(props['data-endpoint']).then(\n         *     (response) => response.ok ? response.json() : 'Failed to receive list data',\n         *     (error) => error.message,\n         * ).then((payload) => {\n         *     if (typeof payload === 'string') {\n         *         return (<div className='error'>{payload}</div>);\n         *     }\n         *\n         *     return (\n         *         <ul>\n         *             {payload.map((item) => (<li key={item.id}>{item.content}</li>))}\n         *         </ul>\n         *     );\n         * });\n         *\n         * <Async data-endpoint='/some/list/data/endpoint'>{fetchListData}</Async>\n         * ```\n         */\n        children: PropTypes.oneOfType([\n            PropTypes.func,\n            PropTypes.node,\n            PropTypes.instanceOf(Promise),\n        ]).isRequired,\n\n        /** a callback for when real content has been rendered; this will be called immediately if normal JSX is passed to Async, or, in the case of a promise, upon resolution or rejection */\n        childrenDidRender: PropTypes.func,\n\n        /** content to be shown while the promise is in \"pending\" state (like a loading graphic, perhaps) */\n        pendingContent: PropTypes.node,\n    }\n\n    static defaultProps = {\n        children: <div />,\n        childrenDidRender: () => {},\n        pendingContent: <div />,\n    }\n\n    static internalKeys = Object.keys(Async.defaultProps)\n\n    mounted = false\n    promise = null\n    state = {}\n\n    handlePromiseFulfillment(context, payload) {\n        if (!this.mounted) { return; }\n\n        // only set the component if the promise that is fulfilled matches\n        // the one we're tracking in state, otherwise ignore it and retain the previous data\n        this.setState(function renderPayloadIfPromiseMatches(state) {\n            if (this.promise === context) {\n                this.promise = null;\n\n                return {component: payload};\n            }\n\n            return state;\n        }, this.fireRenderCallback);\n    }\n\n    handleChildren(children) {\n        let content = children;\n\n        if (React.isValidElement(content)) {\n            return this.setState({component: content}, this.fireRenderCallback);\n        } else if (typeof content === 'function') {\n            return this.handleChildren(content(this.props));\n        }\n\n        const boundHandler = this.handlePromiseFulfillment.bind(this, content);\n\n        // this is kept outside state so it can be set immediately if the props change\n        this.promise = content;\n\n        this.setState({component: null}, () => content.then(boundHandler, boundHandler));\n    }\n\n    fireRenderCallback() {\n        if (this.state.component) {\n            this.props.childrenDidRender();\n        }\n    }\n\n    componentWillMount()                 { this.handleChildren(this.props.children); }\n    componentDidMount()                  { this.mounted = true; }\n    componentWillReceiveProps(nextProps) { this.handleChildren(nextProps.children); }\n    componentWillUnmount()               { this.mounted = false; }\n\n    render() {\n        const {props, state} = this;\n\n        return React.cloneElement(state.component || props.pendingContent, {\n            ...omit(props, Async.internalKeys),\n            className: cx(\n                'b-async',\n                props.className,\n                state.component === null && get(props, 'pendingContent.props.className'),\n                state.component && get(state, 'component.props.className', ''),\n                {'b-async-pending': state.component === null}\n            ),\n        });\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-async/index.js"],"sourceRoot":""}

@@ -6,5 +6,5 @@ import React, {PropTypes} from 'react';

const get = (base, path, fallback) => path.split('.').reduce((current, fragment) => current[fragment] || fallback, base);
/**
* # Async
* __A higher-order component for rendering data that isn't ready yet.__

@@ -15,28 +15,73 @@ *

* that pattern by handling common types of promises and providing a simple mechanism
* for materializing the resolved data into JSX.
* for materializing the fulfilled payload into JSX.
*/
export default class Async extends React.PureComponent {
static propTypes = {
/** a callback for when real content has been rendered; either normal passed data or when a passed promise resolves */
contentRenderedFunc: PropTypes.func,
/**
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes)
*/
'*': PropTypes.any,
/** a function that takes the resolved payload of a promise provided by `props.data` and returns renderable JSX; defaults to trying to render the resolved value of the Promise */
convertToJSXFunc: PropTypes.func,
/**
* a promise, function that returns a promise, or other type of renderable content; if a function is passed, it will
* be called with the current props
*
* Promise example:
*
* ```jsx
* const listDataPromise = fetch('/some/list/data/endpoint').then(
* (response) => response.ok ? response.json() : 'Failed to receive list data',
* (error) => error.message,
* ).then((payload) => {
* if (typeof payload === 'string') {
* return (<div className='error'>{payload}</div>);
* }
*
* return (
* <ul>
* {payload.map((item) => (<li key={item.id}>{item.content}</li>))}
* </ul>
* );
* });
*
* <Async>{listDataPromise}</Async>
*
* Function example:
*
* ```jsx
* const fetchListData = (props) => fetch(props['data-endpoint']).then(
* (response) => response.ok ? response.json() : 'Failed to receive list data',
* (error) => error.message,
* ).then((payload) => {
* if (typeof payload === 'string') {
* return (<div className='error'>{payload}</div>);
* }
*
* return (
* <ul>
* {payload.map((item) => (<li key={item.id}>{item.content}</li>))}
* </ul>
* );
* });
*
* <Async data-endpoint='/some/list/data/endpoint'>{fetchListData}</Async>
* ```
*/
children: PropTypes.oneOfType([
PropTypes.func,
PropTypes.node,
PropTypes.instanceOf(Promise),
]).isRequired,
/** a promise, or some other piece of data to be run through `props.convertToJSXFunc` */
data: PropTypes.any,
/** a callback for when real content has been rendered; this will be called immediately if normal JSX is passed to Async, or, in the case of a promise, upon resolution or rejection */
childrenDidRender: PropTypes.func,
/** content to be shown if the promise is rejected */
errorContent: PropTypes.node,
/** content to be shown while the promise is in pending state */
loadingContent: PropTypes.node,
/** content to be shown while the promise is in "pending" state (like a loading graphic, perhaps) */
pendingContent: PropTypes.node,
}
static defaultProps = {
contentRenderedFunc: () => {},
convertToJSXFunc: (x) => x,
data: null,
errorContent: '⚠️',
loadingContent: null,
children: <div />,
childrenDidRender: () => {},
pendingContent: <div />,
}

@@ -47,60 +92,63 @@

mounted = false
promise = null
state = {}
convertDataToJSXOrWait(props = this.props) {
const {data} = props;
handlePromiseFulfillment(context, payload) {
if (!this.mounted) { return; }
if (data instanceof Promise) {
this.setState({component: null});
// only set the component if the promise that is fulfilled matches
// the one we're tracking in state, otherwise ignore it and retain the previous data
this.setState(function renderPayloadIfPromiseMatches(state) {
if (this.promise === context) {
this.promise = null;
return data.then((payload) => {
if (this.mounted) {
// only replace if we're looking at the same promise, otherwise do nothing
this.setState((state, currentProps) => ({
component: currentProps.data === data
? currentProps.convertToJSXFunc(payload)
: state.component,
}));
}
}, () => this.setState({component: false}));
return {component: payload};
}
return state;
}, this.fireRenderCallback);
}
handleChildren(children) {
let content = children;
if (React.isValidElement(content)) {
return this.setState({component: content}, this.fireRenderCallback);
} else if (typeof content === 'function') {
return this.handleChildren(content(this.props));
}
this.setState({component: props.convertToJSXFunc(data)});
const boundHandler = this.handlePromiseFulfillment.bind(this, content);
// this is kept outside state so it can be set immediately if the props change
this.promise = content;
this.setState({component: null}, () => content.then(boundHandler, boundHandler));
}
fireCallbackIfDataRendered() {
fireRenderCallback() {
if (this.state.component) {
this.props.contentRenderedFunc();
this.props.childrenDidRender();
}
}
componentWillMount() { this.convertDataToJSXOrWait(); }
componentDidMount() { this.mounted = true; this.fireCallbackIfDataRendered(); }
componentDidUpdate() { this.fireCallbackIfDataRendered(); }
componentWillReceiveProps(nextProps) { this.convertDataToJSXOrWait(nextProps); }
componentWillMount() { this.handleChildren(this.props.children); }
componentDidMount() { this.mounted = true; }
componentWillReceiveProps(nextProps) { this.handleChildren(nextProps.children); }
componentWillUnmount() { this.mounted = false; }
getClasses(extraClasses) {
return cx('b-async', this.props.className, extraClasses, {
'b-async-error': this.state.component === false,
'b-async-loading': this.state.component === null,
});
}
render() {
if (this.state.component === null || this.state.component === false) {
return (
<div {...omit(this.props, Async.internalKeys)} className={this.getClasses()}>
{this.state.component === null
? this.props.loadingContent
: this.props.errorContent}
</div>
);
}
const {props, state} = this;
return React.cloneElement(this.state.component, {
...omit(this.props, Async.internalKeys),
className: this.getClasses(this.state.component.props && this.state.component.props.className),
return React.cloneElement(state.component || props.pendingContent, {
...omit(props, Async.internalKeys),
className: cx(
'b-async',
props.className,
state.component === null && get(props, 'pendingContent.props.className'),
state.component && get(state, 'component.props.className', ''),
{'b-async-pending': state.component === null}
),
});
}
}

@@ -5,7 +5,6 @@ /* eslint no-unused-expressions:0 */

import ReactDOM from 'react-dom';
import {identity} from 'lodash';
import sinon from 'sinon';
import Async from './index';
import conformanceChecker from '../boundless-utils-conformance/index';
import {$, conformanceChecker} from '../boundless-utils-test-helpers/index';

@@ -25,56 +24,48 @@ describe('Async higher-order component', () => {

it('accepts normal renderable content', () => {
render(<Async data={<span className='bar'>foo</span>} />);
expect(document.querySelector('.bar')).not.toBeNull();
render(<Async><span className='bar'>foo</span></Async>);
expect($('.bar')).not.toBeNull();
});
it('calls contentRenderedFunc() upon successful rendering of passed data', () => {
const stub = sandbox.stub();
render(<Async contentRenderedFunc={stub} data={<span className='bar'>foo</span>} />);
expect(stub.calledOnce).toBe(true);
expect(document.querySelector('.bar')).not.toBeNull();
});
describe('promise support', () => {
it('accepts a promise as props.data', () => {
const promise = Promise.resolve(<span className='bar'>foo</span>);
it('renders the promise\'s payload on resolution', () => {
render(
<Async>
{Promise.resolve(<span className='bar'>foo</span>)}
</Async>
);
render(<Async data={promise} />);
return Promise.resolve().then(() => {
expect(document.querySelector('.bar')).not.toBeNull();
expect($('.bar')).not.toBeNull();
});
});
it('displays loading content while the promise is pending', () => {
render(<Async data={new Promise(() => {})} loadingContent='⏲' />);
it('renders the promise\'s payload on rejection', () => {
render(
<Async>
{Promise.reject(<span className='bar'>foo</span>)}
</Async>
);
return Promise.resolve().then(() => {
expect(document.querySelector('.b-async-loading')).not.toBeNull();
expect(document.querySelector('.b-async-loading').textContent).toBe('⏲');
expect($('.bar')).not.toBeNull();
});
});
it('displays error content if the promise rejects', () => {
let rejector;
const promise = new Promise((_, reject) => (rejector = reject));
it('renders pending content if provided until the child promise has been fulfilled', () => {
let resolver;
render(<Async data={promise} errorContent='😞' />);
rejector();
render(
<Async pendingContent={<i className='loading'>⏲</i>}>
{new Promise((resolve) => (resolver = resolve))}
</Async>
);
return Promise.resolve().then(() => {
expect(document.querySelector('.b-async-error')).not.toBeNull();
expect(document.querySelector('.b-async-error').textContent).toBe('😞');
});
});
expect($('.loading')).not.toBeNull();
expect($('.loading').textContent).toBe('⏲');
it('calls convertToJSXFunc when the promise resolves', () => {
const promise = Promise.resolve({children: 'foo', className: 'bar'});
const converter = sandbox.spy((data) => <span {...data} />);
resolver(<span className='bar'>foo</span>);
render(<Async convertToJSXFunc={converter} data={promise} />);
return Promise.resolve().then(() => {
expect(converter.calledOnce).toBe(true);
expect(document.querySelector('.bar')).not.toBeNull();
expect($('.loading')).toBeNull();
expect($('.bar')).not.toBeNull();
});

@@ -86,8 +77,5 @@ });

let resolver2;
const promise1 = new Promise((resolve) => (resolver1 = resolve));
const promise2 = new Promise((resolve) => (resolver2 = resolve));
const converter = sandbox.spy(identity);
render(<Async data={promise1} convertToJSXFunc={converter} />);
render(<Async data={promise2} convertToJSXFunc={converter} />);
render(<Async>{new Promise((resolve) => (resolver1 = resolve))}</Async>);
render(<Async>{new Promise((resolve) => (resolver2 = resolve))}</Async>);

@@ -98,24 +86,68 @@ resolver2(<span className='bar'>foo</span>);

return Promise.resolve().then(() => {
expect(converter.calledOnce).toBe(true);
expect(document.querySelector('.bar')).not.toBeNull();
expect(document.querySelector('.fizz')).toBeNull();
expect($('.bar')).not.toBeNull();
expect($('.fizz')).toBeNull();
});
});
});
it('calls contentRenderedFunc() once the promise has resolved', () => {
let resolver1;
const promise1 = new Promise((resolve) => (resolver1 = resolve));
describe('props.childrenDidRender function', () => {
it('is called when the passed child content is rendered', () => {
const stub = sandbox.stub();
render(<Async contentRenderedFunc={stub} data={promise1} convertToJSXFunc={identity} />);
expect(stub.notCalled).toBe(true);
render(<Async childrenDidRender={stub}><span className='bar'>foo</span></Async>);
expect(stub.calledOnce).toBe(true);
expect($('.bar')).not.toBeNull();
});
resolver1(<span className='fizz'>buzz</span>);
it('is called when a passed child promise is fulfilled and then rendered', () => {
const stub = sandbox.stub();
let resolver;
render(
<Async childrenDidRender={stub}>
{new Promise((resolve) => (resolver = resolve))}
</Async>
);
expect(stub.called).toBe(false);
resolver(<span className='bar'>foo</span>);
return Promise.resolve().then(() => {
expect(stub.calledOnce).toBe(true);
expect(document.querySelector('.fizz')).not.toBeNull();
expect($('.bar')).not.toBeNull();
});
});
it('is called when a passed child function returns JSX, which is rendered immediately', () => {
const stub = sandbox.stub();
render(
<Async childrenDidRender={stub}>
{() => <span className='bar'>foo</span>}
</Async>
);
expect(stub.calledOnce).toBe(true);
expect($('.bar')).not.toBeNull();
});
it('is called when a passed child function returns a promise and that promise is later fulfilled', () => {
const stub = sandbox.stub();
let resolver;
render(
<Async childrenDidRender={stub}>
{() => new Promise((resolve) => (resolver = resolve))}
</Async>
);
expect(stub.called).toBe(false);
resolver(<span className='bar'>foo</span>);
return Promise.resolve().then(() => {
expect(stub.calledOnce).toBe(true);
expect($('.bar')).not.toBeNull();
});
});
});
});
{
"name": "boundless-async",
"version": "1.0.0-beta.6",
"version": "1.0.0-beta.7",
"description": "A higher-order component for rendering data that isn't ready yet.",

@@ -24,3 +24,3 @@ "author": "Evan Scott <glitterbyte@gmail.com> (http://yaycmyk.com) (http://yaycmyk.com)",

"dependencies": {
"boundless-utils-omit-keys": "^1.0.0-beta.6",
"boundless-utils-omit-keys": "^1.0.0-beta.7",
"classnames": "^2.1.5"

@@ -27,0 +27,0 @@ },

@@ -0,4 +1,6 @@

<!---
THIS IS AN AUTOGENERATED FILE. EDIT INDEX.JS INSTEAD.
-->
# Async
# Async
__A higher-order component for rendering data that isn't ready yet.__

@@ -9,60 +11,96 @@

that pattern by handling common types of promises and providing a simple mechanism
for materializing the resolved data into JSX.
for materializing the fulfilled payload into JSX.
## Props
_Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Async#props)._
> Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Async#props).
### Required Props
There are no required props.
- __`children`__ ・ a promise, function that returns a promise, or other type of renderable content; if a function is passed, it will
be called with the current props
Promise example:
```jsx
const listDataPromise = fetch('/some/list/data/endpoint').then(
(response) => response.ok ? response.json() : 'Failed to receive list data',
(error) => error.message,
).then((payload) => {
if (typeof payload === 'string') {
return (<div className='error'>{payload}</div>);
}
return (
<ul>
{payload.map((item) => (<li key={item.id}>{item.content}</li>))}
</ul>
);
});
<Async>{listDataPromise}</Async>
Function example:
```jsx
const fetchListData = (props) => fetch(props['data-endpoint']).then(
(response) => response.ok ? response.json() : 'Failed to receive list data',
(error) => error.message,
).then((payload) => {
if (typeof payload === 'string') {
return (<div className='error'>{payload}</div>);
}
return (
<ul>
{payload.map((item) => (<li key={item.id}>{item.content}</li>))}
</ul>
);
});
<Async data-endpoint='/some/list/data/endpoint'>{fetchListData}</Async>
```
Expects | Default Value
- | -
`function or any renderable or Promise` | `<div />`
### Optional Props
<table>
<tr>
<th>Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Description</th>
</tr>
- __`*`__ ・ any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes)
<tr>
<td>contentRenderedFunc</td>
<td><pre><code>function</code></pre></td>
<td><pre><code class="language-js">() => {}</code></pre></td>
<td>a callback for when real content has been rendered; either normal passed data or when a passed promise resolves</td>
</tr>
Expects | Default Value
- | -
`any` | `n/a`
<tr>
<td>convertToJSXFunc</td>
<td><pre><code>function</code></pre></td>
<td><pre><code class="language-js">(x) => x</code></pre></td>
<td>a function that takes the resolved payload of a promise provided by `props.data` and returns renderable JSX; defaults to trying to render the resolved value of the Promise</td>
</tr>
- __`childrenDidRender`__ ・ a callback for when real content has been rendered; this will be called immediately if normal JSX is passed to Async, or, in the case of a promise, upon resolution or rejection
<tr>
<td>data</td>
<td><pre><code>any</code></pre></td>
<td><pre><code class="language-js">null</code></pre></td>
<td>a promise, or some other piece of data to be run through `props.convertToJSXFunc`</td>
</tr>
Expects | Default Value
- | -
`function` | `() => {}`
<tr>
<td>errorContent</td>
<td><pre><code>any renderable</code></pre></td>
<td><pre><code class="language-js">'⚠️'</code></pre></td>
<td>content to be shown if the promise is rejected</td>
</tr>
- __`pendingContent`__ ・ content to be shown while the promise is in "pending" state (like a loading graphic, perhaps)
<tr>
<td>loadingContent</td>
<td><pre><code>any renderable</code></pre></td>
<td><pre><code class="language-js">null</code></pre></td>
<td>content to be shown while the promise is in pending state</td>
</tr>
Expects | Default Value
- | -
`any renderable` | `<div />`
</table>
## Reference Styles
### Stylus
```stylus
// Bring in Boundless's base Stylus variables
@require "node_modules/boundless-async/variables"
// Redefine any variables as desired, e.g.
color-accent = royalblue
// Bring in the component styles; they will be autoconfigured based on the above
@require "node_modules/boundless-async/style"
```
### CSS
If desired, a precompiled plain CSS stylesheet is available for customization at `/build/style.css`, based on Boundless's [default variables](https://github.com/enigma-io/boundless/blob/master/variables.styl).

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc