From 9ed78cfaacc0589d13a97d940cf0d8aa62c52e99 Mon Sep 17 00:00:00 2001 From: stereobooster Date: Mon, 29 May 2017 02:53:31 +0200 Subject: [PATCH] Inject styles --- examples/basic/src/App.css | 60 ++++++++++++++++++++++++++++++++------ src/LazyLoad.jsx | 17 ++++++++++- src/utils/css.js | 20 +++++++++++++ src/utils/injectCSS.js | 14 +++++++++ 4 files changed, 101 insertions(+), 10 deletions(-) create mode 100644 src/utils/css.js create mode 100644 src/utils/injectCSS.js diff --git a/examples/basic/src/App.css b/examples/basic/src/App.css index 1441f22..5d33206 100644 --- a/examples/basic/src/App.css +++ b/examples/basic/src/App.css @@ -1,12 +1,3 @@ -.LazyLoad { - opacity: 0; - transition: all 2s ease-in-out; -} - -.LazyLoad.is-visible { - opacity: 1; -} - .filler { height: 150px; } @@ -16,3 +7,54 @@ overflow: scroll; background-color: grey; } + +/* override default styles */ +.LazyLoad { + background: #ccc; +} + +.LazyLoad img { + transition: all 2s ease-in-out; +} + +.LazyLoad .spinner { + width: 40px; + height: 40px; + position: absolute; + top: 50%; + left: 50%; + margin: -20px -20px 0 0; + background-color: #fff; + border-radius: 100%; + -webkit-animation: sk-scaleout 1.0s infinite ease-in-out; + animation: sk-scaleout 1.0s infinite ease-in-out; +} + +@-webkit-keyframes sk-scaleout { + 0% { -webkit-transform: scale(0) } + 100% { + -webkit-transform: scale(1.0); + opacity: 0; + } +} + +@keyframes sk-scaleout { + 0% { + -webkit-transform: scale(0); + transform: scale(0); + } 100% { + -webkit-transform: scale(1.0); + transform: scale(1.0); + opacity: 0; + } +} + +.LazyLoad .offline { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: no-repeat center center url(); + background-size: 100px 100px; +} diff --git a/src/LazyLoad.jsx b/src/LazyLoad.jsx index 1340182..d3d6909 100644 --- a/src/LazyLoad.jsx +++ b/src/LazyLoad.jsx @@ -6,6 +6,9 @@ import debounce from 'lodash/debounce'; import throttle from 'lodash/throttle'; import parentScroll from './utils/parentScroll'; import inViewport from './utils/inViewport'; +import injectCss from './utils/injectCSS'; + +injectCss(window); export default class LazyLoad extends Component { constructor(props) { @@ -125,10 +128,22 @@ export default class LazyLoad extends Component { onError: () => { this.setState({ errored: true }); }, }; + let content; + + if (visible) { + if (loaded) { + content = React.cloneElement(children, props); + } else if (errored) { + content = offline; + } else { + content = [spinner, React.cloneElement(children, props)] + } + } + return React.createElement(this.props.elementType, { className: elClasses, style: elStyles, - }, visible && [spinner, offline, React.cloneElement(children, props)] ); + }, content); } } diff --git a/src/utils/css.js b/src/utils/css.js new file mode 100644 index 0000000..435c980 --- /dev/null +++ b/src/utils/css.js @@ -0,0 +1,20 @@ +export default ` +.LazyLoad img { opacity: 0; } +.LazyLoad.is-loaded img { opacity: 1; } +.LazyLoad { + position: relative; + height: 0; + padding-bottom: 75%; + overflow: hidden; +} +.LazyLoad iframe, +.LazyLoad object, +.LazyLoad embed, +.LazyLoad video, +.LazyLoad img { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; +}`; diff --git a/src/utils/injectCSS.js b/src/utils/injectCSS.js new file mode 100644 index 0000000..1512855 --- /dev/null +++ b/src/utils/injectCSS.js @@ -0,0 +1,14 @@ +import cssRules from './css'; + +const injectCSS = (window) => { + if (window && typeof window === 'object' && window.document) { + const { document } = window; + const head = (document.head || document.getElementsByTagName('head')[0]); + + const styleElement = document.createElement('style'); + styleElement.innerHTML = cssRules; + head.appendChild(styleElement); + } +}; + +export default injectCSS;