{"version":3,"sources":["webpack:///./node_modules/react-responsive-carousel/lib/index.js","webpack:///./node_modules/react-responsive-carousel/node_modules/prop-types/index.js","webpack:///./node_modules/react-responsive-carousel/lib/components/Thumbs.js","webpack:///./node_modules/react-responsive-carousel/node_modules/react-easy-swipe/lib/index.js","webpack:///./node_modules/react-responsive-carousel/lib/CSSTranslate.js","webpack:///./node_modules/react-responsive-carousel/lib/cssClasses.js","webpack:///./node_modules/react-responsive-carousel/lib/customPropTypes.js","webpack:///./node_modules/react-responsive-carousel/lib/dimensions.js","webpack:///./node_modules/react-responsive-carousel/node_modules/react-easy-swipe/lib/react-swipe.js","webpack:///./node_modules/react-responsive-carousel/node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack:///./node_modules/react-responsive-carousel/node_modules/fbjs/lib/invariant.js","webpack:///./node_modules/react-responsive-carousel/node_modules/fbjs/lib/emptyFunction.js","webpack:///./node_modules/react-responsive-carousel/node_modules/prop-types/factoryWithThrowingShims.js","webpack:///./node_modules/react-responsive-carousel/lib/components/Carousel.js"],"names":["Object","defineProperty","exports","value","Thumbs","Carousel","undefined","_Carousel2","_interopRequireDefault","__webpack_require__","_Thumbs2","obj","__esModule","default","module","_createClass","defineProperties","target","props","i","length","descriptor","enumerable","configurable","writable","key","Constructor","protoProps","staticProps","prototype","_react","_react2","_propTypes2","_cssClasses2","_dimensions","_CSSTranslate2","_reactEasySwipe2","_Component","instance","TypeError","_classCallCheck","this","_this","self","call","ReferenceError","_possibleConstructorReturn","__proto__","getPrototypeOf","setItemsWrapperRef","node","itemsWrapperRef","setItemsListRef","itemsListRef","setThumbsRef","index","thumbsRef","updateSizes","children","total","wrapperSize","clientWidth","itemSize","thumbWidth","outerWidth","visibleItems","Math","floor","lastPosition","showArrows","setState","firstItem","getFirstItem","selectedItem","setMountState","hasMount","handleClickItem","item","handler","onSelectItem","onSwipeStart","swiping","onSwipeEnd","onSwipeMove","deltaX","currentPosition","state","lastLeftBoundry","position","forEach","prop","list","style","axis","slideRight","positions","moveTo","slideLeft","images","getImages","subClass","superClass","create","constructor","setPrototypeOf","_inherits","Component","nextProps","setupThumbs","prevProps","destroyThumbs","window","addEventListener","removeEventListener","Children","map","img","type","toArray","filter","image","console","warn","_this2","itemClass","ITEM","thumbProps","ref","e","className","onClick","bind","cloneElement","onLoad","createElement","itemListStyles","hasPrev","hasNext","transformProp","transitionTime","WebkitTransform","MozTransform","MsTransform","OTransform","transform","msTransform","WebkitTransitionDuration","MozTransitionDuration","MsTransitionDuration","OTransitionDuration","transitionDuration","msTransitionDuration","CAROUSEL","WRAPPER","ARROW_PREV","tagName","SLIDER","onSwipeLeft","onSwipeRight","renderItems","ARROW_NEXT","displayName","propsTypes","element","isRequired","number","defaultProps","__WEBPACK_AMD_DEFINE_FACTORY__","__WEBPACK_AMD_DEFINE_ARRAY__","__WEBPACK_AMD_DEFINE_RESULT__","_reactSwipe","_reactSwipe2","apply","join","_classnames2","isSlider","carousel","carousel-slider","thumbs-wrapper","slider-wrapper","axis-horizontal","axis-vertical","isSwiping","thumbs","slider","animated","selected","thumb","slide","disabled","control-arrow control-prev","control-disabled","control-arrow control-next","DOT","dot","unit","propName","componentName","test","Error","el","width","offsetWidth","getComputedStyle","parseInt","marginLeft","marginRight","_propTypes","setHasSupportToCaptureOption","supportsCaptureOption","hasSupport","get","getSafeEventHandlerOpts","options","arguments","capture","getPosition","event","_event$touches$","touches","pageX","pageY","x","y","screenX","screenY","ReactSwipe","_ref","_len","args","Array","_key","concat","_handleSwipeStart","_handleSwipeMove","_handleSwipeEnd","_onMouseDown","_onMouseMove","_onMouseUp","swiper","passive","allowMouseEvents","mouseDown","document","_getPosition","moveStart","_getPosition2","deltaY","moving","shouldPreventDefault","preventDefault","movePosition","tolerance","onSwipeUp","onSwipeDown","onMouseDown","onTouchStart","onTouchEnd","propTypes","string","object","bool","func","validateFormat","format","condition","a","b","c","d","f","error","argIndex","replace","name","framesToPop","makeEmptyFunction","arg","emptyFunction","thatReturns","thatReturnsFalse","thatReturnsTrue","thatReturnsNull","thatReturnsThis","thatReturnsArgument","invariant","ReactPropTypesSecret","shim","location","propFullName","secret","getShim","ReactPropTypes","array","symbol","any","arrayOf","instanceOf","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","_extends","assign","source","hasOwnProperty","_reactDom2","customPropTypes","newObj","_interopRequireWildcard","noop","setCarouselWrapperRef","carouselWrapperRef","setListRef","listRef","setItemsRef","itemsRef","autoPlay","count","clearTimeout","timer","setTimeout","increment","interval","clearAutoPlay","resetAutoPlay","stopOnHover","isMouseEntered","startOnLeave","navigateWithKeyboard","isHorizontal","prevKey","keyCode","decrement","initialized","clientHeight","cancelClick","onClickItem","handleOnChange","onChange","handleClickThumb","onClickThumb","selectItem","resetPosition","delta","finalBoundry","axisDelta","handledDelta","setPosition","hasMoved","abs","swipeScrollTolerance","findDOMNode","infiniteLoop","changeItem","newIndex","getInitialImage","getElementsByTagName","getVariableImageHeight","complete","onImageLoad","forceUpdate","height","setupCarousel","setupAutoPlay","destroyAutoPlay","destroyCarousel","bindEvents","initialImage","unbindEvents","carouselWrapper","useKeyboardArrows","centerMode","centerSlidePercentage","slideProps","minWidth","_this3","showIndicators","showStatus","statusFormatter","showThumbs","itemsLength","canShowArrows","swiperProps","containerStyles","dynamicHeight","itemHeight","verticalSwipe","swipeable","emulateTouch","renderControls","renderStatus","renderThumbs","current"],"mappings":"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","file":"vendors~BlogCarouselRender~FoodCarouselRender~HeroCarouselRender~HistoryCarouselRender~QuoteCarousel~0245cadf-f8f256e651ae08681398.js","sourcesContent":["'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Thumbs = exports.Carousel = undefined;\n\nvar _Carousel = require('./components/Carousel');\n\nvar _Carousel2 = _interopRequireDefault(_Carousel);\n\nvar _Thumbs = require('./components/Thumbs');\n\nvar _Thumbs2 = _interopRequireDefault(_Thumbs);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.Carousel = _Carousel2.default;\nexports.Thumbs = _Thumbs2.default;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var REACT_ELEMENT_TYPE = (typeof Symbol === 'function' &&\n Symbol.for &&\n Symbol.for('react.element')) ||\n 0xeac7;\n\n var isValidElement = function(object) {\n return typeof object === 'object' &&\n object !== null &&\n object.$$typeof === REACT_ELEMENT_TYPE;\n };\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(isValidElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _cssClasses = require('../cssClasses');\n\nvar _cssClasses2 = _interopRequireDefault(_cssClasses);\n\nvar _dimensions = require('../dimensions');\n\nvar _CSSTranslate = require('../CSSTranslate');\n\nvar _CSSTranslate2 = _interopRequireDefault(_CSSTranslate);\n\nvar _reactEasySwipe = require('react-easy-swipe');\n\nvar _reactEasySwipe2 = _interopRequireDefault(_reactEasySwipe);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Thumbs = function (_Component) {\n _inherits(Thumbs, _Component);\n\n function Thumbs(props) {\n _classCallCheck(this, Thumbs);\n\n var _this = _possibleConstructorReturn(this, (Thumbs.__proto__ || Object.getPrototypeOf(Thumbs)).call(this, props));\n\n _this.setItemsWrapperRef = function (node) {\n _this.itemsWrapperRef = node;\n };\n\n _this.setItemsListRef = function (node) {\n _this.itemsListRef = node;\n };\n\n _this.setThumbsRef = function (node, index) {\n if (!_this.thumbsRef) {\n _this.thumbsRef = [];\n }\n _this.thumbsRef[index] = node;\n };\n\n _this.updateSizes = function () {\n if (!_this.props.children || !_this.itemsWrapperRef) {\n return;\n }\n\n var total = _this.props.children.length;\n var wrapperSize = _this.itemsWrapperRef.clientWidth;\n var itemSize = _this.props.thumbWidth ? _this.props.thumbWidth : (0, _dimensions.outerWidth)(_this.thumbsRef[0]);\n var visibleItems = Math.floor(wrapperSize / itemSize);\n var lastPosition = total - visibleItems;\n var showArrows = visibleItems < total;\n _this.setState({\n itemSize: itemSize,\n visibleItems: visibleItems,\n firstItem: showArrows ? _this.getFirstItem(_this.props.selectedItem) : 0,\n lastPosition: lastPosition,\n showArrows: showArrows\n });\n };\n\n _this.setMountState = function () {\n _this.setState({ hasMount: true });\n _this.updateSizes();\n };\n\n _this.handleClickItem = function (index, item) {\n var handler = _this.props.onSelectItem;\n\n if (typeof handler === 'function') {\n handler(index, item);\n }\n };\n\n _this.onSwipeStart = function () {\n _this.setState({\n swiping: true\n });\n };\n\n _this.onSwipeEnd = function () {\n _this.setState({\n swiping: false\n });\n };\n\n _this.onSwipeMove = function (deltaX) {\n var leftBoundry = 0;\n\n var currentPosition = -_this.state.firstItem * _this.state.itemSize;\n var lastLeftBoundry = -_this.state.visibleItems * _this.state.itemSize;\n\n // prevent user from swiping left out of boundaries\n if (currentPosition === leftBoundry && deltaX > 0) {\n deltaX = 0;\n }\n\n // prevent user from swiping right out of boundaries\n if (currentPosition === lastLeftBoundry && deltaX < 0) {\n deltaX = 0;\n }\n\n var position = currentPosition + 100 / (wrapperSize / deltaX) + '%';\n\n // if 3d isn't available we will use left to move\n ['WebkitTransform', 'MozTransform', 'MsTransform', 'OTransform', 'transform', 'msTransform'].forEach(function (prop) {\n list.style[prop] = (0, _CSSTranslate2.default)(position, _this.props.axis);\n });\n };\n\n _this.slideRight = function (positions) {\n _this.moveTo(_this.state.firstItem - (typeof positions === 'Number' ? positions : 1));\n };\n\n _this.slideLeft = function (positions) {\n _this.moveTo(_this.state.firstItem + (typeof positions === 'Number' ? positions : 1));\n };\n\n _this.moveTo = function (position) {\n // position can't be lower than 0\n position = position < 0 ? 0 : position;\n // position can't be higher than last postion\n position = position >= _this.lastPosition ? _this.lastPosition : position;\n\n _this.setState({\n firstItem: position,\n // if it's not a slider, we don't need to set position here\n selectedItem: _this.state.selectedItem\n });\n };\n\n _this.state = {\n selectedItem: props.selectedItem,\n hasMount: false,\n firstItem: 0,\n itemSize: null,\n visibleItems: 0,\n lastPosition: 0,\n showArrows: false,\n images: _this.getImages()\n };\n return _this;\n }\n\n _createClass(Thumbs, [{\n key: 'componentDidMount',\n value: function componentDidMount(nextProps) {\n this.setupThumbs();\n }\n }, {\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(props, state) {\n if (props.selectedItem !== this.state.selectedItem) {\n this.setState({\n selectedItem: props.selectedItem,\n firstItem: this.getFirstItem(props.selectedItem)\n });\n }\n if (props.children !== this.props.children) {\n this.setState({\n images: this.getImages()\n });\n }\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps) {\n if (this.props.children === prevProps.children) {\n return;\n }\n\n // This will capture any size changes for arrow adjustments etc.\n // usually in the same render cycle so we don't see any flickers\n this.updateSizes();\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n this.destroyThumbs();\n }\n }, {\n key: 'setupThumbs',\n value: function setupThumbs() {\n // as the widths are calculated, we need to resize\n // the carousel when the window is resized\n window.addEventListener(\"resize\", this.updateSizes);\n // issue #2 - image loading smaller\n window.addEventListener(\"DOMContentLoaded\", this.updateSizes);\n\n // when the component is rendered we need to calculate\n // the container size to adjust the responsive behaviour\n this.updateSizes();\n }\n }, {\n key: 'destroyThumbs',\n value: function destroyThumbs() {\n // removing listeners\n window.removeEventListener(\"resize\", this.updateSizes);\n window.removeEventListener(\"DOMContentLoaded\", this.updateSizes);\n }\n }, {\n key: 'getImages',\n value: function getImages() {\n var images = _react.Children.map(this.props.children, function (item, index) {\n var img = item;\n\n // if the item is not an image, try to find the first image in the item's children.\n if (item.type !== \"img\") {\n img = _react.Children.toArray(item.props.children).filter(function (children) {\n return children.type === \"img\";\n })[0];\n }\n\n if (!img || img.length === 0) {\n return null;\n }\n\n return img;\n });\n\n if (images.filter(function (image) {\n return image !== null;\n }).length === 0) {\n console.warn('No images found! Can\\'t build the thumb list without images. If you don\\'t need thumbs, set showThumbs={false} in the Carousel. Note that it\\'s not possible to get images rendered inside custom components. More info at https://github.com/leandrowd/react-responsive-carousel/blob/master/TROUBLESHOOTING.md');\n\n return null;\n }\n\n return images;\n }\n }, {\n key: 'getFirstItem',\n value: function getFirstItem(selectedItem) {\n var firstItem = selectedItem;\n\n if (selectedItem >= this.state.lastPosition) {\n firstItem = this.state.lastPosition;\n }\n\n if (selectedItem < this.state.firstItem + this.state.visibleItems) {\n firstItem = this.state.firstItem;\n }\n\n if (selectedItem < this.state.firstItem) {\n firstItem = selectedItem;\n }\n\n return firstItem;\n }\n }, {\n key: 'renderItems',\n value: function renderItems() {\n var _this2 = this;\n\n return this.state.images.map(function (img, index) {\n var itemClass = _cssClasses2.default.ITEM(false, index === _this2.state.selectedItem && _this2.state.hasMount);\n\n var thumbProps = {\n key: index,\n ref: function ref(e) {\n return _this2.setThumbsRef(e, index);\n },\n className: itemClass,\n onClick: _this2.handleClickItem.bind(_this2, index, _this2.props.children[index])\n };\n\n if (index === 0) {\n img = _react2.default.cloneElement(img, {\n onLoad: _this2.setMountState\n });\n }\n\n return _react2.default.createElement(\n 'li',\n thumbProps,\n img\n );\n });\n }\n }, {\n key: 'render',\n value: function render() {\n if (!this.props.children) {\n return null;\n }\n\n // show left arrow?\n var hasPrev = this.state.showArrows && this.state.firstItem > 0;\n // show right arrow\n var hasNext = this.state.showArrows && this.state.firstItem < this.state.lastPosition;\n // obj to hold the transformations and styles\n var itemListStyles = {};\n\n var currentPosition = -this.state.firstItem * this.state.itemSize + 'px';\n\n var transformProp = (0, _CSSTranslate2.default)(currentPosition, this.props.axis);\n\n var transitionTime = this.props.transitionTime + 'ms';\n\n itemListStyles = {\n 'WebkitTransform': transformProp,\n 'MozTransform': transformProp,\n 'MsTransform': transformProp,\n 'OTransform': transformProp,\n 'transform': transformProp,\n 'msTransform': transformProp,\n 'WebkitTransitionDuration': transitionTime,\n 'MozTransitionDuration': transitionTime,\n 'MsTransitionDuration': transitionTime,\n 'OTransitionDuration': transitionTime,\n 'transitionDuration': transitionTime,\n 'msTransitionDuration': transitionTime\n };\n\n return _react2.default.createElement(\n 'div',\n { className: _cssClasses2.default.CAROUSEL(false) },\n _react2.default.createElement(\n 'div',\n { className: _cssClasses2.default.WRAPPER(false), ref: this.setItemsWrapperRef },\n _react2.default.createElement('button', { type: 'button', className: _cssClasses2.default.ARROW_PREV(!hasPrev), onClick: this.slideRight }),\n _react2.default.createElement(\n _reactEasySwipe2.default,\n { tagName: 'ul',\n selectedItem: this.state.selectedItem,\n className: _cssClasses2.default.SLIDER(false, this.state.swiping),\n onSwipeLeft: this.slideLeft,\n onSwipeRight: this.slideRight,\n onSwipeMove: this.onSwipeMove,\n onSwipeStart: this.onSwipeStart,\n onSwipeEnd: this.onSwipeEnd,\n style: itemListStyles,\n ref: this.setItemsListRef },\n this.renderItems()\n ),\n _react2.default.createElement('button', { type: 'button', className: _cssClasses2.default.ARROW_NEXT(!hasNext), onClick: this.slideLeft })\n )\n );\n }\n }]);\n\n return Thumbs;\n}(_react.Component);\n\nThumbs.displayName = 'Thumbs';\nThumbs.propsTypes = {\n children: _propTypes2.default.element.isRequired,\n transitionTime: _propTypes2.default.number,\n selectedItem: _propTypes2.default.number,\n thumbWidth: _propTypes2.default.number\n};\nThumbs.defaultProps = {\n selectedItem: 0,\n transitionTime: 350,\n axis: 'horizontal'\n};\nexports.default = Thumbs;","(function (global, factory) {\n if (typeof define === \"function\" && define.amd) {\n define(['exports', './react-swipe'], factory);\n } else if (typeof exports !== \"undefined\") {\n factory(exports, require('./react-swipe'));\n } else {\n var mod = {\n exports: {}\n };\n factory(mod.exports, global.reactSwipe);\n global.index = mod.exports;\n }\n})(this, function (exports, _reactSwipe) {\n 'use strict';\n\n Object.defineProperty(exports, \"__esModule\", {\n value: true\n });\n\n var _reactSwipe2 = _interopRequireDefault(_reactSwipe);\n\n function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n }\n\n exports.default = _reactSwipe2.default;\n});","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nexports.default = function (position, axis) {\n var positionCss = axis === 'horizontal' ? [position, 0, 0] : [0, position, 0];\n var transitionProp = 'translate3d';\n\n var translatedPosition = '(' + positionCss.join(',') + ')';\n\n return transitionProp + translatedPosition;\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _classnames = require(\"classnames\");\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = {\n CAROUSEL: function CAROUSEL(isSlider) {\n return (0, _classnames2.default)({\n \"carousel\": true,\n \"carousel-slider\": isSlider\n });\n },\n\n WRAPPER: function WRAPPER(isSlider, axis) {\n return (0, _classnames2.default)({\n \"thumbs-wrapper\": !isSlider,\n \"slider-wrapper\": isSlider,\n \"axis-horizontal\": axis === \"horizontal\",\n \"axis-vertical\": axis !== \"horizontal\"\n });\n },\n\n SLIDER: function SLIDER(isSlider, isSwiping) {\n return (0, _classnames2.default)({\n \"thumbs\": !isSlider,\n \"slider\": isSlider,\n \"animated\": !isSwiping\n });\n },\n\n ITEM: function ITEM(isSlider, selected) {\n return (0, _classnames2.default)({\n \"thumb\": !isSlider,\n \"slide\": isSlider,\n \"selected\": selected\n });\n },\n\n ARROW_PREV: function ARROW_PREV(disabled) {\n return (0, _classnames2.default)({\n \"control-arrow control-prev\": true,\n \"control-disabled\": disabled\n });\n },\n\n ARROW_NEXT: function ARROW_NEXT(disabled) {\n return (0, _classnames2.default)({\n \"control-arrow control-next\": true,\n \"control-disabled\": disabled\n });\n },\n\n DOT: function DOT(selected) {\n return (0, _classnames2.default)({\n \"dot\": true,\n 'selected': selected\n });\n }\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar unit = exports.unit = function unit(props, propName, componentName) {\n if (!/(pt|px|em|rem|vw|vh|%)$/.test(props[propName])) {\n return new Error('Invalid prop `' + propName + '` supplied to' + ' `' + componentName + '`. Validation failed. It needs to be a size unit like pt, px, em, rem, vw, %');\n }\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n\tvalue: true\n});\nvar outerWidth = exports.outerWidth = function outerWidth(el) {\n\tvar width = el.offsetWidth;\n\tvar style = getComputedStyle(el);\n\n\twidth += parseInt(style.marginLeft) + parseInt(style.marginRight);\n\treturn width;\n};","(function (global, factory) {\n if (typeof define === \"function\" && define.amd) {\n define(['exports', 'react', 'prop-types'], factory);\n } else if (typeof exports !== \"undefined\") {\n factory(exports, require('react'), require('prop-types'));\n } else {\n var mod = {\n exports: {}\n };\n factory(mod.exports, global.react, global.propTypes);\n global.reactSwipe = mod.exports;\n }\n})(this, function (exports, _react, _propTypes) {\n 'use strict';\n\n Object.defineProperty(exports, \"__esModule\", {\n value: true\n });\n exports.setHasSupportToCaptureOption = setHasSupportToCaptureOption;\n\n var _react2 = _interopRequireDefault(_react);\n\n var _propTypes2 = _interopRequireDefault(_propTypes);\n\n function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n }\n\n function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n }\n\n var _createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n }();\n\n function _possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n }\n\n function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n }\n\n var supportsCaptureOption = false;\n function setHasSupportToCaptureOption(hasSupport) {\n supportsCaptureOption = hasSupport;\n }\n\n try {\n addEventListener(\"test\", null, Object.defineProperty({}, 'capture', { get: function get() {\n setHasSupportToCaptureOption(true);\n } }));\n } catch (e) {}\n\n function getSafeEventHandlerOpts() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : { capture: true };\n\n return supportsCaptureOption ? options : options.capture;\n }\n\n /**\n * [getPosition returns a position element that works for mouse or touch events]\n * @param {[Event]} event [the received event]\n * @return {[Object]} [x and y coords]\n */\n function getPosition(event) {\n if ('touches' in event) {\n var _event$touches$ = event.touches[0],\n pageX = _event$touches$.pageX,\n pageY = _event$touches$.pageY;\n\n return { x: pageX, y: pageY };\n }\n\n var screenX = event.screenX,\n screenY = event.screenY;\n\n return { x: screenX, y: screenY };\n }\n\n var ReactSwipe = function (_Component) {\n _inherits(ReactSwipe, _Component);\n\n function ReactSwipe() {\n var _ref;\n\n _classCallCheck(this, ReactSwipe);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var _this = _possibleConstructorReturn(this, (_ref = ReactSwipe.__proto__ || Object.getPrototypeOf(ReactSwipe)).call.apply(_ref, [this].concat(args)));\n\n _this._handleSwipeStart = _this._handleSwipeStart.bind(_this);\n _this._handleSwipeMove = _this._handleSwipeMove.bind(_this);\n _this._handleSwipeEnd = _this._handleSwipeEnd.bind(_this);\n\n _this._onMouseDown = _this._onMouseDown.bind(_this);\n _this._onMouseMove = _this._onMouseMove.bind(_this);\n _this._onMouseUp = _this._onMouseUp.bind(_this);\n return _this;\n }\n\n _createClass(ReactSwipe, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n if (this.swiper) {\n this.swiper.addEventListener('touchmove', this._handleSwipeMove, getSafeEventHandlerOpts({\n capture: true,\n passive: false\n }));\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.swiper) {\n this.swiper.removeEventListener('touchmove', this._handleSwipeMove, getSafeEventHandlerOpts({\n capture: true,\n passive: false\n }));\n }\n }\n }, {\n key: '_onMouseDown',\n value: function _onMouseDown(event) {\n if (!this.props.allowMouseEvents) {\n return;\n }\n\n this.mouseDown = true;\n\n document.addEventListener('mouseup', this._onMouseUp);\n document.addEventListener('mousemove', this._onMouseMove);\n\n this._handleSwipeStart(event);\n }\n }, {\n key: '_onMouseMove',\n value: function _onMouseMove(event) {\n if (!this.mouseDown) {\n return;\n }\n\n this._handleSwipeMove(event);\n }\n }, {\n key: '_onMouseUp',\n value: function _onMouseUp(event) {\n this.mouseDown = false;\n\n document.removeEventListener('mouseup', this._onMouseUp);\n document.removeEventListener('mousemove', this._onMouseMove);\n\n this._handleSwipeEnd(event);\n }\n }, {\n key: '_handleSwipeStart',\n value: function _handleSwipeStart(event) {\n var _getPosition = getPosition(event),\n x = _getPosition.x,\n y = _getPosition.y;\n\n this.moveStart = { x: x, y: y };\n this.props.onSwipeStart(event);\n }\n }, {\n key: '_handleSwipeMove',\n value: function _handleSwipeMove(event) {\n if (!this.moveStart) {\n return;\n }\n\n var _getPosition2 = getPosition(event),\n x = _getPosition2.x,\n y = _getPosition2.y;\n\n var deltaX = x - this.moveStart.x;\n var deltaY = y - this.moveStart.y;\n this.moving = true;\n\n // handling the responsability of cancelling the scroll to\n // the component handling the event\n var shouldPreventDefault = this.props.onSwipeMove({\n x: deltaX,\n y: deltaY\n }, event);\n\n if (shouldPreventDefault) {\n event.preventDefault();\n }\n\n this.movePosition = { deltaX: deltaX, deltaY: deltaY };\n }\n }, {\n key: '_handleSwipeEnd',\n value: function _handleSwipeEnd(event) {\n this.props.onSwipeEnd(event);\n\n var tolerance = this.props.tolerance;\n\n\n if (this.moving) {\n if (this.movePosition.deltaX < -tolerance) {\n this.props.onSwipeLeft(1, event);\n } else if (this.movePosition.deltaX > tolerance) {\n this.props.onSwipeRight(1, event);\n }\n if (this.movePosition.deltaY < -tolerance) {\n this.props.onSwipeUp(1, event);\n } else if (this.movePosition.deltaY > tolerance) {\n this.props.onSwipeDown(1, event);\n }\n }\n\n this.moveStart = null;\n this.moving = false;\n this.movePosition = null;\n }\n }, {\n key: 'render',\n value: function render() {\n var _this2 = this;\n\n return _react2.default.createElement(\n this.props.tagName,\n {\n ref: function ref(node) {\n return _this2.swiper = node;\n },\n onMouseDown: this._onMouseDown,\n onTouchStart: this._handleSwipeStart,\n onTouchEnd: this._handleSwipeEnd,\n className: this.props.className,\n style: this.props.style\n },\n this.props.children\n );\n }\n }]);\n\n return ReactSwipe;\n }(_react.Component);\n\n ReactSwipe.displayName = 'ReactSwipe';\n ReactSwipe.propTypes = {\n tagName: _propTypes2.default.string,\n className: _propTypes2.default.string,\n style: _propTypes2.default.object,\n children: _propTypes2.default.node,\n allowMouseEvents: _propTypes2.default.bool,\n onSwipeUp: _propTypes2.default.func,\n onSwipeDown: _propTypes2.default.func,\n onSwipeLeft: _propTypes2.default.func,\n onSwipeRight: _propTypes2.default.func,\n onSwipeStart: _propTypes2.default.func,\n onSwipeMove: _propTypes2.default.func,\n onSwipeEnd: _propTypes2.default.func,\n tolerance: _propTypes2.default.number.isRequired\n };\n ReactSwipe.defaultProps = {\n tagName: 'div',\n allowMouseEvents: false,\n onSwipeUp: function onSwipeUp() {},\n onSwipeDown: function onSwipeDown() {},\n onSwipeLeft: function onSwipeLeft() {},\n onSwipeRight: function onSwipeRight() {},\n onSwipeStart: function onSwipeStart() {},\n onSwipeMove: function onSwipeMove() {},\n onSwipeEnd: function onSwipeEnd() {},\n\n tolerance: 0\n };\n exports.default = ReactSwipe;\n});","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar validateFormat = function validateFormat(format) {};\n\nif (process.env.NODE_ENV !== 'production') {\n validateFormat = function validateFormat(format) {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n };\n}\n\nfunction invariant(condition, format, a, b, c, d, e, f) {\n validateFormat(format);\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.');\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(format.replace(/%s/g, function () {\n return args[argIndex++];\n }));\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n}\n\nmodule.exports = invariant;","\"use strict\";\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nfunction makeEmptyFunction(arg) {\n return function () {\n return arg;\n };\n}\n\n/**\n * This function accepts and discards inputs; it has no side effects. This is\n * primarily useful idiomatically for overridable function endpoints which\n * always need to be callable, since JS lacks a null-call idiom ala Cocoa.\n */\nvar emptyFunction = function emptyFunction() {};\n\nemptyFunction.thatReturns = makeEmptyFunction;\nemptyFunction.thatReturnsFalse = makeEmptyFunction(false);\nemptyFunction.thatReturnsTrue = makeEmptyFunction(true);\nemptyFunction.thatReturnsNull = makeEmptyFunction(null);\nemptyFunction.thatReturnsThis = function () {\n return this;\n};\nemptyFunction.thatReturnsArgument = function (arg) {\n return arg;\n};\n\nmodule.exports = emptyFunction;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar emptyFunction = require('fbjs/lib/emptyFunction');\nvar invariant = require('fbjs/lib/invariant');\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n invariant(\n false,\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim\n };\n\n ReactPropTypes.checkPropTypes = emptyFunction;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _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; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _cssClasses = require('../cssClasses');\n\nvar _cssClasses2 = _interopRequireDefault(_cssClasses);\n\nvar _CSSTranslate = require('../CSSTranslate');\n\nvar _CSSTranslate2 = _interopRequireDefault(_CSSTranslate);\n\nvar _reactEasySwipe = require('react-easy-swipe');\n\nvar _reactEasySwipe2 = _interopRequireDefault(_reactEasySwipe);\n\nvar _Thumbs = require('./Thumbs');\n\nvar _Thumbs2 = _interopRequireDefault(_Thumbs);\n\nvar _customPropTypes = require('../customPropTypes');\n\nvar customPropTypes = _interopRequireWildcard(_customPropTypes);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar noop = function noop() {};\n\nvar defaultStatusFormatter = function defaultStatusFormatter(current, total) {\n return current + ' of ' + total;\n};\n\nvar Carousel = function (_Component) {\n _inherits(Carousel, _Component);\n\n function Carousel(props) {\n _classCallCheck(this, Carousel);\n\n var _this = _possibleConstructorReturn(this, (Carousel.__proto__ || Object.getPrototypeOf(Carousel)).call(this, props));\n\n _this.setThumbsRef = function (node) {\n _this.thumbsRef = node;\n };\n\n _this.setCarouselWrapperRef = function (node) {\n _this.carouselWrapperRef = node;\n };\n\n _this.setListRef = function (node) {\n _this.listRef = node;\n };\n\n _this.setItemsWrapperRef = function (node) {\n _this.itemsWrapperRef = node;\n };\n\n _this.setItemsRef = function (node, index) {\n if (!_this.itemsRef) {\n _this.itemsRef = [];\n }\n _this.itemsRef[index] = node;\n };\n\n _this.autoPlay = function () {\n if (!_this.props.autoPlay || _react.Children.count(_this.props.children) <= 1) {\n return;\n }\n\n clearTimeout(_this.timer);\n _this.timer = setTimeout(function () {\n _this.increment();\n }, _this.props.interval);\n };\n\n _this.clearAutoPlay = function () {\n if (!_this.props.autoPlay) {\n return;\n }\n\n clearTimeout(_this.timer);\n };\n\n _this.resetAutoPlay = function () {\n _this.clearAutoPlay();\n _this.autoPlay();\n };\n\n _this.stopOnHover = function () {\n _this.setState({ isMouseEntered: true });\n _this.clearAutoPlay();\n };\n\n _this.startOnLeave = function () {\n _this.setState({ isMouseEntered: false });\n _this.autoPlay();\n };\n\n _this.navigateWithKeyboard = function (e) {\n var axis = _this.props.axis;\n\n var isHorizontal = axis === 'horizontal';\n var keyNames = {\n ArrowUp: 38,\n ArrowRight: 39,\n ArrowDown: 40,\n ArrowLeft: 37\n };\n\n var nextKey = isHorizontal ? keyNames.ArrowRight : keyNames.ArrowDown;\n var prevKey = isHorizontal ? keyNames.ArrowLeft : keyNames.ArrowUp;\n\n if (nextKey === e.keyCode) {\n _this.increment();\n } else if (prevKey === e.keyCode) {\n _this.decrement();\n }\n };\n\n _this.updateSizes = function () {\n if (!_this.state.initialized) {\n return;\n }\n\n var isHorizontal = _this.props.axis === 'horizontal';\n var firstItem = _this.itemsRef[0];\n var itemSize = isHorizontal ? firstItem.clientWidth : firstItem.clientHeight;\n\n _this.setState({\n itemSize: itemSize,\n wrapperSize: isHorizontal ? itemSize * _react.Children.count(_this.props.children) : itemSize\n });\n\n if (_this.thumbsRef) {\n _this.thumbsRef.updateSizes();\n }\n };\n\n _this.setMountState = function () {\n _this.setState({ hasMount: true });\n _this.updateSizes();\n };\n\n _this.handleClickItem = function (index, item) {\n if (_react.Children.count(_this.props.children) <= 1) {\n return;\n }\n\n if (_this.state.cancelClick) {\n _this.setState({\n cancelClick: false\n });\n\n return;\n }\n\n _this.props.onClickItem(index, item);\n\n if (index !== _this.state.selectedItem) {\n _this.setState({\n selectedItem: index\n });\n }\n };\n\n _this.handleOnChange = function (index, item) {\n if (_react.Children.count(_this.props.children) <= 1) {\n return;\n }\n\n _this.props.onChange(index, item);\n };\n\n _this.handleClickThumb = function (index, item) {\n _this.props.onClickThumb(index, item);\n\n _this.selectItem({\n selectedItem: index\n });\n };\n\n _this.onSwipeStart = function () {\n _this.setState({\n swiping: true\n });\n _this.clearAutoPlay();\n };\n\n _this.onSwipeEnd = function () {\n _this.resetPosition();\n _this.setState({\n swiping: false\n });\n _this.autoPlay();\n };\n\n _this.onSwipeMove = function (delta) {\n var isHorizontal = _this.props.axis === 'horizontal';\n\n var initialBoundry = 0;\n\n var currentPosition = _this.getPosition(_this.state.selectedItem);\n var finalBoundry = _this.getPosition(_react.Children.count(_this.props.children) - 1);\n\n var axisDelta = isHorizontal ? delta.x : delta.y;\n var handledDelta = axisDelta;\n\n // prevent user from swiping left out of boundaries\n if (currentPosition === initialBoundry && axisDelta > 0) {\n handledDelta = 0;\n }\n\n // prevent user from swiping right out of boundaries\n if (currentPosition === finalBoundry && axisDelta < 0) {\n handledDelta = 0;\n }\n\n var position = currentPosition + 100 / (_this.state.itemSize / handledDelta) + '%';\n\n _this.setPosition(position);\n\n // allows scroll if the swipe was within the tolerance\n var hasMoved = Math.abs(axisDelta) > _this.props.swipeScrollTolerance;\n\n if (hasMoved && !_this.state.cancelClick) {\n _this.setState({\n cancelClick: true\n });\n }\n\n return hasMoved;\n };\n\n _this.resetPosition = function () {\n var currentPosition = _this.getPosition(_this.state.selectedItem) + '%';\n _this.setPosition(currentPosition);\n };\n\n _this.setPosition = function (position) {\n var list = _reactDom2.default.findDOMNode(_this.listRef);\n ['WebkitTransform', 'MozTransform', 'MsTransform', 'OTransform', 'transform', 'msTransform'].forEach(function (prop) {\n list.style[prop] = (0, _CSSTranslate2.default)(position, _this.props.axis);\n });\n };\n\n _this.decrement = function (positions) {\n _this.moveTo(_this.state.selectedItem - (typeof positions === 'Number' ? positions : 1));\n };\n\n _this.increment = function (positions) {\n _this.moveTo(_this.state.selectedItem + (typeof positions === 'Number' ? positions : 1));\n };\n\n _this.moveTo = function (position) {\n var lastPosition = _react.Children.count(_this.props.children) - 1;\n\n if (position < 0) {\n position = _this.props.infiniteLoop ? lastPosition : 0;\n }\n\n if (position > lastPosition) {\n position = _this.props.infiniteLoop ? 0 : lastPosition;\n }\n\n _this.selectItem({\n // if it's not a slider, we don't need to set position here\n selectedItem: position\n });\n\n // don't reset auto play when stop on hover is enabled, doing so will trigger a call to auto play more than once\n // and will result in the interval function not being cleared correctly.\n if (_this.props.autoPlay && _this.state.isMouseEntered === false) {\n _this.resetAutoPlay();\n }\n };\n\n _this.changeItem = function (e) {\n var newIndex = e.target.value;\n\n _this.selectItem({\n selectedItem: newIndex\n });\n };\n\n _this.selectItem = function (state) {\n _this.setState(state);\n _this.handleOnChange(state.selectedItem, _react.Children.toArray(_this.props.children)[state.selectedItem]);\n };\n\n _this.getInitialImage = function () {\n var selectedItem = _this.props.selectedItem;\n var item = _this.itemsRef && _this.itemsRef[selectedItem];\n var images = item && item.getElementsByTagName('img');\n return images && images[selectedItem];\n };\n\n _this.getVariableImageHeight = function (position) {\n var item = _this.itemsRef && _this.itemsRef[position];\n var images = item && item.getElementsByTagName('img');\n if (_this.state.hasMount && images.length > 0) {\n var image = images[0];\n\n if (!image.complete) {\n // if the image is still loading, the size won't be available so we trigger a new render after it's done\n var onImageLoad = function onImageLoad() {\n _this.forceUpdate();\n image.removeEventListener('load', onImageLoad);\n };\n\n image.addEventListener('load', onImageLoad);\n }\n\n var height = image.clientHeight;\n return height > 0 ? height : null;\n }\n\n return null;\n };\n\n _this.state = {\n initialized: false,\n selectedItem: props.selectedItem,\n hasMount: false,\n isMouseEntered: false\n };\n return _this;\n }\n\n _createClass(Carousel, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n if (!this.props.children) {\n return;\n }\n\n this.setupCarousel();\n }\n }, {\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(nextProps) {\n if (nextProps.selectedItem !== this.state.selectedItem) {\n this.updateSizes();\n this.moveTo(nextProps.selectedItem);\n }\n\n if (nextProps.autoPlay !== this.props.autoPlay) {\n if (nextProps.autoPlay) {\n this.setupAutoPlay();\n } else {\n this.destroyAutoPlay();\n }\n }\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate(prevProps) {\n if (!prevProps.children && this.props.children && !this.state.initialized) {\n this.setupCarousel();\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n this.destroyCarousel();\n }\n }, {\n key: 'setupCarousel',\n value: function setupCarousel() {\n this.bindEvents();\n\n if (this.props.autoPlay && _react.Children.count(this.props.children) > 1) {\n this.setupAutoPlay();\n }\n\n this.setState({\n initialized: true\n });\n\n var initialImage = this.getInitialImage();\n if (initialImage) {\n // if it's a carousel of images, we set the mount state after the first image is loaded\n initialImage.addEventListener('load', this.setMountState);\n } else {\n this.setMountState();\n }\n }\n }, {\n key: 'destroyCarousel',\n value: function destroyCarousel() {\n if (this.state.initialized) {\n this.unbindEvents();\n this.destroyAutoPlay();\n }\n }\n }, {\n key: 'setupAutoPlay',\n value: function setupAutoPlay() {\n this.autoPlay();\n var carouselWrapper = this.carouselWrapperRef;\n\n if (this.props.stopOnHover && carouselWrapper) {\n carouselWrapper.addEventListener('mouseenter', this.stopOnHover);\n carouselWrapper.addEventListener('mouseleave', this.startOnLeave);\n }\n }\n }, {\n key: 'destroyAutoPlay',\n value: function destroyAutoPlay() {\n this.clearAutoPlay();\n var carouselWrapper = this.carouselWrapperRef;\n\n if (this.props.stopOnHover && carouselWrapper) {\n carouselWrapper.removeEventListener('mouseenter', this.stopOnHover);\n carouselWrapper.removeEventListener('mouseleave', this.startOnLeave);\n }\n }\n }, {\n key: 'bindEvents',\n value: function bindEvents() {\n // as the widths are calculated, we need to resize\n // the carousel when the window is resized\n window.addEventListener(\"resize\", this.updateSizes);\n // issue #2 - image loading smaller\n window.addEventListener(\"DOMContentLoaded\", this.updateSizes);\n\n if (this.props.useKeyboardArrows) {\n document.addEventListener(\"keydown\", this.navigateWithKeyboard);\n }\n }\n }, {\n key: 'unbindEvents',\n value: function unbindEvents() {\n // removing listeners\n window.removeEventListener(\"resize\", this.updateSizes);\n window.removeEventListener(\"DOMContentLoaded\", this.updateSizes);\n\n var initialImage = this.getInitialImage();\n if (initialImage) {\n initialImage.removeEventListener(\"load\", this.setMountState);\n }\n\n if (this.props.useKeyboardArrows) {\n document.removeEventListener(\"keydown\", this.navigateWithKeyboard);\n }\n }\n }, {\n key: 'getPosition',\n value: function getPosition(index) {\n if (this.props.centerMode && this.props.axis === 'horizontal') {\n var currentPosition = -index * this.props.centerSlidePercentage;\n var lastPosition = _react.Children.count(this.props.children) - 1;\n\n if (index && index !== lastPosition) {\n currentPosition += (100 - this.props.centerSlidePercentage) / 2;\n } else if (index === lastPosition) {\n currentPosition += 100 - this.props.centerSlidePercentage;\n }\n\n return currentPosition;\n }\n\n return -index * 100;\n }\n }, {\n key: 'renderItems',\n value: function renderItems() {\n var _this2 = this;\n\n return _react.Children.map(this.props.children, function (item, index) {\n var itemClass = _cssClasses2.default.ITEM(true, index === _this2.state.selectedItem);\n var slideProps = {\n ref: function ref(e) {\n return _this2.setItemsRef(e, index);\n },\n key: 'itemKey' + index,\n className: _cssClasses2.default.ITEM(true, index === _this2.state.selectedItem),\n onClick: _this2.handleClickItem.bind(_this2, index, item)\n };\n\n if (_this2.props.centerMode && _this2.props.axis === 'horizontal') {\n slideProps.style = {\n minWidth: _this2.props.centerSlidePercentage + '%'\n };\n }\n\n return _react2.default.createElement(\n 'li',\n slideProps,\n item\n );\n });\n }\n }, {\n key: 'renderControls',\n value: function renderControls() {\n var _this3 = this;\n\n if (!this.props.showIndicators) {\n return null;\n }\n\n return _react2.default.createElement(\n 'ul',\n { className: 'control-dots' },\n _react.Children.map(this.props.children, function (item, index) {\n return _react2.default.createElement('li', { className: _cssClasses2.default.DOT(index === _this3.state.selectedItem), onClick: _this3.changeItem, value: index, key: index });\n })\n );\n }\n }, {\n key: 'renderStatus',\n value: function renderStatus() {\n if (!this.props.showStatus) {\n return null;\n }\n\n return _react2.default.createElement(\n 'p',\n { className: 'carousel-status' },\n this.props.statusFormatter(this.state.selectedItem + 1, _react.Children.count(this.props.children))\n );\n }\n }, {\n key: 'renderThumbs',\n value: function renderThumbs() {\n if (!this.props.showThumbs || _react.Children.count(this.props.children) === 0) {\n return null;\n }\n\n return _react2.default.createElement(\n _Thumbs2.default,\n { ref: this.setThumbsRef, onSelectItem: this.handleClickThumb, selectedItem: this.state.selectedItem, transitionTime: this.props.transitionTime, thumbWidth: this.props.thumbWidth },\n this.props.children\n );\n }\n }, {\n key: 'render',\n value: function render() {\n if (!this.props.children || _react.Children.count(this.props.children) === 0) {\n return null;\n }\n\n var itemsLength = _react.Children.count(this.props.children);\n\n var isHorizontal = this.props.axis === 'horizontal';\n\n var canShowArrows = this.props.showArrows && itemsLength > 1;\n\n // show left arrow?\n var hasPrev = canShowArrows && (this.state.selectedItem > 0 || this.props.infiniteLoop);\n // show right arrow\n var hasNext = canShowArrows && (this.state.selectedItem < itemsLength - 1 || this.props.infiniteLoop);\n // obj to hold the transformations and styles\n var itemListStyles = {};\n\n var currentPosition = this.getPosition(this.state.selectedItem);\n\n // if 3d is available, let's take advantage of the performance of transform\n var transformProp = (0, _CSSTranslate2.default)(currentPosition + '%', this.props.axis);\n\n var transitionTime = this.props.transitionTime + 'ms';\n\n itemListStyles = {\n 'WebkitTransform': transformProp,\n 'MozTransform': transformProp,\n 'MsTransform': transformProp,\n 'OTransform': transformProp,\n 'transform': transformProp,\n 'msTransform': transformProp\n };\n\n if (!this.state.swiping) {\n itemListStyles = _extends({}, itemListStyles, {\n 'WebkitTransitionDuration': transitionTime,\n 'MozTransitionDuration': transitionTime,\n 'MsTransitionDuration': transitionTime,\n 'OTransitionDuration': transitionTime,\n 'transitionDuration': transitionTime,\n 'msTransitionDuration': transitionTime\n });\n }\n\n var swiperProps = {\n selectedItem: this.state.selectedItem,\n className: _cssClasses2.default.SLIDER(true, this.state.swiping),\n onSwipeMove: this.onSwipeMove,\n onSwipeStart: this.onSwipeStart,\n onSwipeEnd: this.onSwipeEnd,\n style: itemListStyles,\n tolerance: this.props.swipeScrollTolerance\n };\n\n var containerStyles = {};\n\n if (isHorizontal) {\n swiperProps.onSwipeLeft = this.increment;\n swiperProps.onSwipeRight = this.decrement;\n\n if (this.props.dynamicHeight) {\n var itemHeight = this.getVariableImageHeight(this.state.selectedItem);\n swiperProps.style.height = itemHeight || 'auto';\n containerStyles.height = itemHeight || 'auto';\n }\n } else {\n swiperProps.onSwipeUp = this.props.verticalSwipe === 'natural' ? this.increment : this.decrement;\n swiperProps.onSwipeDown = this.props.verticalSwipe === 'natural' ? this.decrement : this.increment;\n swiperProps.style.height = this.state.itemSize;\n containerStyles.height = this.state.itemSize;\n }\n return _react2.default.createElement(\n 'div',\n { className: this.props.className, ref: this.setCarouselWrapperRef },\n _react2.default.createElement(\n 'div',\n { className: _cssClasses2.default.CAROUSEL(true), style: { width: this.props.width } },\n _react2.default.createElement('button', { type: 'button', className: _cssClasses2.default.ARROW_PREV(!hasPrev), onClick: this.decrement }),\n _react2.default.createElement(\n 'div',\n { className: _cssClasses2.default.WRAPPER(true, this.props.axis), style: containerStyles, ref: this.setItemsWrapperRef },\n this.props.swipeable ? _react2.default.createElement(\n _reactEasySwipe2.default,\n _extends({\n tagName: 'ul',\n ref: this.setListRef\n }, swiperProps, {\n allowMouseEvents: this.props.emulateTouch }),\n this.renderItems()\n ) : _react2.default.createElement(\n 'ul',\n {\n className: _cssClasses2.default.SLIDER(true, this.state.swiping),\n style: itemListStyles },\n this.renderItems()\n )\n ),\n _react2.default.createElement('button', { type: 'button', className: _cssClasses2.default.ARROW_NEXT(!hasNext), onClick: this.increment }),\n this.renderControls(),\n this.renderStatus()\n ),\n this.renderThumbs()\n );\n }\n }]);\n\n return Carousel;\n}(_react.Component);\n\nCarousel.displayName = 'Carousel';\nCarousel.propTypes = {\n className: _propTypes2.default.string,\n children: _propTypes2.default.node,\n showArrows: _propTypes2.default.bool,\n showStatus: _propTypes2.default.bool,\n showIndicators: _propTypes2.default.bool,\n infiniteLoop: _propTypes2.default.bool,\n showThumbs: _propTypes2.default.bool,\n thumbWidth: _propTypes2.default.number,\n selectedItem: _propTypes2.default.number,\n onClickItem: _propTypes2.default.func.isRequired,\n onClickThumb: _propTypes2.default.func.isRequired,\n onChange: _propTypes2.default.func.isRequired,\n axis: _propTypes2.default.oneOf(['horizontal', 'vertical']),\n verticalSwipe: _propTypes2.default.oneOf(['natural', 'standard']),\n width: customPropTypes.unit,\n useKeyboardArrows: _propTypes2.default.bool,\n autoPlay: _propTypes2.default.bool,\n stopOnHover: _propTypes2.default.bool,\n interval: _propTypes2.default.number,\n transitionTime: _propTypes2.default.number,\n swipeScrollTolerance: _propTypes2.default.number,\n swipeable: _propTypes2.default.bool,\n dynamicHeight: _propTypes2.default.bool,\n emulateTouch: _propTypes2.default.bool,\n statusFormatter: _propTypes2.default.func.isRequired,\n centerMode: _propTypes2.default.bool,\n centerSlidePercentage: _propTypes2.default.number\n};\nCarousel.defaultProps = {\n showIndicators: true,\n showArrows: true,\n showStatus: true,\n showThumbs: true,\n infiniteLoop: false,\n selectedItem: 0,\n axis: 'horizontal',\n verticalSwipe: 'standard',\n width: '100%',\n useKeyboardArrows: false,\n autoPlay: false,\n stopOnHover: true,\n interval: 3000,\n transitionTime: 350,\n swipeScrollTolerance: 5,\n swipeable: true,\n dynamicHeight: false,\n emulateTouch: false,\n onClickItem: noop,\n onClickThumb: noop,\n onChange: noop,\n statusFormatter: defaultStatusFormatter,\n centerMode: false,\n centerSlidePercentage: 80\n};\nexports.default = Carousel;"],"sourceRoot":""}