Sha256: 94278a0ad341e6e5530cec640bee836cec5c774e67d29df994156277952c4303

Contents?: true

Size: 1.71 KB

Versions: 34

Compression:

Stored size: 1.71 KB

Contents

/* eslint-disable jsx-control-statements/jsx-use-if-tag */
import React, { useState } from 'react'
import { Flex, Image } from 'playbook-ui'
import Lightbox from '../_lightbox.tsx'

const LightboxDefault = (props) => {
  const photos = [
    'https://images.unsplash.com/photo-1638727228877-d2a79ab75e68?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2668&q=80',
  ]
  const [selectedPhoto, setSelectedPhoto] = useState(0)
  const [showLightbox, toggleShowLightbox] = useState(false)

  const handleCloseLightbox = () => {
    toggleShowLightbox(!showLightbox)
    setSelectedPhoto(null)
  }

  const onPhotoClick = (photoIndex) => {
    toggleShowLightbox(!showLightbox)
    setSelectedPhoto(photoIndex)
  }

  return (
    <>
      <div>
        {showLightbox ? (
          <Lightbox
              icon="times"
              initialPhoto={selectedPhoto}
              onClose={handleCloseLightbox}
              photos={photos}
              {...props}
          />
        ) : (
          <div className="PhotoViewer">
            <Flex>
              {photos.map((photo, index) => {
                return (
                  <div
                      key={photo[index]}
                      onClick={() => onPhotoClick(index)}
                  >
                    <Image
                        cursor="pointer"
                        marginRight="xl"
                        rounded
                        size="lg"
                        url={photo}
                    />

                    <div className="overlay" />
                  </div>
                )
              })}
            </Flex>
          </div>
        )}
      </div>
    </>
  )
}

export default LightboxDefault

Version data entries

34 entries across 34 versions & 2 rubygems

Version Path
playbook_ui_docs-13.34.0.pre.alpha.PLAY14143373 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.34.0.pre.alpha.PLAY14143373 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.34.0.pre.alpha.PLAY14143372 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.34.0.pre.alpha.PLAY14143372 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.34.0.pre.alpha.PLAY14143358 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.34.0.pre.alpha.PLAY14143358 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.34.0.pre.alpha.PLAY14143357 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.34.0.pre.alpha.PLAY14143357 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.1.pre.alpha.PLAY14143340 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.1.pre.alpha.PLAY14143340 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.1.pre.alpha.PLAY14143336 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.1.pre.alpha.PLAY14143336 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.0.pre.alpha.PLAY14143318 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.0.pre.alpha.PLAY14143318 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.0.pre.alpha.PLAY14143312 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.0.pre.alpha.PLAY14143312 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.0.pre.alpha.PLAY14143306 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.0.pre.alpha.PLAY14143306 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui_docs-13.33.0.pre.alpha.PLAY14143305 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx
playbook_ui-13.33.0.pre.alpha.PLAY14143305 app/pb_kits/playbook/pb_lightbox/docs/_lightbox_default.jsx