lifechurch/melos

View on GitHub
src/components/images/LazyImage/stories/index.stories.js

Summary

Maintainability
A
2 hrs
Test Coverage
import React from 'react'
import { storiesOf } from '@storybook/react'
import { withInfo } from '@storybook/addon-info'
import Card from '../../../containers/Card'
import LazyImage from '../../LazyImage'

import DocTemplate, {
    Installation,
    Changelog,
    Usage,
    Example
} from '../../../../../stories/Docs'

const Docs = () => {
  return (
    <DocTemplate
      installation={
        <Installation
          maintainer={
            <a href='https://in.thewardro.be/jacob.allenwood'>
                            Jacob Allenwood
                        </a>
                    }
        />
            }
      usage={
        <Usage importString={'import LazyImage from \'@youversion/melos\''}>
          {`
                        This package exports a LazyImage component.
                        Use LazyImage for lazy loading images with an animated transition between an optional placeholder and the desired src.
                        The src only replaces the placeholder if it is successfully downloaded (i.e. not missing, 0 width, broken etc.).
                        The 'lazy' ability can also be false for server rendering.
                        Having a placeholder requires explicit dimension properties, but if a dynamic image size is required just forgo the placeholder and pass \`{ width: '100%', height: null }\`
                    `}
        </Usage>
            }
    />
  )
}

storiesOf('Images/LazyImage', module)
  .add('Lazy loading image',
    withInfo({
      text: <Docs />
    })(() => {
      return (<div style={{ background: 'whitesmoke', padding: '50px 0' }}>
        <div style={{ width: '1187px', margin: 'auto' }}>
          <Card>
            <LazyImage
              width={1122}
              height={400}
              src="https://firebasestorage.googleapis.com/v0/b/blog-9eb89.appspot.com/o/yosemite_cover.png?alt=media&token=c4dbfe80-e871-406d-b633-24d6496dce27"
              placeholder={(
                <img
                  alt='placeholder'
                  width="100%"
                  height="100%" src=''
                />
                            )}
            />
          </Card>
        </div>
      </div>)
    }
        )
  )