| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _json2mq = _interopRequireDefault(require("../_util/json2mq"));
- var _BaseMixin = _interopRequireDefault(require("../_util/BaseMixin"));
- var _vnode = require("../_util/vnode");
- var _innerSlider = _interopRequireDefault(require("./inner-slider"));
- var _defaultProps = _interopRequireDefault(require("./default-props"));
- var _innerSliderUtils = require("./utils/innerSliderUtils");
- var _propsUtil = require("../_util/props-util");
- var _default = exports.default = (0, _vue.defineComponent)({
- name: 'Slider',
- mixins: [_BaseMixin.default],
- inheritAttrs: false,
- props: (0, _extends2.default)({}, _defaultProps.default),
- data() {
- this._responsiveMediaHandlers = [];
- return {
- breakpoint: null
- };
- },
- // handles responsive breakpoints
- mounted() {
- if (this.responsive) {
- const breakpoints = this.responsive.map(breakpt => breakpt.breakpoint);
- // sort them in increasing order of their numerical value
- breakpoints.sort((x, y) => x - y);
- breakpoints.forEach((breakpoint, index) => {
- // media query for each breakpoint
- let bQuery;
- if (index === 0) {
- bQuery = (0, _json2mq.default)({
- minWidth: 0,
- maxWidth: breakpoint
- });
- } else {
- bQuery = (0, _json2mq.default)({
- minWidth: breakpoints[index - 1] + 1,
- maxWidth: breakpoint
- });
- }
- // when not using server side rendering
- (0, _innerSliderUtils.canUseDOM)() && this.media(bQuery, () => {
- this.setState({
- breakpoint
- });
- });
- });
- // Register media query for full screen. Need to support resize from small to large
- // convert javascript object to media query string
- const query = (0, _json2mq.default)({
- minWidth: breakpoints.slice(-1)[0]
- });
- (0, _innerSliderUtils.canUseDOM)() && this.media(query, () => {
- this.setState({
- breakpoint: null
- });
- });
- }
- },
- beforeUnmount() {
- this._responsiveMediaHandlers.forEach(function (obj) {
- obj.mql.removeListener(obj.listener);
- });
- },
- methods: {
- innerSliderRefHandler(ref) {
- this.innerSlider = ref;
- },
- media(query, handler) {
- // javascript handler for css media query
- const mql = window.matchMedia(query);
- const listener = _ref => {
- let {
- matches
- } = _ref;
- if (matches) {
- handler();
- }
- };
- mql.addListener(listener);
- listener(mql);
- this._responsiveMediaHandlers.push({
- mql,
- query,
- listener
- });
- },
- slickPrev() {
- var _a;
- (_a = this.innerSlider) === null || _a === void 0 ? void 0 : _a.slickPrev();
- },
- slickNext() {
- var _a;
- (_a = this.innerSlider) === null || _a === void 0 ? void 0 : _a.slickNext();
- },
- slickGoTo(slide) {
- let dontAnimate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var _a;
- (_a = this.innerSlider) === null || _a === void 0 ? void 0 : _a.slickGoTo(slide, dontAnimate);
- },
- slickPause() {
- var _a;
- (_a = this.innerSlider) === null || _a === void 0 ? void 0 : _a.pause('paused');
- },
- slickPlay() {
- var _a;
- (_a = this.innerSlider) === null || _a === void 0 ? void 0 : _a.handleAutoPlay('play');
- }
- },
- render() {
- var _a;
- let settings;
- let newProps;
- if (this.breakpoint) {
- newProps = this.responsive.filter(resp => resp.breakpoint === this.breakpoint);
- settings = newProps[0].settings === 'unslick' ? 'unslick' : (0, _extends2.default)((0, _extends2.default)({}, this.$props), newProps[0].settings);
- } else {
- settings = (0, _extends2.default)({}, this.$props);
- }
- // force scrolling by one if centerMode is on
- if (settings.centerMode) {
- if (settings.slidesToScroll > 1 && process.env.NODE_ENV !== 'production') {
- console.warn(`slidesToScroll should be equal to 1 in centerMode, you are using ${settings.slidesToScroll}`);
- }
- settings.slidesToScroll = 1;
- }
- // force showing one slide and scrolling by one if the fade mode is on
- if (settings.fade) {
- if (settings.slidesToShow > 1 && process.env.NODE_ENV !== 'production') {
- console.warn(`slidesToShow should be equal to 1 when fade is true, you're using ${settings.slidesToShow}`);
- }
- if (settings.slidesToScroll > 1 && process.env.NODE_ENV !== 'production') {
- console.warn(`slidesToScroll should be equal to 1 when fade is true, you're using ${settings.slidesToScroll}`);
- }
- settings.slidesToShow = 1;
- settings.slidesToScroll = 1;
- }
- // makes sure that children is an array, even when there is only 1 child
- let children = (0, _propsUtil.getSlot)(this) || [];
- // Children may contain false or null, so we should filter them
- // children may also contain string filled with spaces (in certain cases where we use jsx strings)
- children = children.filter(child => {
- if (typeof child === 'string') {
- return !!child.trim();
- }
- return !!child;
- });
- // rows and slidesPerRow logic is handled here
- if (settings.variableWidth && (settings.rows > 1 || settings.slidesPerRow > 1)) {
- console.warn(`variableWidth is not supported in case of rows > 1 or slidesPerRow > 1`);
- settings.variableWidth = false;
- }
- const newChildren = [];
- let currentWidth = null;
- for (let i = 0; i < children.length; i += settings.rows * settings.slidesPerRow) {
- const newSlide = [];
- for (let j = i; j < i + settings.rows * settings.slidesPerRow; j += settings.slidesPerRow) {
- const row = [];
- for (let k = j; k < j + settings.slidesPerRow; k += 1) {
- if (settings.variableWidth && ((_a = children[k].props) === null || _a === void 0 ? void 0 : _a.style)) {
- currentWidth = children[k].props.style.width;
- }
- if (k >= children.length) break;
- row.push((0, _vnode.cloneElement)(children[k], {
- key: 100 * i + 10 * j + k,
- tabindex: -1,
- style: {
- width: `${100 / settings.slidesPerRow}%`,
- display: 'inline-block'
- }
- }));
- }
- newSlide.push((0, _vue.createVNode)("div", {
- "key": 10 * i + j
- }, [row]));
- }
- if (settings.variableWidth) {
- newChildren.push((0, _vue.createVNode)("div", {
- "key": i,
- "style": {
- width: currentWidth
- }
- }, [newSlide]));
- } else {
- newChildren.push((0, _vue.createVNode)("div", {
- "key": i
- }, [newSlide]));
- }
- }
- if (settings === 'unslick') {
- const className = 'regular slider ' + (this.className || '');
- return (0, _vue.createVNode)("div", {
- "class": className
- }, [children]);
- } else if (newChildren.length <= settings.slidesToShow) {
- settings.unslick = true;
- }
- const sliderProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, this.$attrs), settings), {
- children: newChildren,
- ref: this.innerSliderRefHandler
- });
- return (0, _vue.createVNode)(_innerSlider.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, sliderProps), {}, {
- "__propsSymbol__": []
- }), this.$slots);
- }
- });
|