Bare Slideshow v0.3-BETA
Basic slideshow plugin written in vanilla js.
Features
- Flexible / Responsive
- Handles image loading
- Adds css based on settings
- Loads start slide first (to reduce load time)
- Support for handling custom slide types (e.g. video)
To do
How to use
HTML:
<div class="slideshow">
<div class="slideshow__slides">
<div class="slideshow__slide">
<img bs-src="original.jpg" />
</div>
</div>
</div>
JS:
var instance = new BareSlideshow(element, optional_settings);
instance.run();
instance.el.onclick = instance.goToNextSlide;
Settings
Copied from source code, line 5:
const DEFAULT_SETTINGS = {
selectors: {
slides: ".slideshow__slide",
slidesWrapper: ".slideshow__slides"
},
activeSlideClass: "is-active",
direction: "horizontal",
disableSlideCssTransform: false,
fadeAnimationDuration: 700,
fitImages: true,
hasVariableHeight: false,
loadedFirstClass: "has-loaded-first",
loadingClass: "is-loading",
setImagesAsBackground: false,
slideAnimationDuration: 400,
startInTheMiddle: false,
startSlide: 1,
transition: "slide",
transitionSystem: "two-step",
versions: NEW_OBJECT_PLACEHOLDER,
versionElementSelector: false
};
Transition systems
Two step (two-step)
Removes the previous slide and brings in the new one.
All (all)
Keeps all the slides in the DOM. Use this if you want show multiple slides next to each other.
Versions
Versions can be used to load smaller assets depending on window width.
settings = {
versions = {
small: 640,
medium: 1024
}
};
<div class="slideshow">
<div class="slideshow__slides">
<div class="slideshow__slide">
<img bs-small-src="small.jpg" bs-medium-src="medium.jpg" bs-src="original.jpg" />
</div>
</div>
</div>
Custom slide types
A slide can have a type by passing the 'bs-type' attribute to the slide element. When loading the slideshow, the function 'loadSlideWith{{TYPE}}' will be called for each slide. Make sure this function returns a Promise. Check bareSlideshowInstance.loadSlideWithImages
for a reference.