Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

vueperslides

Package Overview
Dependencies
Maintainers
1
Versions
109
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

vueperslides - npm Package Compare versions

Comparing version 1.1.0 to 1.2.0

238

dist/vueperslides.js

@@ -20,3 +20,3 @@ (function (global, factory) {

var VueperSlide = { render: function render() {
var _vm = this;var _h = _vm.$createElement;var _c = _vm._self._c || _h;return _c('div', { class: { 'vueperslides__slide': true, 'vueperslides__slide--active': _vm.$parent.activeSlideUid === _vm._uid }, style: _vm.styles }, [!_vm.$parent.conf.slideContentOutside && (_vm.title || _vm.content) ? _c('div', { staticClass: "vueperslides__slide-content" }, [_c('p', { staticClass: "slide-title", domProps: { "innerHTML": _vm._s(_vm.title) } }), _c('p', { staticClass: "slide-content", domProps: { "innerHTML": _vm._s(_vm.content) } })]) : _vm._e()]);
var _vm = this;var _h = _vm.$createElement;var _c = _vm._self._c || _h;return _c('div', { class: { 'vueperslides__slide': true, 'vueperslides__slide--active': _vm.$parent.slides.activeUid === _vm._uid }, style: _vm.styles }, [!_vm.$parent.conf.slideContentOutside && (_vm.title || _vm.content) ? _c('div', { staticClass: "vueperslides__slide-content" }, [_c('p', { staticClass: "slide-title", domProps: { "innerHTML": _vm._s(_vm.title) } }), _c('p', { staticClass: "slide-content", domProps: { "innerHTML": _vm._s(_vm.content) } })]) : _vm._e()]);
}, staticRenderFns: [],

@@ -71,2 +71,4 @@ props: {

var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }

@@ -87,8 +89,8 @@

var VueperSlides = { render: function render() {
var _vm = this;var _h = _vm.$createElement;var _c = _vm._self._c || _h;return _c('div', { staticClass: "vueperslides-wrapper", class: { 'ready': _vm.isReady } }, [_vm.conf.slideContentOutside ? _c('div', { staticClass: "vueperslides__slide-content vueperslides__slide-content--outside", class: _vm.conf.slideContentOutsideClass }, [_vm.slidesCount && _vm.slides[_vm.currentSlide].title ? _c('p', { staticClass: "slide-title", domProps: { "innerHTML": _vm._s(_vm.slides[_vm.currentSlide].title) } }) : _vm._e(), _vm.slidesCount && _vm.slides[_vm.currentSlide].content ? _c('p', { staticClass: "slide-content", domProps: { "innerHTML": _vm._s(_vm.slides[_vm.currentSlide].content) } }) : _vm._e()]) : _vm._e(), _c('div', { ref: "vueperslides", staticClass: "vueperslides", class: { 'vueperslides--fade': _vm.conf.fade, 'vueperslides--touchable': _vm.touchEnabled && !_vm.disable } }, [_c('div', { staticClass: "vueperslides__slides-wrapper" }, [_c('div', { ref: "track", staticClass: "vueperslides__track", class: { 'vueperslides__track--dragging': _vm.dragging, 'vueperslides__track--mousedown': _vm.mouseDown }, style: !_vm.conf.fade ? 'transform: translate3d(' + _vm.currentTranslation + '%, 0, 0)' : 'padding-bottom: ' + _vm.conf.slideRatio * 100 + '%' }, [_vm.slidesCount && _vm.clones[0] ? _c('vueper-slide', { staticClass: "vueperslides__slide--clone", style: _vm.clones[0].style, attrs: { "clone": 0, "title": _vm.clones[0].title, "content": _vm.clones[0].content, "image": _vm.clones[0].image } }) : _vm._e(), _vm._t("default", null, { currentSlide: _vm.currentSlide }), _vm.slidesCount && _vm.clones[1] ? _c('vueper-slide', { staticClass: "vueperslides__slide--clone", style: _vm.clones[1].style, attrs: { "clone": 1, "title": _vm.clones[1].title, "content": _vm.clones[1].content, "image": _vm.clones[1].image } }) : _vm._e()], 2)]), _vm.$slots.pausedIcon ? _c('div', { staticClass: "vueperslides__paused" }, [_vm._t("pausedIcon")], 2) : _vm._e(), _vm.conf.arrows && _vm.slidesCount > 1 && !_vm.disable ? _c('div', { staticClass: "vueperslides__arrows" }, [_c('button', { directives: [{ name: "show", rawName: "v-show", value: !_vm.arrowPrevDisabled, expression: "!arrowPrevDisabled" }], staticClass: "vueperslides__arrow vueperslides__arrow--prev", on: { "click": function click($event) {
var _vm = this;var _h = _vm.$createElement;var _c = _vm._self._c || _h;return _c('div', { staticClass: "vueperslides-wrapper", class: { 'ready': _vm.isReady } }, [_vm.conf.slideContentOutside ? _c('div', { staticClass: "vueperslides__slide-content vueperslides__slide-content--outside", class: _vm.conf.slideContentOutsideClass }, [_vm.slides.count && _vm.slides.list[_vm.slides.current].title ? _c('p', { staticClass: "slide-title", domProps: { "innerHTML": _vm._s(_vm.slides.list[_vm.slides.current].title) } }) : _vm._e(), _vm.slides.count && _vm.slides.list[_vm.slides.current].content ? _c('p', { staticClass: "slide-content", domProps: { "innerHTML": _vm._s(_vm.slides.list[_vm.slides.current].content) } }) : _vm._e()]) : _vm._e(), _c('div', { ref: "vueperslides", staticClass: "vueperslides", class: { 'vueperslides--fade': _vm.conf.fade, 'vueperslides--touchable': _vm.touch.enabled && !_vm.disable } }, [_c('div', { staticClass: "vueperslides__slides-wrapper" }, [_c('div', { ref: "track", staticClass: "vueperslides__track", class: { 'vueperslides__track--dragging': _vm.touch.dragging, 'vueperslides__track--mousedown': _vm.mouseDown }, style: !_vm.conf.fade ? 'transform: translate3d(' + _vm.currentTranslation + '%, 0, 0)' : 'padding-bottom: ' + _vm.conf.slideRatio * 100 + '%' }, [_vm.slides.count && _vm.clones[0] ? _c('vueper-slide', { staticClass: "vueperslides__slide--clone", style: _vm.clones[0].style, attrs: { "clone": 0, "title": _vm.clones[0].title, "content": _vm.clones[0].content, "image": _vm.clones[0].image } }) : _vm._e(), _vm._t("default", null, { currentSlide: _vm.slides.current }), _vm.slides.count && _vm.clones[1] ? _c('vueper-slide', { staticClass: "vueperslides__slide--clone", style: _vm.clones[1].style, attrs: { "clone": 1, "title": _vm.clones[1].title, "content": _vm.clones[1].content, "image": _vm.clones[1].image } }) : _vm._e()], 2)]), _vm.$slots.pausedIcon ? _c('div', { staticClass: "vueperslides__paused" }, [_vm._t("pausedIcon")], 2) : _vm._e(), _vm.conf.arrows && _vm.slides.count > 1 && !_vm.disable ? _c('div', { staticClass: "vueperslides__arrows" }, [_c('button', { directives: [{ name: "show", rawName: "v-show", value: !_vm.arrowPrevDisabled, expression: "!arrowPrevDisabled" }], staticClass: "vueperslides__arrow vueperslides__arrow--prev", on: { "click": function click($event) {
_vm.onArrowClick(false);
} } }, [_vm._t("arrowLeft", [_c('svg', { attrs: { "viewBox": "0 0 24 24" } }, [_c('path', { attrs: { "d": "M16.2,21c0.3,0,0.5-0.1,0.7-0.3c0.4-0.4,0.4-1,0-1.4L9.6,12L17,4.7c0.4-0.4,0.4-1,0-1.4c-0.4-0.4-1-0.4-1.4,0L6.8,12l8.8,8.7C15.7,20.9,16,21,16.2,21z" } })])])], 2), _c('button', { directives: [{ name: "show", rawName: "v-show", value: !_vm.arrowNextDisabled, expression: "!arrowNextDisabled" }], staticClass: "vueperslides__arrow vueperslides__arrow--next", on: { "click": function click($event) {
_vm.onArrowClick();
} } }, [_vm._t("arrowRight", [_c('svg', { attrs: { "viewBox": "0 0 24 24" } }, [_c('path', { attrs: { "d": "M7.8,21c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l7.4-7.3L7,4.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l8.8,8.7l-8.8,8.7C8.3,20.9,8,21,7.8,21z" } })])])], 2)]) : _vm._e(), _vm.conf.bullets && _vm.slidesCount > 1 && !_vm.disable ? _c('div', { staticClass: "vueperslides__bullets", class: { 'vueperslides__bullets--outside': _vm.conf.bulletsOutside } }, _vm._l(_vm.slides, function (item, i) {
return _c('button', { key: i, ref: "bullet", refInFor: true, staticClass: "vueperslides__bullet", class: { 'vueperslides__bullet--active': _vm.currentSlide === i }, on: { "click": function click($event) {
} } }, [_vm._t("arrowRight", [_c('svg', { attrs: { "viewBox": "0 0 24 24" } }, [_c('path', { attrs: { "d": "M7.8,21c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l7.4-7.3L7,4.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l8.8,8.7l-8.8,8.7C8.3,20.9,8,21,7.8,21z" } })])])], 2)]) : _vm._e(), _vm.conf.bullets && _vm.slides.count > 1 && !_vm.disable ? _c('div', { staticClass: "vueperslides__bullets", class: { 'vueperslides__bullets--outside': _vm.conf.bulletsOutside } }, _vm._l(_vm.slides.list, function (item, i) {
return _c('button', { key: i, ref: "bullet", refInFor: true, staticClass: "vueperslides__bullet", class: { 'vueperslides__bullet--active': _vm.slides.current === i }, on: { "click": function click($event) {
_vm.goToSlide(i);

@@ -170,2 +172,8 @@ }, "keyup": [function ($event) {

},
// By default when touch is enabled you have to drag from a slide side and pass 50% of slideshow width to change
// slide. This setting changes this behavior to a horizontal pixel amount from anywhere on slideshow.
draggingDistance: {
type: [Number],
default: null
},
disable: {

@@ -185,20 +193,12 @@ type: Boolean,

isReady: false,
slides: [],
slidesCount: 0,
activeSlideUid: null,
slides: { list: [], count: 0, activeUid: null, current: 0, clones: [] },
clones: [],
mouseDown: false,
mouseOver: false,
dragging: false,
currentSlide: 0,
touch: { enabled: true, dragging: false, dragStartX: 0, dragAmount: 0, goNext: true },
currentTranslation: 0,
dragStartX: 0,
dragStartY: 0,
goNext: true,
timer: null,
arrowPrevDisabled: false,
arrowNextDisabled: false,
touchEnabled: true,
clones: [],
breakpointsList: [],
currentBreakpoint: null,
breakpointsData: { list: [], current: null },
conf: null

@@ -208,3 +208,3 @@ };

created: function created() {
this.conf = Object.assign({}, this.$props);
this.conf = _extends({}, this.$props);
delete this.conf.breakpoints; // Prevent cyclic redundancy.

@@ -219,3 +219,3 @@ },

this.emit('before-init', false);
this.slidesCount = this.slides.length;
this.slides.count = this.slides.list.length;

@@ -227,3 +227,3 @@ if (Object.keys(this.breakpoints).length) {

this.touchEnabled = this.conf.touchable;
this.touch.enabled = this.conf.touchable;

@@ -252,7 +252,7 @@ if (this.conf.infinite && !this.conf.fade) {

args[1] = {};
if (includeCurrentSlide && this.activeSlideUid) {
if (includeCurrentSlide && this.slides.activeUid) {
args[1].currentSlide = {
index: this.currentSlide,
title: this.slides[this.currentSlide].title,
content: this.slides[this.currentSlide].content
index: this.slides.current,
title: this.slides.list[this.slides.current].title,
content: this.slides.list[this.slides.current].content
};

@@ -266,4 +266,4 @@ }

index: nextSlide,
title: this.slides[nextSlide].title,
content: this.slides[nextSlide].content
title: this.slides.list[nextSlide].title,
content: this.slides.list[nextSlide].content
};

@@ -276,3 +276,3 @@ }

setBreakpointsList: function setBreakpointsList() {
this.breakpointsList = [99999].concat(_toConsumableArray(Object.keys(this.breakpoints))).sort(function (a, b) {
this.breakpointsData.list = [99999].concat(_toConsumableArray(Object.keys(this.breakpoints))).sort(function (a, b) {
return parseInt(a) < parseInt(b);

@@ -283,14 +283,14 @@ });

var windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;
var breakpoints = [windowWidth].concat(_toConsumableArray(this.breakpointsList)).sort(function (a, b) {
var breakpoints = [windowWidth].concat(_toConsumableArray(this.breakpointsData.list)).sort(function (a, b) {
return parseInt(a) < parseInt(b);
});
return this.breakpointsList[breakpoints.indexOf(windowWidth) - 1];
return this.breakpointsData.list[breakpoints.indexOf(windowWidth) - 1];
},
hasBreakpointChanged: function hasBreakpointChanged(breakpoint) {
return this.currentBreakpoint !== breakpoint;
return this.breakpointsData.current !== breakpoint;
},
setBreakpointConfig: function setBreakpointConfig(breakpoint) {
this.currentBreakpoint = breakpoint;
this.conf = Object.assign({}, this.$props, this.$props.breakpoints[breakpoint] || {});
this.breakpointsData.current = breakpoint;
this.conf = _extends({}, this.$props, this.$props.breakpoints[breakpoint] || {});

@@ -309,12 +309,12 @@ // Re-apply slide ratio on clones.

this.clones[0] = {
title: this.slides[this.slidesCount - 1].title,
content: this.slides[this.slidesCount - 1].content,
image: this.slides[this.slidesCount - 1].image,
title: this.slides.list[this.slides.count - 1].title,
content: this.slides.list[this.slides.count - 1].content,
image: this.slides.list[this.slides.count - 1].image,
// Need to define CSS style in an object format for possible later override of paddingBottom in setBreakpointConfig().
style: { cssText: lastSlide && lastSlide.attributes.style ? lastSlide.attributes.style.value : null }
};
this.clones[1] = {
title: this.slides[0].title,
content: this.slides[0].content,
image: this.slides[0].image,
// style: firstSlide && lastSlide.attributes.style ? firstSlide.attributes.style.value : null
title: this.slides.list[0].title,
content: this.slides.list[0].content,
image: this.slides.list[0].image,
style: { cssText: firstSlide && lastSlide.attributes.style ? firstSlide.attributes.style.value : null }

@@ -326,3 +326,3 @@ };

if (this.touchEnabled) {
if (this.touch.enabled) {
this.$refs.track.addEventListener(hasTouch ? 'touchstart' : 'mousedown', this.onMouseDown);

@@ -339,16 +339,6 @@ document.addEventListener(hasTouch ? 'touchmove' : 'mousemove', this.onMouseMove);

if (this.breakpointsList.length) {
if (this.breakpointsData.list.length) {
window.addEventListener('resize', this.onResize);
}
},
getDragPercentage: function getDragPercentage(e) {
this.dragStartX = 'ontouchstart' in window ? e.touches[0].clientX : e.clientX;
// For full window width slideshow only.
// let windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth
// return this.dragStartX / windowWidth
var vueperslidesWrapper = this.$refs.vueperslides.offsetParent;
return (this.dragStartX - vueperslidesWrapper.offsetLeft) / vueperslidesWrapper.clientWidth;
},
onResize: function onResize() {

@@ -375,37 +365,56 @@ var breakpoint = this.getCurrentBreakpoint();

onMouseDown: function onMouseDown(e) {
if (!this.touchEnabled || this.disable) return;
if (!this.touch.enabled || this.disable) return;
if (!e.touches) e.preventDefault();
if (!e.touches) {
e.preventDefault();
}
// this.disableScroll()
this.mouseDown = true;
var dragPercentage = this.getDragPercentage(e);
if (this.draggingDistance) {
// Store drag start in var for distance calculation in onMouseUp().
this.touch.dragStartX = 'ontouchstart' in window ? e.touches[0].clientX : e.clientX;
} else {
var dragPercentage = this.getDragPercentage(e);
// Set a flag for use while dragging in `onMouseMove` to know if drag was toward left or right.
this.goNext = dragPercentage >= 0.5;
// Set a flag for use while dragging in `onMouseMove` to know if drag was toward left or right.
this.touch.goNext = dragPercentage >= 0.5;
this.currentTranslation = -100 * (this.currentSlide + (this.goNext ? 1 : 0) + (this.clones.length ? 1 : 0) - dragPercentage);
this.currentTranslation = -100 * (this.slides.current + (this.touch.goNext ? 1 : 0) + (this.clones.length ? 1 : 0) - dragPercentage);
}
},
onMouseMove: function onMouseMove(e) {
if (this.mouseDown || this.dragging) {
if (this.mouseDown || this.touch.dragging) {
this.mouseDown = false;
this.dragging = true;
this.touch.dragging = true;
var dragPercentage = this.getDragPercentage(e);
this.currentTranslation = -100 * (this.currentSlide + (this.goNext ? 1 : 0) + (this.clones.length ? 1 : 0) - dragPercentage);
if (this.draggingDistance) {
this.touch.dragAmount = this.getDragAmount(e);
var dragAmountPercentage = this.touch.dragAmount / this.$refs.vueperslides.offsetParent.clientWidth;
this.currentTranslation = -100 * (this.slides.current + (this.clones.length ? 1 : 0) - dragAmountPercentage);
} else {
var dragPercentage = this.getDragPercentage(e);
this.currentTranslation = -100 * (this.slides.current + (this.touch.goNext ? 1 : 0) + (this.clones.length ? 1 : 0) - dragPercentage);
}
}
},
onMouseUp: function onMouseUp() {
if (this.mouseDown || this.dragging) {
onMouseUp: function onMouseUp(e) {
if (this.mouseDown || this.touch.dragging) {
this.mouseDown = false;
this.dragging = false;
this.touch.dragging = false;
// this.currentTranslation = Math.min(Math.max(0, Math.round(this.currentTranslation / 100) * 100), (this.slidesCount - 1) * 100)
// this.currentSlide = this.currentTranslation / 100
var slideOnDragEnd = void 0;
if (this.draggingDistance) {
var dragAmount = this.touch.dragAmount;
var dragAmountPercentage = dragAmount / this.$refs.vueperslides.offsetParent.clientWidth;
// When the drag is realeased, calculate if the drag ends before or after the 50%-slideshow-width threshold.
// Then finish the sliding toward that slide.
var slideOnDragEnd = -(Math.round(this.currentTranslation / 100) + (this.clones.length ? 1 : 0));
slideOnDragEnd = this.slides.current;
if (Math.abs(dragAmount) >= this.draggingDistance) {
slideOnDragEnd += dragAmount > 0 ? -1 : 1;
}
} else {
// When the drag is realeased, calculate if the drag ends before or after the 50%-slideshow-width threshold.
// Then finish the sliding toward that slide.
slideOnDragEnd = -(Math.round(this.currentTranslation / 100) + (this.clones.length ? 1 : 0));
}

@@ -420,16 +429,36 @@ var _getSlideInRange2 = this.getSlideInRange(slideOnDragEnd),

if (this.arrowNextDisabled && this.conf.autoplay && nextSlide === 0) {
nextSlide = this.slidesCount - 1;
nextSlide = this.slides.count - 1;
}
// Only call `goToSlide` if the drag ends on a slide that is different than the currentSlide.
if (nextSlide !== this.currentSlide) {
if (nextSlide !== this.slides.current) {
this.goToSlide(slideOnDragEnd);
} else {
// Apply transition to snap back to current slide.
this.currentTranslation = -(this.currentSlide + (this.clones.length ? 1 : 0)) * 100;
this.currentTranslation = -(this.slides.current + (this.clones.length ? 1 : 0)) * 100;
}
this.touch.dragStartX = null;
this.touch.dragAmount = null;
this.enableScroll();
}
},
getDragPercentage: function getDragPercentage(e) {
var dragStartX = 'ontouchstart' in window ? e.touches[0].clientX : e.clientX;
// For full window width slideshow only.
// let windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth
// return dragStartX / windowWidth
var vueperslidesWrapper = this.$refs.vueperslides.offsetParent;
return (dragStartX - vueperslidesWrapper.offsetLeft) / vueperslidesWrapper.clientWidth;
},
/**
* Return the x distance in pixel between drag start and current drag position.
*/
getDragAmount: function getDragAmount(e) {
return ('ontouchstart' in window ? e.touches[0].clientX : e.clientX) - this.touch.dragStartX;
},
disableScroll: function disableScroll() {

@@ -453,3 +482,3 @@ document.ontouchmove = function (e) {

this.timer = setTimeout(function () {
_this.goToSlide(_this.currentSlide + 1, true, true);
_this.goToSlide(_this.slides.current + 1, true, true);
}, this.conf.speed);

@@ -460,3 +489,3 @@ },

this.goToSlide(this.currentSlide + (next ? 1 : -1));
this.goToSlide(this.slides.current + (next ? 1 : -1));
},

@@ -469,5 +498,5 @@ getSlideInRange: function getSlideInRange(i) {

if (i < 0) {
i = this.slidesCount - 1;
i = this.slides.count - 1;
clone = 0;
} else if (i > this.slidesCount - 1) {
} else if (i > this.slides.count - 1) {
i = 0;

@@ -478,10 +507,10 @@ clone = 1;

// If not infinite, can't go lower than 0 or beyond `slidesCount` with `disableArrowsOnEdges`.
// If not infinite, can't go lower than 0 or beyond `slides.count` with `disableArrowsOnEdges`.
// If `disableArrowsOnEdges` is enabled going out of range will take first slide from the other end
// of the slideshow.
else {
if (i < 0) i = this.conf.disableArrowsOnEdges ? 0 : this.slidesCount - 1;else if (i > this.slidesCount - 1) {
if (i < 0) i = this.conf.disableArrowsOnEdges ? 0 : this.slides.count - 1;else if (i > this.slides.count - 1) {
// If autoplay is on but disableArrowsOnEdges is enabled, going beyond the last one will also bring
// the first one in.
i = this.conf.disableArrowsOnEdges ? this.conf.autoplay ? 0 : this.slidesCount - 1 : 0;
i = this.conf.disableArrowsOnEdges ? this.conf.autoplay ? 0 : this.slides.count - 1 : 0;
}

@@ -498,3 +527,3 @@ }

if (!this.slidesCount || this.disable) return;
if (!this.slides.count || this.disable) return;

@@ -515,3 +544,3 @@ if (this.conf.autoplay) this.clearTimer();

this.arrowPrevDisabled = nextSlide === 0;
this.arrowNextDisabled = nextSlide === this.slidesCount - 1;
this.arrowNextDisabled = nextSlide === this.slides.count - 1;
}

@@ -528,7 +557,7 @@

setTimeout(function () {
_this2.goToSlide(nextSlideIsClone ? 0 : _this2.slidesCount - 1, false, autoSliding);
_this2.goToSlide(nextSlideIsClone ? 0 : _this2.slides.count - 1, false, autoSliding);
}, 400);
}
this.currentSlide = nextSlide;
this.slides.current = nextSlide;

@@ -538,7 +567,7 @@ // Only apply sliding transition when the slideshow animation type is `slide`.

if (nextSlideIsClone !== null) {
this.currentTranslation = -100 * (nextSlideIsClone ? this.slidesCount + 1 : 0);
} else this.currentTranslation = -100 * (this.currentSlide + (this.clones.length ? 1 : 0));
this.currentTranslation = -100 * (nextSlideIsClone ? this.slides.count + 1 : 0);
} else this.currentTranslation = -100 * (this.slides.current + (this.clones.length ? 1 : 0));
}
this.activeSlideUid = this.slides[this.currentSlide]._uid;
this.slides.activeUid = this.slides.list[this.slides.current]._uid;

@@ -549,4 +578,4 @@ if (this.conf.autoplay && !this.mouseOver) {

if (this.slidesCount) {
if (this.$slots.default[this.currentSlide]) {
if (this.slides.count) {
if (this.$slots.default[this.slides.current]) {
// First use of goToSlide is while init, so should not propagate an event.

@@ -556,4 +585,4 @@ if (this.isReady) this.emit('slide');

if (this.isReady && !autoSliding && this.$refs.bullet[this.currentSlide]) {
this.$refs.bullet[this.currentSlide].focus();
if (this.isReady && !autoSliding && this.$refs.bullet[this.slides.current]) {
this.$refs.bullet[this.slides.current].focus();
}

@@ -570,9 +599,9 @@ }

} else {
// Add the slide in the slides array & update slidesCount.
this.slides.push(newSlide);
this.slidesCount = this.slides.length;
// Add the slide in the slides array & update slides.count.
this.slides.list.push(newSlide);
this.slides.count = this.slides.list.length;
}
if (this.slidesCount > 1) {
this.touchEnabled = true;
if (this.slides.count > 1) {
this.touch.enabled = true;
}

@@ -592,16 +621,16 @@

this.slides.some(function (slide, i) {
this.slides.list.some(function (slide, i) {
if (slide._uid === uid) {
// Remove the slide.
_this4.slides.splice(i, 1);
_this4.slidesCount = _this4.slides.length;
_this4.slides.list.splice(i, 1);
_this4.slides.count = _this4.slides.list.length;
// If the slide to remove is the current slide, slide to the previous slide.
if (uid === _this4.activeSlideUid) {
_this4.activeSlideUid = null;
if (uid === _this4.slides.activeUid) {
_this4.slides.activeUid = null;
_this4.goToSlide(i - 1, true, true);
}
if (_this4.slidesCount <= 1) {
_this4.touchEnabled = false;
if (_this4.slides.count <= 1) {
_this4.touch.enabled = false;
}

@@ -615,3 +644,3 @@

if (this.slidesCount && needReclone) {
if (this.slides.count && needReclone) {
this.cloneSlides();

@@ -623,3 +652,2 @@ }

// Expose component to global scope.
if (typeof window !== 'undefined' && window.Vue) {

@@ -626,0 +654,0 @@ window.Vue.component('vueper-slides', VueperSlides);

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t(e.VueperSlides=e.VueperSlides||{})}(this,function(e){"use strict";!function(){if("undefined"!=typeof document){var e=document.head||document.getElementsByTagName("head")[0],t=document.createElement("style");t.type="text/css",t.styleSheet?t.styleSheet.cssText="":t.appendChild(document.createTextNode("")),e.appendChild(t)}}();var t={render:function(){var e=this,t=e.$createElement,s=e._self._c||t;return s("div",{class:{vueperslides__slide:!0,"vueperslides__slide--active":e.$parent.activeSlideUid===e._uid},style:e.styles},[e.$parent.conf.slideContentOutside||!e.title&&!e.content?e._e():s("div",{staticClass:"vueperslides__slide-content"},[s("p",{staticClass:"slide-title",domProps:{innerHTML:e._s(e.title)}}),s("p",{staticClass:"slide-content",domProps:{innerHTML:e._s(e.content)}})])])},staticRenderFns:[],props:{clone:{type:Number,default:null},image:{type:String,default:""},title:{type:String,default:""},content:{type:String,default:""}},created:function(){this.$parent.addSlide({_uid:this._uid,image:this.image,title:this.title,content:this.content,clone:this.clone})},destroyed:function(){null===this.clone&&this.$parent.removeSlide(this._uid)},computed:{styles:function(){var e={};return this.image&&(e.backgroundImage="url("+this.image+")"),this.$parent.conf.slideRatio&&(e.paddingBottom=100*this.$parent.conf.slideRatio+"%"),e}}};function s(e){if(Array.isArray(e)){for(var t=0,s=Array(e.length);t<e.length;t++)s[t]=e[t];return s}return Array.from(e)}!function(){if("undefined"!=typeof document){var e=document.head||document.getElementsByTagName("head")[0],t=document.createElement("style"),s='.vueperslides { position: relative; } .vueperslides-wrapper { position: relative; } .vueperslides__slides-wrapper { position: relative; overflow: hidden; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; z-index: 1; } .vueperslides__slides-wrapper::before, .vueperslides__slides-wrapper::after { content: ""; position: absolute; bottom: 100%; left: -1em; right: -1em; height: 2em; box-shadow: 0 0 20px rgba(0, 0, 0, 0.25); z-index: 2; } .vueperslides__slides-wrapper::after { top: 100%; bottom: auto; } .vueperslides--fade .vueperslides__track { white-space: normal; transition: none; } .vueperslides--touchable .vueperslides__track { cursor: ew-resize; cursor: -webkit-grab; } .vueperslides--touchable .vueperslides__track--mousedown, .vueperslides--touchable .vueperslides__track--dragging { cursor: -webkit-grabbing; } .vueperslides__track { white-space: nowrap; transition: 0.5s ease-in-out transform; } .vueperslides__track--mousedown { transition: 0.2s ease-in-out transform; } .vueperslides__track--dragging { transition: none; } .vueperslides__track--no-animation { transition-duration: 0s; } .vueperslides__slide { white-space: normal; padding-bottom: 34%; background-position: top; background-size: cover; display: inline-block; width: 100%; height: 0; margin-bottom: -8px; } .vueperslides__slide-content { user-select: none; } .vueperslides__slide-content--outside { user-select: initial; } .vueperslides--fade .vueperslides__slide { position: absolute; top: 0; left: 0; right: 0; bottom: 0; opacity: 0; transition: .8s ease-in-out opacity; } .vueperslides--fade .vueperslides__slide--active { z-index: 1; opacity: 1; } .vueperslides__arrow { position: absolute; top: 50%; background-color: transparent; border: none; color: #fff; fill: currentColor; font-size: 3em; width: 1em; text-align: center; transform: translateY(-50%); opacity: 0.7; z-index: 10; transition: 0.3s ease-in-out; cursor: pointer; user-select: none; outline: none; z-index: 2; } .vueperslides__arrow--prev { left: 10px; } .vueperslides__arrow--next { right: 10px; } .vueperslides__arrow:hover { opacity: 1; } .vueperslides__paused { position: absolute; top: 3%; right: 3%; opacity: 0; transition: 0.3s ease-in-out; text-shadow: 0 0 3px rgba(0, 0, 0, 0.4); z-index: 1; } .vueperslides:hover .vueperslides__paused { opacity: 1; } .vueperslides__bullets { display: flex; justify-content: center; position: absolute; bottom: 0; left: 0; right: 0; } .vueperslides__bullets--outside { position: relative; } .vueperslides__bullet { width: 12px; height: 12px; border-radius: 12px; border: 1px solid #fff; background-color: transparent; box-shadow: 0 0 1px rgba(0, 0, 0, 0.5), 0 0 3px rgba(0, 0, 0, 0.3); margin: 1.5em 0.6em; padding: 0; display: inline-block; cursor: pointer; user-select: none; outline: none; z-index: 2; display: flex; justify-content: center; align-items: center; } .vueperslides__bullet--active { background-color: #fff; } .vueperslides__bullet span { display: none; } @media screen and (max-width: 1000px) { .vueperslides__slide { padding-bottom: 45%; } .vueperslides--fade .vueperslides__track { padding-bottom: 45%; } } @media screen and (max-width: 700px) { .vueperslides__slide { padding-bottom: 54%; } .vueperslides--fade .vueperslides__track { padding-bottom: 54%; } } @media screen and (max-width: 400px) { .vueperslides__slide { padding-bottom: 60%; } .vueperslides--fade .vueperslides__track { padding-bottom: 60%; } } ';t.type="text/css",t.styleSheet?t.styleSheet.cssText=s:t.appendChild(document.createTextNode(s)),e.appendChild(t)}}();var i={render:function(){var e=this,t=e.$createElement,s=e._self._c||t;return s("div",{staticClass:"vueperslides-wrapper",class:{ready:e.isReady}},[e.conf.slideContentOutside?s("div",{staticClass:"vueperslides__slide-content vueperslides__slide-content--outside",class:e.conf.slideContentOutsideClass},[e.slidesCount&&e.slides[e.currentSlide].title?s("p",{staticClass:"slide-title",domProps:{innerHTML:e._s(e.slides[e.currentSlide].title)}}):e._e(),e.slidesCount&&e.slides[e.currentSlide].content?s("p",{staticClass:"slide-content",domProps:{innerHTML:e._s(e.slides[e.currentSlide].content)}}):e._e()]):e._e(),s("div",{ref:"vueperslides",staticClass:"vueperslides",class:{"vueperslides--fade":e.conf.fade,"vueperslides--touchable":e.touchEnabled&&!e.disable}},[s("div",{staticClass:"vueperslides__slides-wrapper"},[s("div",{ref:"track",staticClass:"vueperslides__track",class:{"vueperslides__track--dragging":e.dragging,"vueperslides__track--mousedown":e.mouseDown},style:e.conf.fade?"padding-bottom: "+100*e.conf.slideRatio+"%":"transform: translate3d("+e.currentTranslation+"%, 0, 0)"},[e.slidesCount&&e.clones[0]?s("vueper-slide",{staticClass:"vueperslides__slide--clone",style:e.clones[0].style,attrs:{clone:0,title:e.clones[0].title,content:e.clones[0].content,image:e.clones[0].image}}):e._e(),e._t("default",null,{currentSlide:e.currentSlide}),e.slidesCount&&e.clones[1]?s("vueper-slide",{staticClass:"vueperslides__slide--clone",style:e.clones[1].style,attrs:{clone:1,title:e.clones[1].title,content:e.clones[1].content,image:e.clones[1].image}}):e._e()],2)]),e.$slots.pausedIcon?s("div",{staticClass:"vueperslides__paused"},[e._t("pausedIcon")],2):e._e(),e.conf.arrows&&e.slidesCount>1&&!e.disable?s("div",{staticClass:"vueperslides__arrows"},[s("button",{directives:[{name:"show",rawName:"v-show",value:!e.arrowPrevDisabled,expression:"!arrowPrevDisabled"}],staticClass:"vueperslides__arrow vueperslides__arrow--prev",on:{click:function(t){e.onArrowClick(!1)}}},[e._t("arrowLeft",[s("svg",{attrs:{viewBox:"0 0 24 24"}},[s("path",{attrs:{d:"M16.2,21c0.3,0,0.5-0.1,0.7-0.3c0.4-0.4,0.4-1,0-1.4L9.6,12L17,4.7c0.4-0.4,0.4-1,0-1.4c-0.4-0.4-1-0.4-1.4,0L6.8,12l8.8,8.7C15.7,20.9,16,21,16.2,21z"}})])])],2),s("button",{directives:[{name:"show",rawName:"v-show",value:!e.arrowNextDisabled,expression:"!arrowNextDisabled"}],staticClass:"vueperslides__arrow vueperslides__arrow--next",on:{click:function(t){e.onArrowClick()}}},[e._t("arrowRight",[s("svg",{attrs:{viewBox:"0 0 24 24"}},[s("path",{attrs:{d:"M7.8,21c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l7.4-7.3L7,4.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l8.8,8.7l-8.8,8.7C8.3,20.9,8,21,7.8,21z"}})])])],2)]):e._e(),e.conf.bullets&&e.slidesCount>1&&!e.disable?s("div",{staticClass:"vueperslides__bullets",class:{"vueperslides__bullets--outside":e.conf.bulletsOutside}},e._l(e.slides,function(t,i){return s("button",{key:i,ref:"bullet",refInFor:!0,staticClass:"vueperslides__bullet",class:{"vueperslides__bullet--active":e.currentSlide===i},on:{click:function(t){e.goToSlide(i)},keyup:[function(t){return"button"in t||!e._k(t.keyCode,"left",37,t.key,["Left","ArrowLeft"])?"button"in t&&0!==t.button?null:void e.onArrowClick(!1):null},function(t){return"button"in t||!e._k(t.keyCode,"right",39,t.key,["Right","ArrowRight"])?"button"in t&&2!==t.button?null:void e.onArrowClick():null}]}},[s("span",[e._v(e._s(i+1))])])})):e._e()])])},staticRenderFns:[],name:"vueper-slides",components:{VueperSlide:t},props:{initSlide:{type:Number,default:1},slideRatio:{type:Number,default:1/3},arrows:{type:Boolean,default:!0},disableArrowsOnEdges:{type:[Boolean,String],default:!1},bullets:{type:Boolean,default:!0},bulletsOutside:{type:Boolean,default:!1},fade:{type:Boolean,default:!1},slideContentOutside:{type:Boolean,default:!1},slideContentOutsideClass:{type:String,default:""},autoplay:{type:Boolean,default:!1},speed:{type:[Number,String],default:4e3},pauseOnHover:{type:Boolean,default:!0},infinite:{type:Boolean,default:!0},touchable:{type:Boolean,default:!0},disable:{type:Boolean,default:!1},breakpoints:{type:Object,default:function(){return{}}}},data:function(){return{isReady:!1,slides:[],slidesCount:0,activeSlideUid:null,mouseDown:!1,mouseOver:!1,dragging:!1,currentSlide:0,currentTranslation:0,dragStartX:0,dragStartY:0,goNext:!0,timer:null,arrowPrevDisabled:!1,arrowNextDisabled:!1,touchEnabled:!0,clones:[],breakpointsList:[],currentBreakpoint:null,conf:null}},created:function(){this.conf=Object.assign({},this.$props),delete this.conf.breakpoints},mounted:function(){this.init()},methods:{init:function(){this.emit("before-init",!1),this.slidesCount=this.slides.length,Object.keys(this.breakpoints).length&&(this.setBreakpointsList(),this.setBreakpointConfig(this.getCurrentBreakpoint())),this.touchEnabled=this.conf.touchable,this.conf.infinite&&!this.conf.fade&&this.cloneSlides(),this.goToSlide(this.conf.initSlide-1),this.bindEvents(),this.isReady=!0,this.emit("ready")},emit:function(e){var t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=arguments.length>2&&void 0!==arguments[2]&&arguments[2],i=[e];if((t||"number"==typeof s)&&(i[1]={},t&&this.activeSlideUid&&(i[1].currentSlide={index:this.currentSlide,title:this.slides[this.currentSlide].title,content:this.slides[this.currentSlide].content}),"number"==typeof s)){var n=this.getSlideInRange(s).nextSlide;i[1].nextSlide={index:n,title:this.slides[n].title,content:this.slides[n].content}}this.$emit.apply(this,[e].concat(i))},setBreakpointsList:function(){this.breakpointsList=[99999].concat(s(Object.keys(this.breakpoints))).sort(function(e,t){return parseInt(e)<parseInt(t)})},getCurrentBreakpoint:function(){var e=window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,t=[e].concat(s(this.breakpointsList)).sort(function(e,t){return parseInt(e)<parseInt(t)});return this.breakpointsList[t.indexOf(e)-1]},hasBreakpointChanged:function(e){return this.currentBreakpoint!==e},setBreakpointConfig:function(e){this.currentBreakpoint=e,this.conf=Object.assign({},this.$props,this.$props.breakpoints[e]||{}),this.clones.length&&this.conf.slideRatio&&(this.clones[0].style["padding-bottom"]=100*this.conf.slideRatio+"%",this.clones[1].style["padding-bottom"]=100*this.conf.slideRatio+"%")},cloneSlides:function(){var e=this.$slots.default[0].tag,t=this.$slots.default[e?0:1].elm,s=this.$slots.default[this.$slots.default.length-1].elm;this.clones[0]={title:this.slides[this.slidesCount-1].title,content:this.slides[this.slidesCount-1].content,image:this.slides[this.slidesCount-1].image,style:{cssText:s&&s.attributes.style?s.attributes.style.value:null}},this.clones[1]={title:this.slides[0].title,content:this.slides[0].content,image:this.slides[0].image,style:{cssText:t&&s.attributes.style?t.attributes.style.value:null}}},bindEvents:function(){var e="ontouchstart"in window;this.touchEnabled&&(this.$refs.track.addEventListener(e?"touchstart":"mousedown",this.onMouseDown),document.addEventListener(e?"touchmove":"mousemove",this.onMouseMove),document.addEventListener(e?"touchend":"mouseup",this.onMouseUp)),this.conf.pauseOnHover&&!e&&this.conf.autoplay&&(this.$refs.vueperslides.addEventListener("mouseover",this.onMouseIn),this.$refs.vueperslides.addEventListener("mouseout",this.onMouseOut)),this.breakpointsList.length&&window.addEventListener("resize",this.onResize)},getDragPercentage:function(e){this.dragStartX="ontouchstart"in window?e.touches[0].clientX:e.clientX;var t=this.$refs.vueperslides.offsetParent;return(this.dragStartX-t.offsetLeft)/t.clientWidth},onResize:function(){var e=this.getCurrentBreakpoint();this.hasBreakpointChanged(e)&&this.setBreakpointConfig(e)},onMouseIn:function(){this.mouseOver=!0,this.conf.pauseOnHover&&this.conf.autoplay&&this.clearTimer()},onMouseOut:function(){this.mouseOver=!1,this.conf.pauseOnHover&&this.conf.autoplay&&this.setTimer()},onMouseDown:function(e){if(this.touchEnabled&&!this.disable){e.touches||e.preventDefault(),this.mouseDown=!0;var t=this.getDragPercentage(e);this.goNext=t>=.5,this.currentTranslation=-100*(this.currentSlide+(this.goNext?1:0)+(this.clones.length?1:0)-t)}},onMouseMove:function(e){if(this.mouseDown||this.dragging){this.mouseDown=!1,this.dragging=!0;var t=this.getDragPercentage(e);this.currentTranslation=-100*(this.currentSlide+(this.goNext?1:0)+(this.clones.length?1:0)-t)}},onMouseUp:function(){if(this.mouseDown||this.dragging){this.mouseDown=!1,this.dragging=!1;var e=-(Math.round(this.currentTranslation/100)+(this.clones.length?1:0)),t=this.getSlideInRange(e).nextSlide;this.arrowNextDisabled&&this.conf.autoplay&&0===t&&(t=this.slidesCount-1),t!==this.currentSlide?this.goToSlide(e):this.currentTranslation=100*-(this.currentSlide+(this.clones.length?1:0)),this.enableScroll()}},disableScroll:function(){document.ontouchmove=function(e){e.preventDefault()}},enableScroll:function(){document.ontouchmove=function(){return!0}},clearTimer:function(){clearTimeout(this.timer),this.timer=0},setTimer:function(){var e=this;this.timer=setTimeout(function(){e.goToSlide(e.currentSlide+1,!0,!0)},this.conf.speed)},onArrowClick:function(){var e=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.goToSlide(this.currentSlide+(e?1:-1))},getSlideInRange:function(e){var t=null;return this.clones.length?e<0?(e=this.slidesCount-1,t=0):e>this.slidesCount-1&&(e=0,t=1):e<0?e=this.conf.disableArrowsOnEdges?0:this.slidesCount-1:e>this.slidesCount-1&&(e=this.conf.disableArrowsOnEdges?this.conf.autoplay?0:this.slidesCount-1:0),{nextSlide:e,clone:t}},goToSlide:function(e){var t=this,s=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(this.slidesCount&&!this.disable){this.conf.autoplay&&this.clearTimer();var n=this.getSlideInRange(e),o=n.nextSlide,l=n.clone;this.isReady&&this.emit("before-slide",!0,o),this.conf.arrows&&this.conf.disableArrowsOnEdges&&(this.arrowPrevDisabled=0===o,this.arrowNextDisabled=o===this.slidesCount-1),this.$refs.track.classList[s?"remove":"add"]("vueperslides__track--no-animation"),null!==l&&setTimeout(function(){t.goToSlide(l?0:t.slidesCount-1,!1,i)},400),this.currentSlide=o,this.conf.fade||(this.currentTranslation=null!==l?-100*(l?this.slidesCount+1:0):-100*(this.currentSlide+(this.clones.length?1:0))),this.activeSlideUid=this.slides[this.currentSlide]._uid,this.conf.autoplay&&!this.mouseOver&&this.setTimer(),this.slidesCount&&(this.$slots.default[this.currentSlide]&&this.isReady&&this.emit("slide"),this.isReady&&!i&&this.$refs.bullet[this.currentSlide]&&this.$refs.bullet[this.currentSlide].focus())}},addSlide:function(e){var t=this,s=this.conf.infinite&&!this.conf.fade&&this.isReady&&!e.clone;null!==e.clone?this.clones[e.clone]=e:(this.slides.push(e),this.slidesCount=this.slides.length),this.slidesCount>1&&(this.touchEnabled=!0),s&&this.$nextTick(function(){return t.cloneSlides()})},removeSlide:function(e){var t=this,s=!1;this.slides.some(function(i,n){if(i._uid===e)return t.slides.splice(n,1),t.slidesCount=t.slides.length,e===t.activeSlideUid&&(t.activeSlideUid=null,t.goToSlide(n-1,!0,!0)),t.slidesCount<=1&&(t.touchEnabled=!1),t.clones.length&&t.isReady&&!i.clone&&(s=!0),!0}),this.slidesCount&&s&&this.cloneSlides()}}};"undefined"!=typeof window&&window.Vue&&(window.Vue.component("vueper-slides",i),window.Vue.component("vueper-slide",t)),e.VueperSlides=i,e.VueperSlide=t,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t(e.VueperSlides=e.VueperSlides||{})}(this,function(e){"use strict";!function(){if("undefined"!=typeof document){var e=document.head||document.getElementsByTagName("head")[0],t=document.createElement("style");t.type="text/css",t.styleSheet?t.styleSheet.cssText="":t.appendChild(document.createTextNode("")),e.appendChild(t)}}();var t={render:function(){var e=this,t=e.$createElement,s=e._self._c||t;return s("div",{class:{vueperslides__slide:!0,"vueperslides__slide--active":e.$parent.slides.activeUid===e._uid},style:e.styles},[e.$parent.conf.slideContentOutside||!e.title&&!e.content?e._e():s("div",{staticClass:"vueperslides__slide-content"},[s("p",{staticClass:"slide-title",domProps:{innerHTML:e._s(e.title)}}),s("p",{staticClass:"slide-content",domProps:{innerHTML:e._s(e.content)}})])])},staticRenderFns:[],props:{clone:{type:Number,default:null},image:{type:String,default:""},title:{type:String,default:""},content:{type:String,default:""}},created:function(){this.$parent.addSlide({_uid:this._uid,image:this.image,title:this.title,content:this.content,clone:this.clone})},destroyed:function(){null===this.clone&&this.$parent.removeSlide(this._uid)},computed:{styles:function(){var e={};return this.image&&(e.backgroundImage="url("+this.image+")"),this.$parent.conf.slideRatio&&(e.paddingBottom=100*this.$parent.conf.slideRatio+"%"),e}}},s=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var s=arguments[t];for(var i in s)Object.prototype.hasOwnProperty.call(s,i)&&(e[i]=s[i])}return e};function i(e){if(Array.isArray(e)){for(var t=0,s=Array(e.length);t<e.length;t++)s[t]=e[t];return s}return Array.from(e)}!function(){if("undefined"!=typeof document){var e=document.head||document.getElementsByTagName("head")[0],t=document.createElement("style"),s='.vueperslides { position: relative; } .vueperslides-wrapper { position: relative; } .vueperslides__slides-wrapper { position: relative; overflow: hidden; border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; z-index: 1; } .vueperslides__slides-wrapper::before, .vueperslides__slides-wrapper::after { content: ""; position: absolute; bottom: 100%; left: -1em; right: -1em; height: 2em; box-shadow: 0 0 20px rgba(0, 0, 0, 0.25); z-index: 2; } .vueperslides__slides-wrapper::after { top: 100%; bottom: auto; } .vueperslides--fade .vueperslides__track { white-space: normal; transition: none; } .vueperslides--touchable .vueperslides__track { cursor: ew-resize; cursor: -webkit-grab; } .vueperslides--touchable .vueperslides__track--mousedown, .vueperslides--touchable .vueperslides__track--dragging { cursor: -webkit-grabbing; } .vueperslides__track { white-space: nowrap; transition: 0.5s ease-in-out transform; } .vueperslides__track--mousedown { transition: 0.2s ease-in-out transform; } .vueperslides__track--dragging { transition: none; } .vueperslides__track--no-animation { transition-duration: 0s; } .vueperslides__slide { white-space: normal; padding-bottom: 34%; background-position: top; background-size: cover; display: inline-block; width: 100%; height: 0; margin-bottom: -8px; } .vueperslides__slide-content { user-select: none; } .vueperslides__slide-content--outside { user-select: initial; } .vueperslides--fade .vueperslides__slide { position: absolute; top: 0; left: 0; right: 0; bottom: 0; opacity: 0; transition: .8s ease-in-out opacity; } .vueperslides--fade .vueperslides__slide--active { z-index: 1; opacity: 1; } .vueperslides__arrow { position: absolute; top: 50%; background-color: transparent; border: none; color: #fff; fill: currentColor; font-size: 3em; width: 1em; text-align: center; transform: translateY(-50%); opacity: 0.7; z-index: 10; transition: 0.3s ease-in-out; cursor: pointer; user-select: none; outline: none; z-index: 2; } .vueperslides__arrow--prev { left: 10px; } .vueperslides__arrow--next { right: 10px; } .vueperslides__arrow:hover { opacity: 1; } .vueperslides__paused { position: absolute; top: 3%; right: 3%; opacity: 0; transition: 0.3s ease-in-out; text-shadow: 0 0 3px rgba(0, 0, 0, 0.4); z-index: 1; } .vueperslides:hover .vueperslides__paused { opacity: 1; } .vueperslides__bullets { display: flex; justify-content: center; position: absolute; bottom: 0; left: 0; right: 0; } .vueperslides__bullets--outside { position: relative; } .vueperslides__bullet { width: 12px; height: 12px; border-radius: 12px; border: 1px solid #fff; background-color: transparent; box-shadow: 0 0 1px rgba(0, 0, 0, 0.5), 0 0 3px rgba(0, 0, 0, 0.3); margin: 1.5em 0.6em; padding: 0; display: inline-block; cursor: pointer; user-select: none; outline: none; z-index: 2; display: flex; justify-content: center; align-items: center; } .vueperslides__bullet--active { background-color: #fff; } .vueperslides__bullet span { display: none; } @media screen and (max-width: 1000px) { .vueperslides__slide { padding-bottom: 45%; } .vueperslides--fade .vueperslides__track { padding-bottom: 45%; } } @media screen and (max-width: 700px) { .vueperslides__slide { padding-bottom: 54%; } .vueperslides--fade .vueperslides__track { padding-bottom: 54%; } } @media screen and (max-width: 400px) { .vueperslides__slide { padding-bottom: 60%; } .vueperslides--fade .vueperslides__track { padding-bottom: 60%; } } ';t.type="text/css",t.styleSheet?t.styleSheet.cssText=s:t.appendChild(document.createTextNode(s)),e.appendChild(t)}}();var n={render:function(){var e=this,t=e.$createElement,s=e._self._c||t;return s("div",{staticClass:"vueperslides-wrapper",class:{ready:e.isReady}},[e.conf.slideContentOutside?s("div",{staticClass:"vueperslides__slide-content vueperslides__slide-content--outside",class:e.conf.slideContentOutsideClass},[e.slides.count&&e.slides.list[e.slides.current].title?s("p",{staticClass:"slide-title",domProps:{innerHTML:e._s(e.slides.list[e.slides.current].title)}}):e._e(),e.slides.count&&e.slides.list[e.slides.current].content?s("p",{staticClass:"slide-content",domProps:{innerHTML:e._s(e.slides.list[e.slides.current].content)}}):e._e()]):e._e(),s("div",{ref:"vueperslides",staticClass:"vueperslides",class:{"vueperslides--fade":e.conf.fade,"vueperslides--touchable":e.touch.enabled&&!e.disable}},[s("div",{staticClass:"vueperslides__slides-wrapper"},[s("div",{ref:"track",staticClass:"vueperslides__track",class:{"vueperslides__track--dragging":e.touch.dragging,"vueperslides__track--mousedown":e.mouseDown},style:e.conf.fade?"padding-bottom: "+100*e.conf.slideRatio+"%":"transform: translate3d("+e.currentTranslation+"%, 0, 0)"},[e.slides.count&&e.clones[0]?s("vueper-slide",{staticClass:"vueperslides__slide--clone",style:e.clones[0].style,attrs:{clone:0,title:e.clones[0].title,content:e.clones[0].content,image:e.clones[0].image}}):e._e(),e._t("default",null,{currentSlide:e.slides.current}),e.slides.count&&e.clones[1]?s("vueper-slide",{staticClass:"vueperslides__slide--clone",style:e.clones[1].style,attrs:{clone:1,title:e.clones[1].title,content:e.clones[1].content,image:e.clones[1].image}}):e._e()],2)]),e.$slots.pausedIcon?s("div",{staticClass:"vueperslides__paused"},[e._t("pausedIcon")],2):e._e(),e.conf.arrows&&e.slides.count>1&&!e.disable?s("div",{staticClass:"vueperslides__arrows"},[s("button",{directives:[{name:"show",rawName:"v-show",value:!e.arrowPrevDisabled,expression:"!arrowPrevDisabled"}],staticClass:"vueperslides__arrow vueperslides__arrow--prev",on:{click:function(t){e.onArrowClick(!1)}}},[e._t("arrowLeft",[s("svg",{attrs:{viewBox:"0 0 24 24"}},[s("path",{attrs:{d:"M16.2,21c0.3,0,0.5-0.1,0.7-0.3c0.4-0.4,0.4-1,0-1.4L9.6,12L17,4.7c0.4-0.4,0.4-1,0-1.4c-0.4-0.4-1-0.4-1.4,0L6.8,12l8.8,8.7C15.7,20.9,16,21,16.2,21z"}})])])],2),s("button",{directives:[{name:"show",rawName:"v-show",value:!e.arrowNextDisabled,expression:"!arrowNextDisabled"}],staticClass:"vueperslides__arrow vueperslides__arrow--next",on:{click:function(t){e.onArrowClick()}}},[e._t("arrowRight",[s("svg",{attrs:{viewBox:"0 0 24 24"}},[s("path",{attrs:{d:"M7.8,21c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l7.4-7.3L7,4.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l8.8,8.7l-8.8,8.7C8.3,20.9,8,21,7.8,21z"}})])])],2)]):e._e(),e.conf.bullets&&e.slides.count>1&&!e.disable?s("div",{staticClass:"vueperslides__bullets",class:{"vueperslides__bullets--outside":e.conf.bulletsOutside}},e._l(e.slides.list,function(t,i){return s("button",{key:i,ref:"bullet",refInFor:!0,staticClass:"vueperslides__bullet",class:{"vueperslides__bullet--active":e.slides.current===i},on:{click:function(t){e.goToSlide(i)},keyup:[function(t){return"button"in t||!e._k(t.keyCode,"left",37,t.key,["Left","ArrowLeft"])?"button"in t&&0!==t.button?null:void e.onArrowClick(!1):null},function(t){return"button"in t||!e._k(t.keyCode,"right",39,t.key,["Right","ArrowRight"])?"button"in t&&2!==t.button?null:void e.onArrowClick():null}]}},[s("span",[e._v(e._s(i+1))])])})):e._e()])])},staticRenderFns:[],name:"vueper-slides",components:{VueperSlide:t},props:{initSlide:{type:Number,default:1},slideRatio:{type:Number,default:1/3},arrows:{type:Boolean,default:!0},disableArrowsOnEdges:{type:[Boolean,String],default:!1},bullets:{type:Boolean,default:!0},bulletsOutside:{type:Boolean,default:!1},fade:{type:Boolean,default:!1},slideContentOutside:{type:Boolean,default:!1},slideContentOutsideClass:{type:String,default:""},autoplay:{type:Boolean,default:!1},speed:{type:[Number,String],default:4e3},pauseOnHover:{type:Boolean,default:!0},infinite:{type:Boolean,default:!0},touchable:{type:Boolean,default:!0},draggingDistance:{type:[Number],default:null},disable:{type:Boolean,default:!1},breakpoints:{type:Object,default:function(){return{}}}},data:function(){return{isReady:!1,slides:{list:[],count:0,activeUid:null,current:0,clones:[]},clones:[],mouseDown:!1,mouseOver:!1,touch:{enabled:!0,dragging:!1,dragStartX:0,dragAmount:0,goNext:!0},currentTranslation:0,timer:null,arrowPrevDisabled:!1,arrowNextDisabled:!1,breakpointsData:{list:[],current:null},conf:null}},created:function(){this.conf=s({},this.$props),delete this.conf.breakpoints},mounted:function(){this.init()},methods:{init:function(){this.emit("before-init",!1),this.slides.count=this.slides.list.length,Object.keys(this.breakpoints).length&&(this.setBreakpointsList(),this.setBreakpointConfig(this.getCurrentBreakpoint())),this.touch.enabled=this.conf.touchable,this.conf.infinite&&!this.conf.fade&&this.cloneSlides(),this.goToSlide(this.conf.initSlide-1),this.bindEvents(),this.isReady=!0,this.emit("ready")},emit:function(e){var t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],s=arguments.length>2&&void 0!==arguments[2]&&arguments[2],i=[e];if((t||"number"==typeof s)&&(i[1]={},t&&this.slides.activeUid&&(i[1].currentSlide={index:this.slides.current,title:this.slides.list[this.slides.current].title,content:this.slides.list[this.slides.current].content}),"number"==typeof s)){var n=this.getSlideInRange(s).nextSlide;i[1].nextSlide={index:n,title:this.slides.list[n].title,content:this.slides.list[n].content}}this.$emit.apply(this,[e].concat(i))},setBreakpointsList:function(){this.breakpointsData.list=[99999].concat(i(Object.keys(this.breakpoints))).sort(function(e,t){return parseInt(e)<parseInt(t)})},getCurrentBreakpoint:function(){var e=window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,t=[e].concat(i(this.breakpointsData.list)).sort(function(e,t){return parseInt(e)<parseInt(t)});return this.breakpointsData.list[t.indexOf(e)-1]},hasBreakpointChanged:function(e){return this.breakpointsData.current!==e},setBreakpointConfig:function(e){this.breakpointsData.current=e,this.conf=s({},this.$props,this.$props.breakpoints[e]||{}),this.clones.length&&this.conf.slideRatio&&(this.clones[0].style["padding-bottom"]=100*this.conf.slideRatio+"%",this.clones[1].style["padding-bottom"]=100*this.conf.slideRatio+"%")},cloneSlides:function(){var e=this.$slots.default[0].tag,t=this.$slots.default[e?0:1].elm,s=this.$slots.default[this.$slots.default.length-1].elm;this.clones[0]={title:this.slides.list[this.slides.count-1].title,content:this.slides.list[this.slides.count-1].content,image:this.slides.list[this.slides.count-1].image,style:{cssText:s&&s.attributes.style?s.attributes.style.value:null}},this.clones[1]={title:this.slides.list[0].title,content:this.slides.list[0].content,image:this.slides.list[0].image,style:{cssText:t&&s.attributes.style?t.attributes.style.value:null}}},bindEvents:function(){var e="ontouchstart"in window;this.touch.enabled&&(this.$refs.track.addEventListener(e?"touchstart":"mousedown",this.onMouseDown),document.addEventListener(e?"touchmove":"mousemove",this.onMouseMove),document.addEventListener(e?"touchend":"mouseup",this.onMouseUp)),this.conf.pauseOnHover&&!e&&this.conf.autoplay&&(this.$refs.vueperslides.addEventListener("mouseover",this.onMouseIn),this.$refs.vueperslides.addEventListener("mouseout",this.onMouseOut)),this.breakpointsData.list.length&&window.addEventListener("resize",this.onResize)},onResize:function(){var e=this.getCurrentBreakpoint();this.hasBreakpointChanged(e)&&this.setBreakpointConfig(e)},onMouseIn:function(){this.mouseOver=!0,this.conf.pauseOnHover&&this.conf.autoplay&&this.clearTimer()},onMouseOut:function(){this.mouseOver=!1,this.conf.pauseOnHover&&this.conf.autoplay&&this.setTimer()},onMouseDown:function(e){if(this.touch.enabled&&!this.disable)if(e.touches||e.preventDefault(),this.mouseDown=!0,this.draggingDistance)this.touch.dragStartX="ontouchstart"in window?e.touches[0].clientX:e.clientX;else{var t=this.getDragPercentage(e);this.touch.goNext=t>=.5,this.currentTranslation=-100*(this.slides.current+(this.touch.goNext?1:0)+(this.clones.length?1:0)-t)}},onMouseMove:function(e){if(this.mouseDown||this.touch.dragging)if(this.mouseDown=!1,this.touch.dragging=!0,this.draggingDistance){this.touch.dragAmount=this.getDragAmount(e);var t=this.touch.dragAmount/this.$refs.vueperslides.offsetParent.clientWidth;this.currentTranslation=-100*(this.slides.current+(this.clones.length?1:0)-t)}else{var s=this.getDragPercentage(e);this.currentTranslation=-100*(this.slides.current+(this.touch.goNext?1:0)+(this.clones.length?1:0)-s)}},onMouseUp:function(e){if(this.mouseDown||this.touch.dragging){this.mouseDown=!1,this.touch.dragging=!1;var t=void 0;if(this.draggingDistance){var s=this.touch.dragAmount;this.$refs.vueperslides.offsetParent.clientWidth;t=this.slides.current,Math.abs(s)>=this.draggingDistance&&(t+=s>0?-1:1)}else t=-(Math.round(this.currentTranslation/100)+(this.clones.length?1:0));var i=this.getSlideInRange(t).nextSlide;this.arrowNextDisabled&&this.conf.autoplay&&0===i&&(i=this.slides.count-1),i!==this.slides.current?this.goToSlide(t):this.currentTranslation=100*-(this.slides.current+(this.clones.length?1:0)),this.touch.dragStartX=null,this.touch.dragAmount=null,this.enableScroll()}},getDragPercentage:function(e){var t="ontouchstart"in window?e.touches[0].clientX:e.clientX,s=this.$refs.vueperslides.offsetParent;return(t-s.offsetLeft)/s.clientWidth},getDragAmount:function(e){return("ontouchstart"in window?e.touches[0].clientX:e.clientX)-this.touch.dragStartX},disableScroll:function(){document.ontouchmove=function(e){e.preventDefault()}},enableScroll:function(){document.ontouchmove=function(){return!0}},clearTimer:function(){clearTimeout(this.timer),this.timer=0},setTimer:function(){var e=this;this.timer=setTimeout(function(){e.goToSlide(e.slides.current+1,!0,!0)},this.conf.speed)},onArrowClick:function(){var e=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.goToSlide(this.slides.current+(e?1:-1))},getSlideInRange:function(e){var t=null;return this.clones.length?e<0?(e=this.slides.count-1,t=0):e>this.slides.count-1&&(e=0,t=1):e<0?e=this.conf.disableArrowsOnEdges?0:this.slides.count-1:e>this.slides.count-1&&(e=this.conf.disableArrowsOnEdges?this.conf.autoplay?0:this.slides.count-1:0),{nextSlide:e,clone:t}},goToSlide:function(e){var t=this,s=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(this.slides.count&&!this.disable){this.conf.autoplay&&this.clearTimer();var n=this.getSlideInRange(e),o=n.nextSlide,l=n.clone;this.isReady&&this.emit("before-slide",!0,o),this.conf.arrows&&this.conf.disableArrowsOnEdges&&(this.arrowPrevDisabled=0===o,this.arrowNextDisabled=o===this.slides.count-1),this.$refs.track.classList[s?"remove":"add"]("vueperslides__track--no-animation"),null!==l&&setTimeout(function(){t.goToSlide(l?0:t.slides.count-1,!1,i)},400),this.slides.current=o,this.conf.fade||(this.currentTranslation=null!==l?-100*(l?this.slides.count+1:0):-100*(this.slides.current+(this.clones.length?1:0))),this.slides.activeUid=this.slides.list[this.slides.current]._uid,this.conf.autoplay&&!this.mouseOver&&this.setTimer(),this.slides.count&&(this.$slots.default[this.slides.current]&&this.isReady&&this.emit("slide"),this.isReady&&!i&&this.$refs.bullet[this.slides.current]&&this.$refs.bullet[this.slides.current].focus())}},addSlide:function(e){var t=this,s=this.conf.infinite&&!this.conf.fade&&this.isReady&&!e.clone;null!==e.clone?this.clones[e.clone]=e:(this.slides.list.push(e),this.slides.count=this.slides.list.length),this.slides.count>1&&(this.touch.enabled=!0),s&&this.$nextTick(function(){return t.cloneSlides()})},removeSlide:function(e){var t=this,s=!1;this.slides.list.some(function(i,n){if(i._uid===e)return t.slides.list.splice(n,1),t.slides.count=t.slides.list.length,e===t.slides.activeUid&&(t.slides.activeUid=null,t.goToSlide(n-1,!0,!0)),t.slides.count<=1&&(t.touch.enabled=!1),t.clones.length&&t.isReady&&!i.clone&&(s=!0),!0}),this.slides.count&&s&&this.cloneSlides()}}};"undefined"!=typeof window&&window.Vue&&(window.Vue.component("vueper-slides",n),window.Vue.component("vueper-slide",t)),e.VueperSlides=n,e.VueperSlide=t,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=vueperslides.min.js.map
{
"name": "vueperslides",
"version": "1.1.0",
"version": "1.2.0",
"description": "A touch ready & responsive slideshow for Vue JS.",

@@ -29,2 +29,4 @@ "repository": "https://github.com/antoniandre/vueper-slides",

"babel-core": "^6.26.0",
"babel-plugin-transform-es2015-destructuring": "^6.23.0",
"babel-plugin-transform-object-rest-spread": "^6.26.0",
"babel-preset-env": "^1.6.1",

@@ -31,0 +33,0 @@ "eslint": "^3.17.1",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc