svelte-lightbox
v1.1.6
Published
Lightweight lightbox library for Svelte
Downloads
3,474
Maintainers
Readme
svelte-lightbox
Lightweight lightbox library for Svelte
Lightweight Lightbox, but very customizable Svelte component library. There is also support for mobile devices. Note that this first version of this library, if you notice any bug, please report it to this library's GitHub repository to the 'Issues' section.
Instalation
npm i svelte-lightbox -D
How to use
- Make Svelte page
Standard lightbox
Include
import { Lightbox } from 'svelte-lightbox';
into that file.Make
<Lightbox>
component and image you need to display put inside slot (as its child).
Lightbox with gallery
Include
import { LightboxGallery, GalleryImage, GalleryThumbnail } from 'svelte-lightbox';
into that file.Make
<LightboxGallery>
component and append to it list of<GalleryImage>
, which each<GalleryImage>
contains desired image (or it could be video).Prepend
<LightboxGallery>
with element or svelte:fragment with prop slot equal to"thumbnail"
, under this element place your thumbnail layout, which is basically layout with images wrapped inside<GalleryThumbnail>
.
Common use cases
<script>
import {
Lightbox,
LightboxGallery,
GalleryThumbnail,
GalleryImage
} from 'svelte-lightbox'
let lightboxProgrammaticController
</script>
<!-- Lightbox with image same as thumbnail -->
<Lightbox description="Simple lightbox">
<img src="path" alt="Simple lightbox">
</Lightbox>
<!-- Lightbox with different image from thumbnail -->
<Lightbox description="Lightbox with thumbnail and image">
<img slot="thumbnail" src="path/thumbnail.png" alt="Thumbnail">
<img src="path/image.png" alt="Lightbox image">
</Lightbox>
<!-- Programmatically controlled lightbox without thumbnail -->
<Lightbox enableFallbackThumbnail={false} bind:programmaticController={lightboxProgrammaticController}
description="Simple lightbox">
<img src="path" alt="Simple lightbox">
</Lightbox>
<LightboxGallery>
<!-- Layout-->
<svelte:fragment slot="thumbnail">
<div class="sample-class-1">
<GalleryThumbnail>
<img src="./thumbnail-0.jpg" alt="Simple lightbox">
</GalleryThumbnail>
<div class="sample-class-2">
<div class="sample-class-3">
<img src="./thumbnail-0.jpg" alt="Simple lightbox">
</div>
<div class="sample-class-4">
<img src="./thumbnail-0.jpg" alt="Simple lightbox">
</div>
</div>
</div>
</svelte:fragment>
<GalleryImage>
<img src="./image-0.jpg" alt="Simple lightbox">
</GalleryImage>
<GalleryImage>
<img src="./image-1.jpg" alt="Simple lightbox">
</GalleryImage>
<GalleryImage>
<img src="./image-2.jpg" alt="Simple lightbox">
</GalleryImage>
</LightboxGallery>
If you need more usage examples, you should see demo page code at this library GitHub repository.
API
This library mainly consists out of 2 components which are <Lightbox>
and <LightboxGallery>
, but their customization
is significant part of using them.
<Lightbox>
This component is meant to be used to display image, which is clickable, that click will trigger action to open same or different image in larger scale.
title string/HTML
Image's title that is displayed below the image (in a lightbox), feel free to use HTML (eg, <br>
, <span>
). Everything
in a lightbox footer is aligned to the left, but you can override it by putting it into <span>
which would allow you to
apply a different style or a class of your choosing.
description string/HTML
Image's description that is, similarly to the title, displayed under the image (in a lightbox). The difference between
those two are the title is wrapped in <h2>
and description is wrapped in <h5>
.
imagePreset ImagePrest (string)
Select between these 3 presets:
''
- Default preset, doesn't make any drastic behavior changes, just displays image in its maximum size and fits into viewport.'fullscreen'
- Makes image fullscreen to cover at least one of axes.'scroll'
- Enables scrolling big image instead of making it smaller to fit into the screen.
customization LightboxCustomization (object)/CSS
Using LightboxCustomization
object
Customization object contains these props, which represent html props of their key (e.g. closeButtonProps = html props of close button of).
- closeButtonProps:
HTMLButtonElement
- lightboxFooterProps:
HTMLDivElement
- lightboxHeaderProps:
HTMLDivElement
- coverProps:
HTMLDivElement
- lightboxProps:
HTMLDivElement
- thumbnailProps:
HTMLDivElement
Using CSS
If you'd like to change global styles, feel free to override these global CSS classes instead: .svelte-lightbox-main
,
.svelte-lightbox-body
, .svelte-lightbox-overlay
, .svelte-lightbox-header
, .svelte-lightbox-footer
and .svelte-lightbox-thumbnail
.
transitionDuration number
Duration of lightbox toggle, in milliseconds. Based on this number are calculated transitions for lightbox cover. Default
300
.
keepBodyScroll boolean
Keeps body scroll while lightbox is open. Default false
.
enableImageExpand boolean
Enables image inside lightbox to resize above its resolution. Default false
.
enableFallbackThumbnail boolean
Enables inferring thumbnail from lightbox content, if thumbnail isn't specified. Default true
.
enableEscapeToClose boolean
Enables closing lightbox on keydown which is equal to escape button. Default true
.
enableClickToClose boolean
Anywhere user clicks when modal is opened, closes it. Default false
.
showCloseButton boolean
Shows close button. Default true
.
isVisible boolean
Allows you to programmatically control lightbox visibility without programmaticController. Default varies on user activity.
programmaticController
Object with these basic control functions:
- toggle
() => void
- toggles lightbox (opened -> closed, vice versa) - open
() => void
- opens lightbox - close
() => void
- closes lightbox
<LightboxGallery>
Lightbox component with explicitly defined thumbnail layout and multiple images, allows listing thorough all images within gallery. According to almost 2 years experience of using this component (in early versions), I found out, that gallery without thumbnail layout doesn't give any sense in most of the cases, so I decided to embed this feature in design of this component.
title string/HTML
Same as in <Lightbox>
title, but this is same in whole gallery. <GalleryImage>
can override this title for specific image.
description string/HTML
Same as in <Lightbox>
description, but this is same in whole gallery. <GalleryImage>
can override this description for
specific image.
imagePreset ImagePrest (string)
Same as in <Lightbox>
.
customization LightboxCustomization (object)
Same as in <Lightbox>
.
transitionDuration number
Same as in <Lightbox>
.
keepBodyScroll boolean
Same as in <Lightbox>
.
enableImageExpand boolean
Same as in <Lightbox>
.
enableEscapeToClose boolean
Same as in <Lightbox>
.
enableClickToClose boolean
Same as in <Lightbox>
.
showCloseButton boolean
Same as in <Lightbox>
.
isVisible boolean
Same as in <Lightbox>
.
activeImage number
Number which sets visibility of image with id equal to it. Also optional, this is used for programmatic selecting of visible image when Lightbox is opened.
arrowsConfig GalleryArrowsConfig (object)
Allows customizing gallery arrows.
color string
Sets arrow color, valid value is any valid css color.
character GalleryArrowCharacter (string)
Sets arrow charter in edge cases (0th and last item of gallery). Valid values:
''
- Leaves arrow inactive and disables particular arrow on keyboard in edge case.'hide'
- Hides arrow and disables particular arrow on keyboard in edge case.'loop'
- Arrows are always active and keyboard arrows as well. For instance when user clicks left arrow on first image, last image will be displayed.
enableKeyboardControl boolean
Enables navigation in gallery using keyboard arrows. Default true
.
programmaticController
Object with these basic control functions:
- toggle
() => void
- toggles lightbox (opened -> closed, vice versa) - open
() => void
- opens lightbox - openImage
(imageId: number) => void
- opens lightbox at specific image - close
() => void
- closes lightbox
<GalleryThumbnail>
id number
Link to gallery image, it can be set to any number within gallery images, starting with 0. Default is order of
<GalleryThumbnail>
, so let's say you have 3 thumbnails under <LightboxGallery>
, the first thumbnails has id 0, next one
1 and third 2.
<GalleryImage>
title string/HTML
Same as <Lightbox>
title, but this is image specific, that means, it will be only shown for particular image.
description string/HTML
Same as <Lightbox>
description, but this is image specific, that means, it will be only shown for particular image.
Custom lightbox
This library by design allows you to construct custom lightbox by providing you with basic building block of lightbox.
If you want to use this advanced functionality, you are supposed to read code (I recommend reading it from GitHub, code
from NPM is already processed) of basic building blocks and examples of their usage (<Lightbox>
, <LightboxGallery>
)
as well, this documentation is only brief overview. You can take available building blocks and lay them down in different
way, or replace some of them by your own tweaked variants. Basic building blocks are:
Building blocks of lightbox modal
<LightboxThumbnail>
Name says it all.
<BodyChild>
Makes content of slot direct child of <body>
, this can be especially useful when using CSS frameworks, which can break
z-index
effect in some cases (element with higher index is lower than element with lower index).
<ModalCover>
Cover behind lightbox modal, dimmed background.
<Modal>
Name says it all.
<LightboxHeader>
Header of lightbox modal, contains close button as well as window keypress binding.
<LightboxHeader>
Body of lightbox modal, contains lightbox image.
<LightboxFooter>
Footer of lightbox modal, contains title, description of image and gallery counter.
<GalleryController>
Layout with image space, left and right arrow, internal logic of gallery.
<PreviousImageButton>
and <NextImageButton>
Buttons which allow you to move within gallery.
i18n
There is 1 thing that has to be localized and that is gallery counter, that what shows user where in gallery is located
(e.g. Image 2 of 4). Gallery counter text can be customized by overriding its generator. That can be done by importing
i18n from 'svelte-lightbox' and then setting generateLocalizedGalleryCounter
to desired generator.
Default generateLocalizedGalleryCounter
(activeImage: number, imageCount: number): string => {
return `Image ${activeImage + 1} of ${imageCount}`
}
Contribution
Every issue or code contribution is welcome.
License
It's free, this component is under MIT license.