Mimicry extension for Metafizzy’s Flickity. Lets Flickity instances mimic real-time interactions of another.
Demo ☞ hydnhntr.github.io/flickity-mimic/
- Replicates dragging and navigation actions in real-time
indexOffset
option to set the mimic ahead or behind the target’sselectedIndex
- No 2 way binding/sync capability, see Flickity Sync instead
- Intended to work with
dragging
andaccessibility
options set tofalse
. - No support for
groupCells
option, requires identical cell counts and works best withwrapAround: true
- Support different cell widths and
cellAlign
option.
<div class="gallery gallery-a">
...
</div>
<div class="gallery gallery-b">
...
</div>
// mimic options object to be supplied as nameValuePair on Flickity config
mimic: {
target: '.gallery-a'
// set as a selector string or HTMLElement `document.querySelector('.gallery-a')`, `jQuery('.gallery-a')[0]`
indexOffset: 1
// Integer, defaults to 0
}
$('.gallery-a').flickity();
$('.gallery-b').flickity({
wrapAround: true,
draggable: false,
accessibility: false,
mimic: {
target: '.gallery-a',
indexOffset: 1
}
});
var flktyA = new Flickity('.gallery-a');
var flktyB = new Flickity( '.gallery-b', {
wrapAround: true,
draggable: false,
accessibility: false,
mimic: {
target: '.gallery-a',
indexOffset: 1
}
});
<div class="gallery gallery-a js-flickity">
...
</div>
<div class="gallery gallery-b js-flickity"
data-flickity='{
"wrapAround": true,
"draggable": false,
"accessibility": false,
"mimic": {
"target": "#carousel-a",
"indexOffset": 1
}
}'>
...
</div>
npm: npm install flickity-mimic
Untested, but should work as per Flickity’s existing plugins: asNavFor, sync. If not, I’ve goofed.
MIT license
By Hayden Hunter, built upon the hard yards by Metafizzy