UNPKG

ant-design-vue

Version:

An enterprise-class UI design language and Vue-based implementation

262 lines (221 loc) 9.26 kB
import { resolveDirective as _resolveDirective, createVNode as _createVNode, isVNode as _isVNode } from "vue"; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _extends() { _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; }; return _extends.apply(this, arguments); } import json2mq from '../../_util/json2mq'; import BaseMixin from '../../_util/BaseMixin'; import { cloneElement } from '../../_util/vnode'; import InnerSlider from './inner-slider'; import defaultProps from './default-props'; import { canUseDOM } from './utils/innerSliderUtils'; import { getSlot } from '../../_util/props-util'; import { defineComponent } from 'vue'; function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !_isVNode(s); } export default defineComponent({ name: 'Slider', mixins: [BaseMixin], inheritAttrs: false, props: _extends({}, defaultProps), data: function data() { this._responsiveMediaHandlers = []; return { breakpoint: null }; }, // handles responsive breakpoints beforeMount: function beforeMount() { var _this = this; if (this.responsive) { var breakpoints = this.responsive.map(function (breakpt) { return breakpt.breakpoint; }); // sort them in increasing order of their numerical value breakpoints.sort(function (x, y) { return x - y; }); breakpoints.forEach(function (breakpoint, index) { // media query for each breakpoint var bQuery; if (index === 0) { bQuery = json2mq({ minWidth: 0, maxWidth: breakpoint }); } else { bQuery = json2mq({ minWidth: breakpoints[index - 1] + 1, maxWidth: breakpoint }); } // when not using server side rendering canUseDOM() && _this.media(bQuery, function () { _this.setState({ breakpoint: breakpoint }); }); }); // Register media query for full screen. Need to support resize from small to large // convert javascript object to media query string var query = json2mq({ minWidth: breakpoints.slice(-1)[0] }); canUseDOM() && this.media(query, function () { _this.setState({ breakpoint: null }); }); } }, beforeUnmount: function beforeUnmount() { this._responsiveMediaHandlers.forEach(function (obj) { obj.mql.removeListener(obj.listener); }); }, methods: { innerSliderRefHandler: function innerSliderRefHandler(ref) { this.innerSlider = ref; }, media: function media(query, handler) { // javascript handler for css media query var mql = window.matchMedia(query); var listener = function listener(_ref) { var matches = _ref.matches; if (matches) { handler(); } }; mql.addListener(listener); listener(mql); this._responsiveMediaHandlers.push({ mql: mql, query: query, listener: listener }); }, slickPrev: function slickPrev() { this.innerSlider.slickPrev(); }, slickNext: function slickNext() { this.innerSlider.slickNext(); }, slickGoTo: function slickGoTo(slide) { var dontAnimate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; this.innerSlider.slickGoTo(slide, dontAnimate); }, slickPause: function slickPause() { this.innerSlider.pause('paused'); }, slickPlay: function slickPlay() { this.innerSlider.handleAutoPlay('play'); } }, render: function render() { var _this2 = this; var settings; var newProps; if (this.breakpoint) { newProps = this.responsive.filter(function (resp) { return resp.breakpoint === _this2.breakpoint; }); settings = newProps[0].settings === 'unslick' ? 'unslick' : _extends(_extends({}, this.$props), newProps[0].settings); } else { settings = _extends({}, 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 ".concat(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 ".concat(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 ".concat(settings.slidesToScroll)); } settings.slidesToShow = 1; settings.slidesToScroll = 1; } // makes sure that children is an array, even when there is only 1 child var children = 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(function (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; } var newChildren = []; var currentWidth = null; for (var i = 0; i < children.length; i += settings.rows * settings.slidesPerRow) { var newSlide = []; for (var j = i; j < i + settings.rows * settings.slidesPerRow; j += settings.slidesPerRow) { var row = []; for (var k = j; k < j + settings.slidesPerRow; k += 1) { if (settings.variableWidth && children[k].props.style) { currentWidth = children[k].props.style.width; } if (k >= children.length) break; row.push(cloneElement(children[k], { key: 100 * i + 10 * j + k, tabindex: -1, style: { width: "".concat(100 / settings.slidesPerRow, "%"), display: 'inline-block' } })); } newSlide.push(_createVNode("div", { "key": 10 * i + j }, _isSlot(row) ? row : { default: function _default() { return [row]; } })); } if (settings.variableWidth) { newChildren.push(_createVNode("div", { "key": i, "style": { width: currentWidth } }, _isSlot(newSlide) ? newSlide : { default: function _default() { return [newSlide]; } })); } else { newChildren.push(_createVNode("div", { "key": i }, _isSlot(newSlide) ? newSlide : { default: function _default() { return [newSlide]; } })); } } if (settings === 'unslick') { var className = 'regular slider ' + (this.className || ''); return _createVNode("div", { "class": className }, _isSlot(newChildren) ? newChildren : { default: function _default() { return [newChildren]; } }); } else if (newChildren.length <= settings.slidesToShow) { settings.unslick = true; } var sliderProps = _extends(_extends(_extends({}, this.$attrs), settings), { children: newChildren, ref: this.innerSliderRefHandler }); return _createVNode(InnerSlider, _objectSpread(_objectSpread({}, sliderProps), {}, { "__propsSymbol__": [] }), _objectSpread({}, this.$slots)); } });