boundless-image
Advanced tools
Comparing version 1.0.0-beta.4 to 1.0.0-beta.5
@@ -1,2 +0,2 @@ | ||
module.exports=function(e){function t(r){if(s[r])return s[r].exports;var a=s[r]={i:r,l:!1,exports:{}};return e[r].call(a.exports,a,a.exports,t),a.l=!0,a.exports}var s={};return t.m=e,t.c=s,t.i=function(e){return e},t.d=function(e,s,r){t.o(e,s)||Object.defineProperty(e,s,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var s=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(s,"a",s),s},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=4)}([function(e,t,s){"use strict";function r(){}t.a=r},function(e,t,s){"use strict";function r(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];return Object.keys(e).reduce(function(s,r){return t.indexOf(r)===-1&&(s[r]=e[r]),s},{})}t.a=r},function(e,t){e.exports=require("react")},function(e,t){e.exports=require("classnames")},function(e,t,s){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=s(2),a=s.n(r),o=s(3),n=s.n(o),i=s(0),l=s(1),u=function(e){function t(){var e,s,r,a;babelHelpers.classCallCheck(this,t);for(var o=arguments.length,n=Array(o),i=0;i<o;i++)n[i]=arguments[i];return s=r=babelHelpers.possibleConstructorReturn(this,(e=t.__proto__||Object.getPrototypeOf(t)).call.apply(e,[this].concat(n))),r.state={status:t.status.LOADING},a=s,babelHelpers.possibleConstructorReturn(r,a)}return babelHelpers.inherits(t,e),babelHelpers.createClass(t,[{key:"componentWillReceiveProps",value:function(e){e.src!==this.props.src&&(this.resetPreloader(),this.setState({status:t.status.LOADING}))}},{key:"componentDidMount",value:function(){this.preload()}},{key:"componentDidUpdate",value:function(){this.preload()}},{key:"componentWillUnmount",value:function(){this.resetPreloader()}},{key:"resetPreloader",value:function(){this.loader.onload=null,this.loader.onerror=null,this.loader=null}},{key:"preload",value:function(){var e=this;this.loader||(this.loader=document.createElement("img"),this.loader.onload=function(){return e.setState({status:t.status.LOADED})},this.loader.onerror=function(){return e.setState({status:t.status.ERROR})},this.loader.src=this.props.src)}},{key:"renderImage",value:function(){return this.props.displayAsBackgroundImage?a.a.createElement("div",babelHelpers.extends({},this.props.imageProps,{ref:"image",className:n()("b-image",this.props.imageProps.className),title:this.props.alt,style:babelHelpers.extends({},this.props.imageProps.style,{backgroundImage:"url("+this.props.src+")"})})):a.a.createElement("img",babelHelpers.extends({},this.props.imageProps,{ref:"image",className:n()("b-image",this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:i.a,onError:i.a}))}},{key:"renderStatus",value:function(){return a.a.createElement("div",babelHelpers.extends({},this.props.statusProps,{ref:"status",className:n()("b-image-status",this.props.statusProps.className,{"b-image-loading":this.state.status===t.status.LOADING,"b-image-loaded":this.state.status===t.status.LOADED,"b-image-error":this.state.status===t.status.ERROR}),role:"presentation"}))}},{key:"render",value:function(){return a.a.createElement("div",babelHelpers.extends({},s.i(l.a)(this.props,t.internalKeys),{ref:"wrapper",className:n()("b-image-wrapper",this.props.className)}),this.renderImage(),this.renderStatus())}}]),t}(a.a.PureComponent);u.status={LOADING:"LOADING",LOADED:"LOADED",ERROR:"ERROR"},u.propTypes={alt:r.PropTypes.string,displayAsBackgroundImage:r.PropTypes.bool,imageProps:r.PropTypes.object,src:r.PropTypes.string.isRequired,statusProps:r.PropTypes.object},u.defaultProps={alt:null,displayAsBackgroundImage:!1,imageProps:{},src:"about:blank",statusProps:{}},u.internalKeys=Object.keys(u.defaultProps),t.default=u}]); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap ffd6bb457f49f2852b46","webpack:///./packages/boundless-utils-noop/index.js","webpack:///./packages/boundless-utils-omit-keys/index.js","webpack:///external {\"amd\":\"react\",\"commonjs2\":\"react\",\"root\":\"React\"}","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///./packages/boundless-image/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__","noop","omitKeysFromSourceObject","source","omittedKeys","arguments","length","undefined","keys","reduce","hash","key","indexOf","require","__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_noop_index__","__WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__","Image","_React$PureComponent","_ref","_temp","_this","_ret","babelHelpers","classCallCheck","this","_len","args","Array","_key","possibleConstructorReturn","__proto__","getPrototypeOf","apply","concat","state","status","LOADING","inherits","createClass","nextProps","src","props","resetPreloader","setState","preload","loader","onload","onerror","_this2","document","createElement","LOADED","ERROR","displayAsBackgroundImage","a","extends","imageProps","ref","className","title","alt","style","backgroundImage","onLoad","onError","statusProps","b-image-loading","b-image-loaded","b-image-error","role","internalKeys","renderImage","renderStatus","PureComponent","propTypes","string","bool","isRequired","defaultProps"],"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 = 4);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = noop;\nfunction noop(){}\n\n/***/ }),\n/* 1 */\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/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 4 */\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__(3);\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_noop_index__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__ = __webpack_require__(1);\nvar Image=function(_React$PureComponent){babelHelpers.inherits(Image,_React$PureComponent);function Image(){var _ref;var _temp,_this,_ret;babelHelpers.classCallCheck(this,Image);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=babelHelpers.possibleConstructorReturn(this,(_ref=Image.__proto__||Object.getPrototypeOf(Image)).call.apply(_ref,[this].concat(args))),_this),_this.state={status:Image.status.LOADING},_temp),babelHelpers.possibleConstructorReturn(_this,_ret);}babelHelpers.createClass(Image,[{key:'componentWillReceiveProps',value:function componentWillReceiveProps(nextProps){if(nextProps.src!==this.props.src){this.resetPreloader();this.setState({status:Image.status.LOADING});}}},{key:'componentDidMount',value:function componentDidMount(){this.preload();}},{key:'componentDidUpdate',value:function componentDidUpdate(){this.preload();}},{key:'componentWillUnmount',value:function componentWillUnmount(){this.resetPreloader();}},{key:'resetPreloader',value:function resetPreloader(){this.loader.onload=null;this.loader.onerror=null;this.loader=null;}},{key:'preload',value:function preload(){var _this2=this;if(this.loader){return;}this.loader=document.createElement('img');this.loader.onload=function(){return _this2.setState({status:Image.status.LOADED});};this.loader.onerror=function(){return _this2.setState({status:Image.status.ERROR});};this.loader.src=this.props.src;}},{key:'renderImage',value:function renderImage(){if(this.props.displayAsBackgroundImage){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',babelHelpers.extends({},this.props.imageProps,{ref:'image',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image',this.props.imageProps.className),title:this.props.alt,style:babelHelpers.extends({},this.props.imageProps.style,{backgroundImage:'url('+this.props.src+')'})}));}return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('img',babelHelpers.extends({},this.props.imageProps,{ref:'image',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image',this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:__WEBPACK_IMPORTED_MODULE_2__boundless_utils_noop_index__[\"a\" /* default */],onError:__WEBPACK_IMPORTED_MODULE_2__boundless_utils_noop_index__[\"a\" /* default */]}));}},{key:'renderStatus',value:function renderStatus(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',babelHelpers.extends({},this.props.statusProps,{ref:'status',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image-status',this.props.statusProps.className,{'b-image-loading':this.state.status===Image.status.LOADING,'b-image-loaded':this.state.status===Image.status.LOADED,'b-image-error':this.state.status===Image.status.ERROR}),role:'presentation'}));}},{key:'render',value:function render(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',babelHelpers.extends({},__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__[\"a\" /* default */])(this.props,Image.internalKeys),{ref:'wrapper',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image-wrapper',this.props.className)}),this.renderImage(),this.renderStatus());}}]);return Image;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Image.status={LOADING:'LOADING',LOADED:'LOADED',ERROR:'ERROR'};Image.propTypes={alt:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,displayAsBackgroundImage:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,imageProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object,src:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string.isRequired,statusProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object};Image.defaultProps={alt:null,displayAsBackgroundImage:false,imageProps:{},src:'about:blank',statusProps:{}};Image.internalKeys=Object.keys(Image.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Image;\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 = 4);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap ffd6bb457f49f2852b46","/**\n * A dummy function with no side effects. Commonly used when mocking interfaces.\n */\nexport default function noop() {}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-noop/index.js","/**\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\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-omit-keys/index.js","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"amd\":\"react\",\"commonjs2\":\"react\",\"root\":\"React\"}\n// module id = 2\n// module chunks = 0","module.exports = require(\"classnames\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"classnames\"}\n// module id = 3\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport noop from '../boundless-utils-noop/index';\nimport omit from '../boundless-utils-omit-keys/index';\n\n/**\n# Image\n__An image block with placeholder support for loading and fallback scenarios.__\n */\nexport default class Image extends React.PureComponent {\n    static status = {\n        LOADING: 'LOADING',\n        LOADED: 'LOADED',\n        ERROR: 'ERROR',\n    }\n\n    static propTypes = {\n        /**\n         * a written description of the image for search engines, hovertext and those using accessibility technologies; applied to the `.b-image` as the HTML attributes `alt` or `title`, depending on the type of rendered node\n         */\n        alt: PropTypes.string,\n\n        /**\n         * emits the image as a `<div>` with `background-image` css property set instead of `<img>`\n         */\n        displayAsBackgroundImage: PropTypes.bool,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image` node\n         */\n        imageProps: PropTypes.object,\n\n        /**\n         * a valid path to the desired image\n         */\n        src: PropTypes.string.isRequired,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image-status` node\n         */\n        statusProps: PropTypes.object,\n    }\n\n    static defaultProps = {\n        alt: null,\n        displayAsBackgroundImage: false,\n        imageProps: {},\n        src: 'about:blank',\n        statusProps: {},\n    }\n\n    static internalKeys = Object.keys(Image.defaultProps)\n\n    state = {\n        status: Image.status.LOADING,\n    }\n\n    componentWillReceiveProps(nextProps) {\n        if (nextProps.src !== this.props.src) {\n            this.resetPreloader();\n            this.setState({status: Image.status.LOADING});\n        }\n    }\n\n    componentDidMount() {\n        this.preload();\n    }\n\n    componentDidUpdate() {\n        this.preload();\n    }\n\n    componentWillUnmount() {\n        this.resetPreloader();\n    }\n\n    resetPreloader() {\n        this.loader.onload = null;\n        this.loader.onerror = null;\n        this.loader = null;\n    }\n\n    preload() {\n        if (this.loader) { return; }\n\n        this.loader = document.createElement('img');\n\n        this.loader.onload = () => this.setState({status: Image.status.LOADED});\n        this.loader.onerror = () => this.setState({status: Image.status.ERROR});\n\n        this.loader.src = this.props.src;\n    }\n\n    renderImage() {\n        if (this.props.displayAsBackgroundImage) {\n            return (\n                <div\n                    {...this.props.imageProps}\n                    ref='image'\n                    className={cx('b-image', this.props.imageProps.className)}\n                    title={this.props.alt}\n                    style={{\n                        ...this.props.imageProps.style,\n                        backgroundImage: `url(${this.props.src})`,\n                    }} />\n            );\n        }\n\n        return (\n            <img\n                {...this.props.imageProps}\n                ref='image'\n                className={cx('b-image', this.props.imageProps.className)}\n                src={this.props.src}\n                alt={this.props.alt}\n                onLoad={noop}\n                onError={noop} />\n        );\n    }\n\n    renderStatus() {\n        return (\n            <div {...this.props.statusProps}\n                 ref='status'\n                 className={cx('b-image-status', this.props.statusProps.className, {\n                    'b-image-loading': this.state.status === Image.status.LOADING,\n                    'b-image-loaded': this.state.status === Image.status.LOADED,\n                    'b-image-error': this.state.status === Image.status.ERROR,\n                 })}\n                 role='presentation' />\n        );\n    }\n\n    render() {\n        return (\n            <div\n                {...omit(this.props, Image.internalKeys)}\n                ref='wrapper'\n                className={cx('b-image-wrapper', this.props.className)}>\n                {this.renderImage()}\n                {this.renderStatus()}\n            </div>\n        );\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-image/index.js"],"sourceRoot":""} | ||
module.exports=function(e){function t(s){if(r[s])return r[s].exports;var o=r[s]={i:s,l:!1,exports:{}};return e[s].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var r={};return t.m=e,t.c=r,t.i=function(e){return e},t.d=function(e,r,s){t.o(e,r)||Object.defineProperty(e,r,{configurable:!1,enumerable:!0,get:s})},t.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(r,"a",r),r},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=4)}([function(e,t,r){"use strict";function s(){}t.a=s},function(e,t,r){"use strict";function s(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];return Object.keys(e).reduce(function(r,s){return t.indexOf(s)===-1&&(r[s]=e[s]),r},{})}t.a=s},function(e,t){e.exports=require("classnames")},function(e,t){e.exports=require("react")},function(e,t,r){"use strict";function s(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function n(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var a=r(3),i=r.n(a),u=r(2),p=r.n(u),l=r(0),c=r(1),f=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var s in r)Object.prototype.hasOwnProperty.call(r,s)&&(e[s]=r[s])}return e},d=function(){function e(e,t){for(var r=0;r<t.length;r++){var s=t[r];s.enumerable=s.enumerable||!1,s.configurable=!0,"value"in s&&(s.writable=!0),Object.defineProperty(e,s.key,s)}}return function(t,r,s){return r&&e(t.prototype,r),s&&e(t,s),t}}(),m=function(e){function t(){var e,r,n,a;s(this,t);for(var i=arguments.length,u=Array(i),p=0;p<i;p++)u[p]=arguments[p];return r=n=o(this,(e=t.__proto__||Object.getPrototypeOf(t)).call.apply(e,[this].concat(u))),n.state={status:t.status.LOADING},a=r,o(n,a)}return n(t,e),d(t,[{key:"componentWillReceiveProps",value:function(e){e.src!==this.props.src&&(this.resetPreloader(),this.setState({status:t.status.LOADING}))}},{key:"componentDidMount",value:function(){this.preload()}},{key:"componentDidUpdate",value:function(){this.preload()}},{key:"componentWillUnmount",value:function(){this.resetPreloader()}},{key:"resetPreloader",value:function(){this.loader.onload=null,this.loader.onerror=null,this.loader=null}},{key:"preload",value:function(){var e=this;this.loader||(this.loader=document.createElement("img"),this.loader.onload=function(){return e.setState({status:t.status.LOADED})},this.loader.onerror=function(){return e.setState({status:t.status.ERROR})},this.loader.src=this.props.src)}},{key:"renderImage",value:function(){return this.props.displayAsBackgroundImage?i.a.createElement("div",f({},this.props.imageProps,{ref:"image",className:p()("b-image",this.props.imageProps.className),title:this.props.alt,style:f({},this.props.imageProps.style,{backgroundImage:"url("+this.props.src+")"})})):i.a.createElement("img",f({},this.props.imageProps,{ref:"image",className:p()("b-image",this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:l.a,onError:l.a}))}},{key:"renderStatus",value:function(){return i.a.createElement("div",f({},this.props.statusProps,{ref:"status",className:p()("b-image-status",this.props.statusProps.className,{"b-image-loading":this.state.status===t.status.LOADING,"b-image-loaded":this.state.status===t.status.LOADED,"b-image-error":this.state.status===t.status.ERROR}),role:"presentation"}))}},{key:"render",value:function(){return i.a.createElement("div",f({},r.i(c.a)(this.props,t.internalKeys),{ref:"wrapper",className:p()("b-image-wrapper",this.props.className)}),this.renderImage(),this.renderStatus())}}]),t}(i.a.PureComponent);m.status={LOADING:"LOADING",LOADED:"LOADED",ERROR:"ERROR"},m.propTypes={alt:a.PropTypes.string,displayAsBackgroundImage:a.PropTypes.bool,imageProps:a.PropTypes.object,src:a.PropTypes.string.isRequired,statusProps:a.PropTypes.object},m.defaultProps={alt:null,displayAsBackgroundImage:!1,imageProps:{},src:"about:blank",statusProps:{}},m.internalKeys=Object.keys(m.defaultProps),t.default=m}]); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap af5ab0760b8021b0ba16","webpack:///./packages/boundless-utils-noop/index.js","webpack:///./packages/boundless-utils-omit-keys/index.js","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///external {\"commonjs2\":\"react\"}","webpack:///./packages/boundless-image/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__","noop","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_noop_index__","__WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__","_extends","assign","target","_createClass","defineProperties","props","descriptor","protoProps","staticProps","Image","_React$PureComponent","_ref","_temp","_this","_ret","this","_len","args","Array","_key","getPrototypeOf","apply","concat","state","status","LOADING","nextProps","src","resetPreloader","setState","preload","loader","onload","onerror","_this2","document","createElement","LOADED","ERROR","displayAsBackgroundImage","a","imageProps","ref","className","title","alt","style","backgroundImage","onLoad","onError","statusProps","b-image-loading","b-image-loaded","b-image-error","role","internalKeys","renderImage","renderStatus","PureComponent","propTypes","string","bool","isRequired","defaultProps"],"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 = 4);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = noop;\nfunction noop(){}\n\n/***/ }),\n/* 1 */\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/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 4 */\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__(3);\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__(2);\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_noop_index__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__ = __webpack_require__(1);\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 Image=function(_React$PureComponent){_inherits(Image,_React$PureComponent);function Image(){var _ref;var _temp,_this,_ret;_classCallCheck(this,Image);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=_possibleConstructorReturn(this,(_ref=Image.__proto__||Object.getPrototypeOf(Image)).call.apply(_ref,[this].concat(args))),_this),_this.state={status:Image.status.LOADING},_temp),_possibleConstructorReturn(_this,_ret);}_createClass(Image,[{key:'componentWillReceiveProps',value:function componentWillReceiveProps(nextProps){if(nextProps.src!==this.props.src){this.resetPreloader();this.setState({status:Image.status.LOADING});}}},{key:'componentDidMount',value:function componentDidMount(){this.preload();}},{key:'componentDidUpdate',value:function componentDidUpdate(){this.preload();}},{key:'componentWillUnmount',value:function componentWillUnmount(){this.resetPreloader();}},{key:'resetPreloader',value:function resetPreloader(){this.loader.onload=null;this.loader.onerror=null;this.loader=null;}},{key:'preload',value:function preload(){var _this2=this;if(this.loader){return;}this.loader=document.createElement('img');this.loader.onload=function(){return _this2.setState({status:Image.status.LOADED});};this.loader.onerror=function(){return _this2.setState({status:Image.status.ERROR});};this.loader.src=this.props.src;}},{key:'renderImage',value:function renderImage(){if(this.props.displayAsBackgroundImage){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},this.props.imageProps,{ref:'image',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image',this.props.imageProps.className),title:this.props.alt,style:_extends({},this.props.imageProps.style,{backgroundImage:'url('+this.props.src+')'})}));}return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('img',_extends({},this.props.imageProps,{ref:'image',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image',this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:__WEBPACK_IMPORTED_MODULE_2__boundless_utils_noop_index__[\"a\" /* default */],onError:__WEBPACK_IMPORTED_MODULE_2__boundless_utils_noop_index__[\"a\" /* default */]}));}},{key:'renderStatus',value:function renderStatus(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},this.props.statusProps,{ref:'status',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image-status',this.props.statusProps.className,{'b-image-loading':this.state.status===Image.status.LOADING,'b-image-loaded':this.state.status===Image.status.LOADED,'b-image-error':this.state.status===Image.status.ERROR}),role:'presentation'}));}},{key:'render',value:function render(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__boundless_utils_omit_keys_index__[\"a\" /* default */])(this.props,Image.internalKeys),{ref:'wrapper',className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image-wrapper',this.props.className)}),this.renderImage(),this.renderStatus());}}]);return Image;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Image.status={LOADING:'LOADING',LOADED:'LOADED',ERROR:'ERROR'};Image.propTypes={alt:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,displayAsBackgroundImage:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,imageProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object,src:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string.isRequired,statusProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object};Image.defaultProps={alt:null,displayAsBackgroundImage:false,imageProps:{},src:'about:blank',statusProps:{}};Image.internalKeys=Object.keys(Image.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Image;\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 = 4);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap af5ab0760b8021b0ba16","/**\n * A dummy function with no side effects. Commonly used when mocking interfaces.\n */\nexport default function noop() {}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-noop/index.js","/**\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\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 = 2\n// module chunks = 0","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"react\"}\n// module id = 3\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport noop from '../boundless-utils-noop/index';\nimport omit from '../boundless-utils-omit-keys/index';\n\n/**\n# Image\n__An image block with placeholder support for loading and fallback scenarios.__\n */\nexport default class Image extends React.PureComponent {\n    static status = {\n        LOADING: 'LOADING',\n        LOADED: 'LOADED',\n        ERROR: 'ERROR',\n    }\n\n    static propTypes = {\n        /**\n         * a written description of the image for search engines, hovertext and those using accessibility technologies; applied to the `.b-image` as the HTML attributes `alt` or `title`, depending on the type of rendered node\n         */\n        alt: PropTypes.string,\n\n        /**\n         * emits the image as a `<div>` with `background-image` css property set instead of `<img>`\n         */\n        displayAsBackgroundImage: PropTypes.bool,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image` node\n         */\n        imageProps: PropTypes.object,\n\n        /**\n         * a valid path to the desired image\n         */\n        src: PropTypes.string.isRequired,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image-status` node\n         */\n        statusProps: PropTypes.object,\n    }\n\n    static defaultProps = {\n        alt: null,\n        displayAsBackgroundImage: false,\n        imageProps: {},\n        src: 'about:blank',\n        statusProps: {},\n    }\n\n    static internalKeys = Object.keys(Image.defaultProps)\n\n    state = {\n        status: Image.status.LOADING,\n    }\n\n    componentWillReceiveProps(nextProps) {\n        if (nextProps.src !== this.props.src) {\n            this.resetPreloader();\n            this.setState({status: Image.status.LOADING});\n        }\n    }\n\n    componentDidMount() {\n        this.preload();\n    }\n\n    componentDidUpdate() {\n        this.preload();\n    }\n\n    componentWillUnmount() {\n        this.resetPreloader();\n    }\n\n    resetPreloader() {\n        this.loader.onload = null;\n        this.loader.onerror = null;\n        this.loader = null;\n    }\n\n    preload() {\n        if (this.loader) { return; }\n\n        this.loader = document.createElement('img');\n\n        this.loader.onload = () => this.setState({status: Image.status.LOADED});\n        this.loader.onerror = () => this.setState({status: Image.status.ERROR});\n\n        this.loader.src = this.props.src;\n    }\n\n    renderImage() {\n        if (this.props.displayAsBackgroundImage) {\n            return (\n                <div\n                    {...this.props.imageProps}\n                    ref='image'\n                    className={cx('b-image', this.props.imageProps.className)}\n                    title={this.props.alt}\n                    style={{\n                        ...this.props.imageProps.style,\n                        backgroundImage: `url(${this.props.src})`,\n                    }} />\n            );\n        }\n\n        return (\n            <img\n                {...this.props.imageProps}\n                ref='image'\n                className={cx('b-image', this.props.imageProps.className)}\n                src={this.props.src}\n                alt={this.props.alt}\n                onLoad={noop}\n                onError={noop} />\n        );\n    }\n\n    renderStatus() {\n        return (\n            <div {...this.props.statusProps}\n                 ref='status'\n                 className={cx('b-image-status', this.props.statusProps.className, {\n                    'b-image-loading': this.state.status === Image.status.LOADING,\n                    'b-image-loaded': this.state.status === Image.status.LOADED,\n                    'b-image-error': this.state.status === Image.status.ERROR,\n                 })}\n                 role='presentation' />\n        );\n    }\n\n    render() {\n        return (\n            <div\n                {...omit(this.props, Image.internalKeys)}\n                ref='wrapper'\n                className={cx('b-image-wrapper', this.props.className)}>\n                {this.renderImage()}\n                {this.renderStatus()}\n            </div>\n        );\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-image/index.js"],"sourceRoot":""} |
{ | ||
"name": "boundless-image", | ||
"version": "1.0.0-beta.4", | ||
"version": "1.0.0-beta.5", | ||
"description": "An image block with placeholder support for loading and fallback scenarios.", | ||
"main": "build/index.js", | ||
"browser": "build/index.js", | ||
"repository": { | ||
@@ -16,3 +16,3 @@ "type": "git", | ||
"contributors": [ | ||
"Evan Scott <evan.scott@enigma.io>", | ||
"Evan Scott <glitterbyte@gmail.com> (http://yaycmyk.com)", | ||
"Abe Rubenstein <abe.rubenstein@enigma.io>", | ||
@@ -27,6 +27,8 @@ "Jenn Creighton <jenn.creighton@enigma.io>" | ||
"dependencies": { | ||
"boundless-utils-noop": "^1.0.0", | ||
"boundless-utils-omit-keys": "^1.0.0-beta.3", | ||
"classnames": "^2.1.5" | ||
}, | ||
"devDependencies": { | ||
"boundless-utils-noop": "^1.0.0", | ||
"boundless-utils-omit-keys": "^1.0.0-beta.3" | ||
}, | ||
"peerDependencies": { | ||
@@ -33,0 +35,0 @@ "react": ">= 15.3", |
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
65342
3
321
2
- Removedboundless-utils-noop@^1.0.0
- Removedboundless-utils-omit-keys@1.1.0(transitive)