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

boundless-image

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-image - npm Package Compare versions

Comparing version 1.0.0-beta.3 to 1.0.0-beta.4

4

build/index.js

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

"use strict";function _interopDefault(e){return e&&typeof e==="object"&&"default"in e?e["default"]:e}var React=require("react");var React__default=_interopDefault(React);function createCommonjsModule(e,t){return t={exports:{}},e(t,t.exports),t.exports}var _typeof=typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"?function(e){return typeof e}:function(e){return e&&typeof Symbol==="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};var classCallCheck=function(e,t){if(!(e instanceof t)){throw new TypeError("Cannot call a class as a function")}};var createClass=function(){function e(e,t){for(var r=0;r<t.length;r++){var s=t[r];s.enumerable=s.enumerable||false;s.configurable=true;if("value"in s)s.writable=true;Object.defineProperty(e,s.key,s)}}return function(t,r,s){if(r)e(t.prototype,r);if(s)e(t,s);return t}}();var _extends=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var s in r){if(Object.prototype.hasOwnProperty.call(r,s)){e[s]=r[s]}}}return e};var inherits=function(e,t){if(typeof t!=="function"&&t!==null){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:false,writable:true,configurable:true}});if(t)Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t};var possibleConstructorReturn=function(e,t){if(!e){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return t&&(typeof t==="object"||typeof t==="function")?t:e};var index=createCommonjsModule(function(e){(function(){"use strict";var t={}.hasOwnProperty;function r(){var e=[];for(var s=0;s<arguments.length;s++){var o=arguments[s];if(!o)continue;var a=typeof o==="undefined"?"undefined":_typeof(o);if(a==="string"||a==="number"){e.push(o)}else if(Array.isArray(o)){e.push(r.apply(null,o))}else if(a==="object"){for(var n in o){if(t.call(o,n)&&o[n]){e.push(n)}}}}return e.join(" ")}if("object"!=="undefined"&&e.exports){e.exports=r}else if(typeof undefined==="function"&&_typeof(undefined.amd)==="object"&&undefined.amd){undefined("classnames",[],function(){return r})}else{window.classNames=r}})()});function noop(){}function omitKeysFromSourceObject(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];return Object.keys(e).reduce(function r(s,o){if(t.indexOf(o)===-1){s[o]=e[o]}return s},{})}var Image=function(e){inherits(t,e);function t(){var e;var r,s,o;classCallCheck(this,t);for(var a=arguments.length,n=Array(a),i=0;i<a;i++){n[i]=arguments[i]}return o=(r=(s=possibleConstructorReturn(this,(e=t.__proto__||Object.getPrototypeOf(t)).call.apply(e,[this].concat(n))),s),s.state={status:t.status.LOADING},r),possibleConstructorReturn(s,o)}createClass(t,[{key:"componentWillReceiveProps",value:function e(r){if(r.src!==this.props.src){this.resetPreloader();this.setState({status:t.status.LOADING})}}},{key:"componentDidMount",value:function e(){this.preload()}},{key:"componentDidUpdate",value:function e(){this.preload()}},{key:"componentWillUnmount",value:function e(){this.resetPreloader()}},{key:"resetPreloader",value:function e(){this.loader.onload=null;this.loader.onerror=null;this.loader=null}},{key:"preload",value:function e(){var r=this;if(this.loader){return}this.loader=document.createElement("img");this.loader.onload=function(){return r.setState({status:t.status.LOADED})};this.loader.onerror=function(){return r.setState({status:t.status.ERROR})};this.loader.src=this.props.src}},{key:"renderImage",value:function e(){if(this.props.displayAsBackgroundImage){return React__default.createElement("div",_extends({},this.props.imageProps,{ref:"image",className:index("b-image",this.props.imageProps.className),title:this.props.alt,style:_extends({},this.props.imageProps.style,{backgroundImage:"url("+this.props.src+")"})}))}return React__default.createElement("img",_extends({},this.props.imageProps,{ref:"image",className:index("b-image",this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:noop,onError:noop}))}},{key:"renderStatus",value:function e(){return React__default.createElement("div",_extends({},this.props.statusProps,{ref:"status",className:index("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 e(){return React__default.createElement("div",_extends({},omitKeysFromSourceObject(this.props,t.internalKeys),{ref:"wrapper",className:index("b-image-wrapper",this.props.className)}),this.renderImage(),this.renderStatus())}}]);return t}(React__default.PureComponent);Image.status={LOADING:"LOADING",LOADED:"LOADED",ERROR:"ERROR"};Image.propTypes={alt:React.PropTypes.string,displayAsBackgroundImage:React.PropTypes.bool,imageProps:React.PropTypes.object,src:React.PropTypes.string.isRequired,statusProps:React.PropTypes.object};Image.defaultProps={alt:null,displayAsBackgroundImage:false,imageProps:{},src:"about:blank",statusProps:{}};Image.internalKeys=Object.keys(Image.defaultProps);module.exports=Image;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../node_modules/classnames/index.js","../../boundless-utils-omit-keys/index.js","../index.js"],"sourcesContent":["/*!\n  Copyright (c) 2016 Jed Watson.\n  Licensed under the MIT License (MIT), see\n  http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tclasses.push(classNames.apply(null, arg));\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","/**\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","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"],"names":["hasOwnProperty","i","arguments","length","arg","argType","classes","push","Array","isArray","classNames","apply","hasOwn","call","key","join","module","exports","babelHelpers.typeof","define","amd","window","source","keys","reduce","hash","omittedKeys","indexOf","state","status","Image","LOADING","nextProps","src","this","props","resetPreloader","setState","preload","loader","onload","onerror","document","createElement","LOADED","ERROR","displayAsBackgroundImage","imageProps","ref","className","cx","title","alt","style","backgroundImage","onLoad","noop","onError","statusProps","b-image-loading","b-image-loaded","b-image-error","role","omit","internalKeys","renderImage","renderStatus","React","PureComponent","propTypes","PropTypes","string","bool","object","isRequired","defaultProps","Object"],"mappings":"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"}
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":"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,MFuESD,EAAuB,EAAIC,GAKtD,SAAU9B,EAAQ6B,EAAqB1B,GAE7C,YG9Ee,SAAS4B,GAAyBC,GAA0B,GAAlBC,GAAkBC,UAAAC,OAAA,GAAAC,SAAAF,UAAA,GAAAA,UAAA,KACvE,OAAOlB,QAAOqB,KAAKL,GAAQM,OAAO,SAA8BC,EAAMC,GAKlE,MAJIP,GAAYQ,QAAQD,MAAS,IAC7BD,EAAKC,GAAOR,EAAOQ,IAGhBD,OHyEkBV,EAAuB,EAAIE,GAKtD,SAAU/B,EAAQC,GIvFxBD,EAAAC,QAAAyC,QAAA,UJ6FM,SAAU1C,EAAQC,GK7FxBD,EAAAC,QAAAyC,QAAA,eLmGM,SAAU1C,EAAQ6B,EAAqB1B,GAE7C,YACAa,QAAOC,eAAeY,EAAqB,cAAgBlB,OAAO,GAC7C,IAAIgC,GAAsCxC,EAAoB,GAC1DyC,EAA8CzC,EAAoBkB,EAAEsB,GACpEE,EAA2C1C,EAAoB,GAC/D2C,EAAmD3C,EAAoBkB,EAAEwB,GACzEE,EAA4D5C,EAAoB,GAChF6C,EAAiE7C,EAAoB,GMlGzF8C,ENmGX,SAASC,GAAwE,QAASD,KAAQ,GAAIE,GAASC,EAAMC,EAAMC,CAAKC,cAAaC,eAAeC,KAAKR,EAAO,KAAI,GAAIS,GAAKxB,UAAUC,OAAOwB,EAAKC,MAAMF,GAAMG,EAAK,EAAEA,EAAKH,EAAKG,IAAQF,EAAKE,GAAM3B,UAAU2B,EAAO,OAAaT,GAAOC,EAAME,aAAaO,0BAA0BL,MAAMN,EAAKF,EAAMc,WAAW/C,OAAOgD,eAAef,IAAQzC,KAAKyD,MAAMd,GAAMM,MAAMS,OAAOP,KAAeN,EMvD1bc,OACIC,OAAQnB,EAAMmB,OAAOC,SNsDgQf,EAA2MF,EAAOG,aAAaO,0BAA0BT,EAAMC,GAAssF,MAAzrGC,cAAae,SAASrB,EAAMC,GAA8dK,aAAagB,YAAYtB,IAAQT,IAAI,4BAA4B7B,MAAM,SMnD5kB6D,GAClBA,EAAUC,MAAQhB,KAAKiB,MAAMD,MAC7BhB,KAAKkB,iBACLlB,KAAKmB,UAAUR,OAAQnB,EAAMmB,OAAOC,cNgDmtB7B,IAAI,oBAAoB7B,MAAM,WM3CzxB8C,KAAKoB,aN2Co0BrC,IAAI,qBAAqB7B,MAAM,WMvCx2B8C,KAAKoB,aNuCo5BrC,IAAI,uBAAuB7B,MAAM,WMnC17B8C,KAAKkB,oBNmC++BnC,IAAI,iBAAiB7B,MAAM,WM/B/gC8C,KAAKqB,OAAOC,OAAS,KACrBtB,KAAKqB,OAAOE,QAAU,KACtBvB,KAAKqB,OAAS,QN6BimCtC,IAAI,UAAU7B,MAAM,WM1B7nC,GAAAsE,GAAAxB,IACFA,MAAKqB,SAETrB,KAAKqB,OAASI,SAASC,cAAc,OAErC1B,KAAKqB,OAAOC,OAAS,iBAAME,GAAKL,UAAUR,OAAQnB,EAAMmB,OAAOgB,UAC/D3B,KAAKqB,OAAOE,QAAU,iBAAMC,GAAKL,UAAUR,OAAQnB,EAAMmB,OAAOiB,SAEhE5B,KAAKqB,OAAOL,IAAMhB,KAAKiB,MAAMD,QNkBw5CjC,IAAI,cAAc7B,MAAM,WMd78C,MAAI8C,MAAKiB,MAAMY,yBAEP1C,EAAA2C,EAAAJ,cAAA,MAAA5B,aAAAiC,WACQ/B,KAAKiB,MAAMe,YACfC,IAAI,QACJC,UAAW7C,IAAG,UAAWW,KAAKiB,MAAMe,WAAWE,WAC/CC,MAAOnC,KAAKiB,MAAMmB,IAClBC,MAAAvC,aAAAiC,WACO/B,KAAKiB,MAAMe,WAAWK,OACzBC,uBAAwBtC,KAAKiB,MAAMD,IAAnC,SAMZ7B,EAAA2C,EAAAJ,cAAA,MAAA5B,aAAAiC,WACQ/B,KAAKiB,MAAMe,YACfC,IAAI,QACJC,UAAW7C,IAAG,UAAWW,KAAKiB,MAAMe,WAAWE,WAC/ClB,IAAKhB,KAAKiB,MAAMD,IAChBoB,IAAKpC,KAAKiB,MAAMmB,IAChBG,OAAQjD,EAAA,EACRkD,QAASlD,EAAA,QNRyyEP,IAAI,eAAe7B,MAAM,WMan1E,MACIiC,GAAA2C,EAAAJ,cAAA,MAAA5B,aAAAiC,WAAS/B,KAAKiB,MAAMwB,aACfR,IAAI,SACJC,UAAW7C,IAAG,iBAAkBW,KAAKiB,MAAMwB,YAAYP,WACpDQ,kBAAmB1C,KAAKU,MAAMC,SAAWnB,EAAMmB,OAAOC,QACtD+B,iBAAkB3C,KAAKU,MAAMC,SAAWnB,EAAMmB,OAAOgB,OACrDiB,gBAAiB5C,KAAKU,MAAMC,SAAWnB,EAAMmB,OAAOiB,QAEvDiB,KAAK,qBNrB2xF9D,IAAI,SAAS7B,MAAM,WM0B5zF,MACIiC,GAAA2C,EAAAJ,cAAA,MAAA5B,aAAAiC,WACQrF,EAAAG,EAAA0C,EAAA,GAAKS,KAAKiB,MAAOzB,EAAMsD,eAC3Bb,IAAI,UACJC,UAAW7C,IAAG,kBAAmBW,KAAKiB,MAAMiB,aAC3ClC,KAAK+C,cACL/C,KAAKgD,oBNhCmtGxD,GMnGtsGL,EAAA2C,EAAMmB,cAApBzD,GACVmB,QACHC,QAAS,UACTe,OAAQ,SACRC,MAAO,SAJMpC,EAOV0D,WAIHd,IAAKlD,EAAA,UAAUiE,OAKftB,yBAA0B3C,EAAA,UAAUkE,KAKpCpB,WAAY9C,EAAA,UAAUpB,OAKtBkD,IAAK9B,EAAA,UAAUiE,OAAOE,WAKtBZ,YAAavD,EAAA,UAAUpB,QA/BV0B,EAkCV8D,cACHlB,IAAK,KACLP,0BAA0B,EAC1BG,cACAhB,IAAK,cACLyB,gBAvCajD,EA0CVsD,aAAevF,OAAOqB,KAAKY,EAAM8D,cNyDw2HlF,EAA6B,QMnG55HoB","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":""}
{
"name": "boundless-image",
"version": "1.0.0-beta.3",
"version": "1.0.0-beta.4",
"description": "An image block with placeholder support for loading and fallback scenarios.",
"module": "index.js",
"main": "build/index.js",

@@ -7,0 +6,0 @@ "repository": {

@@ -13,16 +13,16 @@ THIS IS AN AUTOGENERATED FILE. EDIT INDEX.JS INSTEAD.

<table>
<tr>
<th>Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Description</th>
</tr>
<tr>
<td>src</td>
<td><pre><code>string</code></pre></td>
<td><pre><code class="language-js">'about:blank'</code></pre></td>
<td>a valid path to the desired image</td>
</tr>
<tr>
<th>Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Description</th>
</tr>
<tr>
<td>src</td>
<td><pre><code>string</code></pre></td>
<td><pre><code class="language-js">'about:blank'</code></pre></td>
<td>a valid path to the desired image</td>
</tr>
</table>

@@ -34,38 +34,38 @@

<table>
<tr>
<th>Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Description</th>
</tr>
<tr>
<td>alt</td>
<td><pre><code>string</code></pre></td>
<td><pre><code class="language-js">null</code></pre></td>
<td>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</td>
</tr>
<tr>
<td>displayAsBackgroundImage</td>
<td><pre><code>bool</code></pre></td>
<td><pre><code class="language-js">false</code></pre></td>
<td>emits the image as a `<div>` with `background-image` css property set instead of `<img>`</td>
</tr>
<tr>
<td>imageProps</td>
<td><pre><code>object</code></pre></td>
<td><pre><code class="language-js">{}</code></pre></td>
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image` node</td>
</tr>
<tr>
<td>statusProps</td>
<td><pre><code>object</code></pre></td>
<td><pre><code class="language-js">{}</code></pre></td>
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image-status` node</td>
</tr>
<tr>
<th>Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Description</th>
</tr>
<tr>
<td>alt</td>
<td><pre><code>string</code></pre></td>
<td><pre><code class="language-js">null</code></pre></td>
<td>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</td>
</tr>
<tr>
<td>displayAsBackgroundImage</td>
<td><pre><code>bool</code></pre></td>
<td><pre><code class="language-js">false</code></pre></td>
<td>emits the image as a `<div>` with `background-image` css property set instead of `<img>`</td>
</tr>
<tr>
<td>imageProps</td>
<td><pre><code>object</code></pre></td>
<td><pre><code class="language-js">{}</code></pre></td>
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image` node</td>
</tr>
<tr>
<td>statusProps</td>
<td><pre><code>object</code></pre></td>
<td><pre><code class="language-js">{}</code></pre></td>
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image-status` node</td>
</tr>
</table>
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