boundless-image
Advanced tools
Comparing version 1.0.0-beta.6 to 1.0.0-beta.7
@@ -1,2 +0,2 @@ | ||
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=3)}([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(2),i=r.n(a),u=r(1),p=r.n(u),l=r(0),c=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},f=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}}(),d=function(){},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),f(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",c({},this.props.imageProps,{ref:"image",className:p()("b-image",this.props.imageProps.className),title:this.props.alt,style:c({},this.props.imageProps.style,{backgroundImage:"url("+this.props.src+")"})})):i.a.createElement("img",c({},this.props.imageProps,{ref:"image",className:p()("b-image",this.props.imageProps.className),src:this.props.src,alt:this.props.alt,onLoad:d,onError:d}))}},{key:"renderStatus",value:function(){return i.a.createElement("div",c({},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",c({},r.i(l.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 a68a5b2c36c91e405900","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__","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","noop","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 = 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 noop=function noop(){};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:noop,onError:noop}));}},{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_2_boundless_utils_omit_keys__[\"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 = 3);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap a68a5b2c36c91e405900","/**\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\nconst noop = () => {};\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(t){function e(n){if(r[n])return r[n].exports;var o=r[n]={i:n,l:!1,exports:{}};return t[n].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var r={};return e.m=t,e.c=r,e.i=function(t){return t},e.d=function(t,r,n){e.o(t,r)||Object.defineProperty(t,r,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(r,"a",r),r},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=4)}([function(t,e){t.exports=require("boundless-utils-omit-keys")},function(t,e){t.exports=require("boundless-utils-uuid")},function(t,e){t.exports=require("classnames")},function(t,e){t.exports=require("react")},function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(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 s(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 a=r(3),u=r.n(a),i=r(2),l=r.n(i),c=r(0),p=r.n(c),f=r(1),d=r.n(f),y=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},h=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),b=function(t){function e(){var t,r,s,a;n(this,e);for(var u=arguments.length,i=Array(u),l=0;l<u;l++)i[l]=arguments[l];return r=s=o(this,(t=e.__proto__||Object.getPrototypeOf(e)).call.apply(t,[this].concat(i))),s.state={status:e.status.LOADING},a=r,o(s,a)}return s(e,t),h(e,[{key:"componentWillReceiveProps",value:function(t){t.src!==this.props.src&&(this.resetPreloader(),this.setState({status:e.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 t=this;this.loader||(this.loader=document.createElement("img"),this.loader.onload=function(){return t.setState({status:e.status.LOADED})},this.loader.onerror=function(){return t.setState({status:e.status.ERROR})},this.loader.src=this.props.src)}},{key:"render",value:function(){return u.a.createElement(this.props.component,y({},p()(this.props,e.internalKeys),{className:l()("b-image",this.props.className,{"b-image-loading":this.state.status===e.status.LOADING,"b-image-loaded":this.state.status===e.status.LOADED,"b-image-error":this.state.status===e.status.ERROR}),title:this.props.alt,role:"img",style:y({},this.props.style,{backgroundImage:"url("+this.props.src+")"})})," ")}}]),e}(u.a.PureComponent);b.status={LOADING:d()(),LOADED:d()(),ERROR:d()()},b.propTypes={"*":a.PropTypes.any,alt:a.PropTypes.string,component:a.PropTypes.string,src:a.PropTypes.string.isRequired},b.defaultProps={alt:"",component:"div",src:"about:blank"},b.internalKeys=Object.keys(b.defaultProps),e.default=b}]); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap f26db30152a2bb15a94f","webpack:///external {\"commonjs2\":\"boundless-utils-omit-keys\"}","webpack:///external {\"commonjs2\":\"boundless-utils-uuid\"}","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","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","__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid__","__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid___default","_extends","assign","target","arguments","length","source","key","_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","a","component","internalKeys","className","b-image-loading","b-image-loaded","b-image-error","title","alt","role","style","backgroundImage","PureComponent","propTypes","*","any","string","isRequired","defaultProps","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 = 4);\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(\"boundless-utils-uuid\");\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_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__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid__);\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:'render',value:function render(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(this.props.component,_extends({},__WEBPACK_IMPORTED_MODULE_2_boundless_utils_omit_keys___default()(this.props,Image.internalKeys),{className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-image',this.props.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}),title:this.props.alt,role:'img',style:_extends({},this.props.style,{backgroundImage:'url('+this.props.src+')'})}),'\\xA0');}}]);return Image;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Image.status={LOADING:__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid___default()(),LOADED:__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid___default()(),ERROR:__WEBPACK_IMPORTED_MODULE_3_boundless_utils_uuid___default()()};Image.propTypes={'*':__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].any,alt:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,component:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,src:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string.isRequired};Image.defaultProps={alt:'',component:'div',src:'about:blank'};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 f26db30152a2bb15a94f","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(\"boundless-utils-uuid\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"boundless-utils-uuid\"}\n// module id = 1\n// module chunks = 0","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 omit from 'boundless-utils-omit-keys';\nimport uuid from 'boundless-utils-uuid';\n\n/**\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: uuid(),\n        LOADED: uuid(),\n        ERROR: uuid(),\n    }\n\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 written description of the image for search engines, hovertext and those using accessibility technologies\n         */\n        alt: PropTypes.string,\n\n        /**\n         * overrides the component HTML tag\n         */\n        component: PropTypes.string,\n\n        /**\n         * a valid path to the desired image\n         */\n        src: PropTypes.string.isRequired,\n    }\n\n    static defaultProps = {\n        alt: '',\n        component: 'div',\n        src: 'about:blank',\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()     { this.preload(); }\n    componentDidUpdate()    { this.preload(); }\n    componentWillUnmount()  { this.resetPreloader(); }\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    render() {\n        return (\n            <this.props.component\n                {...omit(this.props, Image.internalKeys)}\n                className={cx('b-image', this.props.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                title={this.props.alt}\n                role='img'\n                style={{\n                    ...this.props.style,\n                    backgroundImage: `url(${this.props.src})`,\n                }}>\n                &nbsp;\n            </this.props.component>\n        );\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-image/index.js"],"sourceRoot":""} |
@@ -18,11 +18,12 @@ import React from 'react'; | ||
return ( | ||
<div className='spread center'> | ||
<div className='demo-image spread center'> | ||
<figure> | ||
<h5>Normal</h5> | ||
<Image ref='normal' | ||
src={`https://c2.staticflickr.com/6/5128/5288605976_9b06c0de8f_b.jpg?${this.state.normal}`} | ||
alt='A snowy drive.' | ||
displayAsBackgroundImage={true} /> | ||
<Button onPressed={this.remountImage.bind(this, 'normal')} | ||
style={{marginTop: '1rem'}}> | ||
<Image | ||
ref='normal' | ||
src={`https://c2.staticflickr.com/6/5128/5288605976_9b06c0de8f_b.jpg?${this.state.normal}`} | ||
alt='A snowy drive.' /> | ||
<Button | ||
onPressed={this.remountImage.bind(this, 'normal')} | ||
style={{marginTop: '1rem'}}> | ||
Remount Image | ||
@@ -34,6 +35,6 @@ </Button> | ||
<h5>Delayed</h5> | ||
<Image ref='delayed' | ||
src={`http://deelay.me/5000/http://igcdn-photos-g-a.akamaihd.net/hphotos-ak-xfa1/t51.2885-15/11244434_646274218842534_532892887_n.jpg?${this.state.delayed}`} | ||
alt='A beachscape.' | ||
displayAsBackgroundImage={true} /> | ||
<Image | ||
ref='delayed' | ||
src={`http://deelay.me/5000/http://igcdn-photos-g-a.akamaihd.net/hphotos-ak-xfa1/t51.2885-15/11244434_646274218842534_532892887_n.jpg?${this.state.delayed}`} | ||
alt='A beachscape.' /> | ||
<Button onPressed={this.remountImage.bind(this, 'delayed')} | ||
@@ -47,8 +48,9 @@ style={{marginTop: '1rem'}}> | ||
<h5>Errored Out</h5> | ||
<Image ref='error' | ||
src={`http://www.flickr.com/1o2k3ok1231?${this.state.error}`} | ||
alt='A dead image.' | ||
displayAsBackgroundImage={true} /> | ||
<Button onPressed={this.remountImage.bind(this, 'error')} | ||
style={{marginTop: '1rem'}}> | ||
<Image | ||
ref='error' | ||
src={`http://www.flickr.com/1o2k3ok1231?${this.state.error}`} | ||
alt='A dead image.' /> | ||
<Button | ||
onPressed={this.remountImage.bind(this, 'error')} | ||
style={{marginTop: '1rem'}}> | ||
Remount Image | ||
@@ -55,0 +57,0 @@ </Button> |
105
index.js
@@ -5,7 +5,5 @@ import React, {PropTypes} from 'react'; | ||
import omit from 'boundless-utils-omit-keys'; | ||
import uuid from 'boundless-utils-uuid'; | ||
const noop = () => {}; | ||
/** | ||
# Image | ||
__An image block with placeholder support for loading and fallback scenarios.__ | ||
@@ -15,5 +13,5 @@ */ | ||
static status = { | ||
LOADING: 'LOADING', | ||
LOADED: 'LOADED', | ||
ERROR: 'ERROR', | ||
LOADING: uuid(), | ||
LOADED: uuid(), | ||
ERROR: uuid(), | ||
} | ||
@@ -23,15 +21,15 @@ | ||
/** | ||
* 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 | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes) | ||
*/ | ||
alt: PropTypes.string, | ||
'*': PropTypes.any, | ||
/** | ||
* emits the image as a `<div>` with `background-image` css property set instead of `<img>` | ||
* a written description of the image for search engines, hovertext and those using accessibility technologies | ||
*/ | ||
displayAsBackgroundImage: PropTypes.bool, | ||
alt: PropTypes.string, | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image` node | ||
* overrides the component HTML tag | ||
*/ | ||
imageProps: PropTypes.object, | ||
component: PropTypes.string, | ||
@@ -42,15 +40,8 @@ /** | ||
src: PropTypes.string.isRequired, | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-image-status` node | ||
*/ | ||
statusProps: PropTypes.object, | ||
} | ||
static defaultProps = { | ||
alt: null, | ||
displayAsBackgroundImage: false, | ||
imageProps: {}, | ||
alt: '', | ||
component: 'div', | ||
src: 'about:blank', | ||
statusProps: {}, | ||
} | ||
@@ -71,14 +62,6 @@ | ||
componentDidMount() { | ||
this.preload(); | ||
} | ||
componentDidMount() { this.preload(); } | ||
componentDidUpdate() { this.preload(); } | ||
componentWillUnmount() { this.resetPreloader(); } | ||
componentDidUpdate() { | ||
this.preload(); | ||
} | ||
componentWillUnmount() { | ||
this.resetPreloader(); | ||
} | ||
resetPreloader() { | ||
@@ -101,53 +84,21 @@ this.loader.onload = null; | ||
renderImage() { | ||
if (this.props.displayAsBackgroundImage) { | ||
return ( | ||
<div | ||
{...this.props.imageProps} | ||
ref='image' | ||
className={cx('b-image', this.props.imageProps.className)} | ||
title={this.props.alt} | ||
style={{ | ||
...this.props.imageProps.style, | ||
backgroundImage: `url(${this.props.src})`, | ||
}} /> | ||
); | ||
} | ||
render() { | ||
return ( | ||
<img | ||
{...this.props.imageProps} | ||
ref='image' | ||
className={cx('b-image', this.props.imageProps.className)} | ||
src={this.props.src} | ||
alt={this.props.alt} | ||
onLoad={noop} | ||
onError={noop} /> | ||
); | ||
} | ||
renderStatus() { | ||
return ( | ||
<div {...this.props.statusProps} | ||
ref='status' | ||
className={cx('b-image-status', this.props.statusProps.className, { | ||
<this.props.component | ||
{...omit(this.props, Image.internalKeys)} | ||
className={cx('b-image', this.props.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' /> | ||
})} | ||
title={this.props.alt} | ||
role='img' | ||
style={{ | ||
...this.props.style, | ||
backgroundImage: `url(${this.props.src})`, | ||
}}> | ||
| ||
</this.props.component> | ||
); | ||
} | ||
render() { | ||
return ( | ||
<div | ||
{...omit(this.props, Image.internalKeys)} | ||
ref='wrapper' | ||
className={cx('b-image-wrapper', this.props.className)}> | ||
{this.renderImage()} | ||
{this.renderStatus()} | ||
</div> | ||
); | ||
} | ||
} |
@@ -7,3 +7,3 @@ /* eslint no-unused-expressions:0 */ | ||
import Image from './index'; | ||
import conformanceChecker from '../boundless-utils-conformance/index'; | ||
import {$, conformanceChecker} from '../boundless-utils-test-helpers/index'; | ||
@@ -20,107 +20,15 @@ describe('Image component', () => { | ||
describe('accepts', () => { | ||
it('arbitrary React-supported HTML attributes via props.imageProps', () => { | ||
const element = render(<Image {...baseProps} imageProps={{'data-id': 'xr1'}} />); | ||
const node = element.refs.image; | ||
expect(node.getAttribute('data-id')).toBe('xr1'); | ||
}); | ||
it('classes via props.imageProps.className', () => { | ||
const element = render( | ||
<Image {...baseProps} | ||
imageProps={{ | ||
className: 'foo', | ||
}} /> | ||
); | ||
expect(element.refs.image.classList.contains('foo')).toBe(true); | ||
}); | ||
it('classes via props.imageProps.className when props.displayAsBackgroundImage is true', () => { | ||
const element = render( | ||
<Image {...baseProps} | ||
displayAsBackgroundImage={true} | ||
imageProps={{ | ||
className: 'foo', | ||
}} /> | ||
); | ||
expect(element.refs.image.classList.contains('foo')).toBe(true); | ||
}); | ||
it('inline styles via props.imageProps.style when props.displayAsBackgroundImage is true', () => { | ||
const element = render( | ||
<Image {...baseProps} | ||
displayAsBackgroundImage={true} | ||
imageProps={{ | ||
style: { | ||
textDecoration: 'underline', | ||
}, | ||
}} /> | ||
); | ||
expect(element.refs.image.style.textDecoration).toBe('underline'); | ||
}); | ||
it('arbitrary React-supported HTML attributes via props.statusProps', () => { | ||
const element = render(<Image {...baseProps} statusProps={{'data-id': 'xr1'}} />); | ||
expect(element.refs.status.getAttribute('data-id')).toBe('xr1'); | ||
}); | ||
it('classes via props.statusProps.className', () => { | ||
const element = render( | ||
<Image {...baseProps} | ||
statusProps={{ | ||
className: 'foo', | ||
}} /> | ||
); | ||
expect(element.refs.status.classList.contains('foo')).toBe(true); | ||
}); | ||
it('an additional class as a string without replacing the core hook', () => { | ||
const element = render(<Image {...baseProps} className='hero-image' />); | ||
['b-image-wrapper', 'hero-image'].forEach((cname) => expect(element.refs.wrapper.classList.contains(cname)).toBe(true)); | ||
}); | ||
it('accepts component customization', () => { | ||
render(<Image {...baseProps} component='figure' />); | ||
expect($('figure.b-image')).not.toBeNull(); | ||
}); | ||
describe('CSS hook', () => { | ||
it('renders .b-image-wrapper', () => { | ||
const element = render(<Image {...baseProps} />); | ||
expect(element.refs.wrapper.classList.contains('b-image-wrapper')).toBe(true); | ||
}); | ||
it('renders .b-image', () => { | ||
const element = render(<Image {...baseProps} />); | ||
expect(element.refs.image.classList.contains('b-image')).toBe(true); | ||
}); | ||
it('renders .b-image-status', () => { | ||
const element = render(<Image {...baseProps} />); | ||
expect(element.refs.status.classList.contains('b-image-status')).toBe(true); | ||
}); | ||
it('renders a single space as its child (needed for Safari)', () => { | ||
render(<Image {...baseProps} alt='foo' />); | ||
expect($('.b-image').textContent).toBe('\u00A0'); | ||
}); | ||
describe('description', () => { | ||
it('renders the HTML `alt` attribute if `props.displayAsBackgroundImage` is falsy', () => { | ||
const element = render(<Image {...baseProps} alt='foo' />); | ||
const node = element.refs.image; | ||
expect(node.getAttribute('alt')).toBe('foo'); | ||
expect(node.hasAttribute('title')).toBe(false); | ||
}); | ||
it('renders the HTML `title` attribute if `props.displayAsBackgroundImage` is `true`', () => { | ||
const element = render(<Image {...baseProps} alt='foo' displayAsBackgroundImage={true} />); | ||
const node = element.refs.image; | ||
expect(node.getAttribute('title')).toBe('foo'); | ||
expect(node.hasAttribute('alt')).toBe(false); | ||
}); | ||
it('renders the HTML `title` attribute', () => { | ||
render(<Image {...baseProps} alt='foo' />); | ||
expect($('.b-image[title="foo"]')).not.toBeNull(); | ||
}); | ||
@@ -151,3 +59,3 @@ | ||
element.setState({ status: Image.status.ERROR }, () => { | ||
expect(element.refs.status.classList.contains('b-image-error')).toBe(true); | ||
expect($('.b-image.b-image-error')).not.toBeNull(); | ||
done(); | ||
@@ -159,3 +67,3 @@ }); | ||
element.setState({ status: Image.status.LOADING }, () => { | ||
expect(element.refs.status.classList.contains('b-image-loading')).toBe(true); | ||
expect($('.b-image.b-image-loading')).not.toBeNull(); | ||
done(); | ||
@@ -167,3 +75,3 @@ }); | ||
element.setState({ status: Image.status.LOADED }, () => { | ||
expect(element.refs.status.classList.contains('b-image-loaded')).toBe(true); | ||
expect($('.b-image.b-image-loaded')).not.toBeNull(); | ||
done(); | ||
@@ -170,0 +78,0 @@ }); |
{ | ||
"name": "boundless-image", | ||
"version": "1.0.0-beta.6", | ||
"version": "1.0.0-beta.7", | ||
"description": "An image block with placeholder support for loading and fallback scenarios.", | ||
@@ -27,3 +27,4 @@ "main": "build/index.js", | ||
"dependencies": { | ||
"boundless-utils-omit-keys": "^1.0.0-beta.6", | ||
"boundless-utils-omit-keys": "^1.0.0-beta.7", | ||
"boundless-utils-uuid": "^1.0.0-beta.7", | ||
"classnames": "^2.1.5" | ||
@@ -30,0 +31,0 @@ }, |
150
README.md
@@ -0,70 +1,122 @@ | ||
<!--- | ||
THIS IS AN AUTOGENERATED FILE. EDIT INDEX.JS INSTEAD. | ||
--> | ||
# Image | ||
# Image | ||
__An image block with placeholder support for loading and fallback scenarios.__ | ||
## Example Usage | ||
```jsx | ||
import React from 'react'; | ||
import Button from '../../boundless-button/index'; | ||
import Image from '../index'; | ||
export default class ImageDemo extends React.PureComponent { | ||
state = { | ||
normal: Date.now(), | ||
delayed: Date.now(), | ||
error: Date.now(), | ||
} | ||
remountImage(refName) { | ||
this.setState({[refName]: Date.now()}); | ||
} | ||
render() { | ||
return ( | ||
<div className='demo-image spread center'> | ||
<figure> | ||
<h5>Normal</h5> | ||
<Image | ||
ref='normal' | ||
src={`https://c2.staticflickr.com/6/5128/5288605976_9b06c0de8f_b.jpg?${this.state.normal}`} | ||
alt='A snowy drive.' /> | ||
<Button | ||
onPressed={this.remountImage.bind(this, 'normal')} | ||
style={{marginTop: '1rem'}}> | ||
Remount Image | ||
</Button> | ||
</figure> | ||
<figure> | ||
<h5>Delayed</h5> | ||
<Image | ||
ref='delayed' | ||
src={`http://deelay.me/5000/http://igcdn-photos-g-a.akamaihd.net/hphotos-ak-xfa1/t51.2885-15/11244434_646274218842534_532892887_n.jpg?${this.state.delayed}`} | ||
alt='A beachscape.' /> | ||
<Button onPressed={this.remountImage.bind(this, 'delayed')} | ||
style={{marginTop: '1rem'}}> | ||
Remount Image | ||
</Button> | ||
</figure> | ||
<figure> | ||
<h5>Errored Out</h5> | ||
<Image | ||
ref='error' | ||
src={`http://www.flickr.com/1o2k3ok1231?${this.state.error}`} | ||
alt='A dead image.' /> | ||
<Button | ||
onPressed={this.remountImage.bind(this, 'error')} | ||
style={{marginTop: '1rem'}}> | ||
Remount Image | ||
</Button> | ||
</figure> | ||
</div> | ||
); | ||
} | ||
} | ||
``` | ||
## Props | ||
_Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Image#props)._ | ||
> Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Image#props). | ||
### Required Props | ||
<table> | ||
<tr> | ||
<th>Name</th> | ||
<th>Type</th> | ||
<th>Default Value</th> | ||
<th>Description</th> | ||
</tr> | ||
- __`src`__ ・ a valid path to the desired image | ||
<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> | ||
Expects | Default Value | ||
- | - | ||
`string` | `'about:blank'` | ||
</table> | ||
### 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>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> | ||
Expects | Default Value | ||
- | - | ||
`any` | `n/a` | ||
<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> | ||
- __`alt`__ ・ a written description of the image for search engines, hovertext and those using accessibility technologies | ||
<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> | ||
Expects | Default Value | ||
- | - | ||
`string` | `''` | ||
<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> | ||
- __`component`__ ・ overrides the component HTML tag | ||
</table> | ||
Expects | Default Value | ||
- | - | ||
`string` | `'div'` | ||
## Reference Styles | ||
### Stylus | ||
```stylus | ||
// Bring in Boundless's base Stylus variables | ||
@require "node_modules/boundless-image/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-image/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
Sorry, the diff of this file is not supported yet
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
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
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
74637
11
123
5
271
1
+ Addedboundless-utils-uuid@1.1.0(transitive)