{"version":3,"sources":["webpack:///./node_modules/react-slider/es/components/ReactSlider/ReactSlider.js"],"names":["_jsxFileName","_extends","Object","assign","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","_setPrototypeOf","o","p","setPrototypeOf","__proto__","pauseEvent","e","stopPropagation","preventDefault","sanitizeInValue","x","Array","isArray","slice","prepareOutValue","addHandlers","eventMap","keys","forEach","document","addEventListener","trimAlignValue","val","props","alignValue","trimmed","min","max","trimValue","valModStep","step","alignedValue","Math","abs","parseFloat","toFixed","ReactSlider","_React$Component","subClass","superClass","_props","_this","onKeyUp","onEnd","onMouseUp","getMouseEventMap","onTouchEnd","getTouchEventMap","onBlur","setState","index","getKeyDownEventMap","onMouseMove","pending","position","getMousePosition","diffPosition","getDiffPosition","newValue","getValueFromPosition","move","onTouchMove","touches","getTouchPosition","isScrolling","diffMainDir","startPosition","diffScrollDir","onKeyDown","ctrlKey","shiftKey","altKey","metaKey","moveDownByStep","moveUpByStep","pageFn","onSliderMouseDown","disabled","button","snapDragDisabled","forceValueFromPosition","start","onSliderClick","hasMoved","valueAtPos","calcValue","calcOffsetFromPosition","createOnKeyDown","createOnMouseDown","createOnTouchStart","undefined","handleResize","resizeTimeout","window","setTimeout","pendingResizeTimeouts","shift","resize","push","renderThumb","style","className","thumbClassName","state","thumbActiveClassName","r","orientation","value","ariaLabel","ariaLabelledby","valueNow","ariaValuetext","renderTrack","offsetFrom","offsetTo","trackClassName","buildTrackStyle","upperBound","defaultValue","zIndices","sliderLength","create","constructor","_proto","componentDidMount","getDerivedStateFromProps","map","item","componentDidUpdate","componentWillUnmount","clearPendingResizeTimeouts","removeEventListener","removeHandlers","fireChangeEvent","getValue","getClosestIndex","pixelOffset","minDist","Number","MAX_VALUE","closestIndex","l","offset","calcOffset","dist","axisKey","orthogonalAxisKey","touch","keydown","keyup","focusout","mousemove","mouseup","touchmove","touchend","diffValue","thumbSize","startValue","invert","slider","thumb","thumb0","sizeKey","sliderRect","getBoundingClientRect","sliderSize","sliderMax","posMaxKey","sliderMin","posMinKey","replace","toLowerCase","range","callback","_this2","nextValue","minDistance","nextTimeout","clearTimeout","thumbRef","focus","splice","indexOf","prevState","_this$state","oldValue","_this$props","pearling","valueBefore","valueAfter","pushSucceeding","padding","trimSucceeding","pushPreceding","trimPreceding","bind","event","buildThumbStyle","touchAction","willChange","zIndex","obj","buildMarkStyle","_ref","renderThumbs","styles","res","_i","renderTracks","tracks","lastIndex","renderMarks","_this3","marks","from","_","filter","sort","a","b","mark","markClassName","renderMark","render","_this4","withTracks","thumbs","createElement","ref","onMouseDown","onClick","Component","displayName","defaultProps","__self","__source","fileName","lineNumber","columnNumber"],"mappings":"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","file":"f8d8dae3b0462ebf44fe044a6fe6946e4d4c9550-1997a22182e201a83313.js","sourcesContent":["import \"core-js/modules/es.array.sort.js\";\nvar _jsxFileName = \"/Users/brians/git/react-slider/src/components/ReactSlider/ReactSlider.jsx\";\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n\n _setPrototypeOf(subClass, superClass);\n}\n\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nimport React from 'react';\n\n/**\n * To prevent text selection while dragging.\n * http://stackoverflow.com/questions/5429827/how-can-i-prevent-text-element-selection-with-cursor-drag\n */\nfunction pauseEvent(e) {\n if (e && e.stopPropagation) {\n e.stopPropagation();\n }\n\n if (e && e.preventDefault) {\n e.preventDefault();\n }\n\n return false;\n}\n\nfunction stopPropagation(e) {\n if (e.stopPropagation) {\n e.stopPropagation();\n }\n}\n\nfunction sanitizeInValue(x) {\n if (x == null) {\n return [];\n }\n\n return Array.isArray(x) ? x.slice() : [x];\n}\n\nfunction prepareOutValue(x) {\n return x !== null && x.length === 1 ? x[0] : x.slice();\n}\n\nfunction trimSucceeding(length, nextValue, minDistance, max) {\n for (var i = 0; i < length; i += 1) {\n var padding = max - i * minDistance;\n\n if (nextValue[length - 1 - i] > padding) {\n // eslint-disable-next-line no-param-reassign\n nextValue[length - 1 - i] = padding;\n }\n }\n}\n\nfunction trimPreceding(length, nextValue, minDistance, min) {\n for (var i = 0; i < length; i += 1) {\n var padding = min + i * minDistance;\n\n if (nextValue[i] < padding) {\n // eslint-disable-next-line no-param-reassign\n nextValue[i] = padding;\n }\n }\n}\n\nfunction addHandlers(eventMap) {\n Object.keys(eventMap).forEach(function (key) {\n if (typeof document !== 'undefined') {\n document.addEventListener(key, eventMap[key], false);\n }\n });\n}\n\nfunction removeHandlers(eventMap) {\n Object.keys(eventMap).forEach(function (key) {\n if (typeof document !== 'undefined') {\n document.removeEventListener(key, eventMap[key], false);\n }\n });\n}\n\nfunction trimAlignValue(val, props) {\n return alignValue(trimValue(val, props), props);\n}\n\nfunction alignValue(val, props) {\n var valModStep = (val - props.min) % props.step;\n var alignedValue = val - valModStep;\n\n if (Math.abs(valModStep) * 2 >= props.step) {\n alignedValue += valModStep > 0 ? props.step : -props.step;\n }\n\n return parseFloat(alignedValue.toFixed(5));\n}\n\nfunction trimValue(val, props) {\n var trimmed = val;\n\n if (trimmed <= props.min) {\n trimmed = props.min;\n }\n\n if (trimmed >= props.max) {\n trimmed = props.max;\n }\n\n return trimmed;\n}\n\nvar ReactSlider = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(ReactSlider, _React$Component);\n\n function ReactSlider(_props) {\n var _this;\n\n _this = _React$Component.call(this, _props) || this;\n\n _this.onKeyUp = function () {\n _this.onEnd();\n };\n\n _this.onMouseUp = function () {\n _this.onEnd(_this.getMouseEventMap());\n };\n\n _this.onTouchEnd = function () {\n _this.onEnd(_this.getTouchEventMap());\n };\n\n _this.onBlur = function () {\n _this.setState({\n index: -1\n }, _this.onEnd(_this.getKeyDownEventMap()));\n };\n\n _this.onMouseMove = function (e) {\n // Prevent controlled updates from happening while mouse is moving\n _this.setState({\n pending: true\n });\n\n var position = _this.getMousePosition(e);\n\n var diffPosition = _this.getDiffPosition(position[0]);\n\n var newValue = _this.getValueFromPosition(diffPosition);\n\n _this.move(newValue);\n };\n\n _this.onTouchMove = function (e) {\n if (e.touches.length > 1) {\n return;\n } // Prevent controlled updates from happending while touch is moving\n\n\n _this.setState({\n pending: true\n });\n\n var position = _this.getTouchPosition(e);\n\n if (typeof _this.isScrolling === 'undefined') {\n var diffMainDir = position[0] - _this.startPosition[0];\n var diffScrollDir = position[1] - _this.startPosition[1];\n _this.isScrolling = Math.abs(diffScrollDir) > Math.abs(diffMainDir);\n }\n\n if (_this.isScrolling) {\n _this.setState({\n index: -1\n });\n\n return;\n }\n\n var diffPosition = _this.getDiffPosition(position[0]);\n\n var newValue = _this.getValueFromPosition(diffPosition);\n\n _this.move(newValue);\n };\n\n _this.onKeyDown = function (e) {\n if (e.ctrlKey || e.shiftKey || e.altKey || e.metaKey) {\n return;\n } // Prevent controlled updates from happening while a key is pressed\n\n\n _this.setState({\n pending: true\n });\n\n switch (e.key) {\n case 'ArrowLeft':\n case 'ArrowDown':\n case 'Left':\n case 'Down':\n e.preventDefault();\n\n _this.moveDownByStep();\n\n break;\n\n case 'ArrowRight':\n case 'ArrowUp':\n case 'Right':\n case 'Up':\n e.preventDefault();\n\n _this.moveUpByStep();\n\n break;\n\n case 'Home':\n e.preventDefault();\n\n _this.move(_this.props.min);\n\n break;\n\n case 'End':\n e.preventDefault();\n\n _this.move(_this.props.max);\n\n break;\n\n case 'PageDown':\n e.preventDefault();\n\n _this.moveDownByStep(_this.props.pageFn(_this.props.step));\n\n break;\n\n case 'PageUp':\n e.preventDefault();\n\n _this.moveUpByStep(_this.props.pageFn(_this.props.step));\n\n break;\n\n default:\n }\n };\n\n _this.onSliderMouseDown = function (e) {\n // do nothing if disabled or right click\n if (_this.props.disabled || e.button === 2) {\n return;\n } // Prevent controlled updates from happening while mouse is moving\n\n\n _this.setState({\n pending: true\n });\n\n if (!_this.props.snapDragDisabled) {\n var position = _this.getMousePosition(e);\n\n _this.forceValueFromPosition(position[0], function (i) {\n _this.start(i, position[0]);\n\n addHandlers(_this.getMouseEventMap());\n });\n }\n\n pauseEvent(e);\n };\n\n _this.onSliderClick = function (e) {\n if (_this.props.disabled) {\n return;\n }\n\n if (_this.props.onSliderClick && !_this.hasMoved) {\n var position = _this.getMousePosition(e);\n\n var valueAtPos = trimAlignValue(_this.calcValue(_this.calcOffsetFromPosition(position[0])), _this.props);\n\n _this.props.onSliderClick(valueAtPos);\n }\n };\n\n _this.createOnKeyDown = function (i) {\n return function (e) {\n if (_this.props.disabled) {\n return;\n }\n\n _this.start(i);\n\n addHandlers(_this.getKeyDownEventMap());\n pauseEvent(e);\n };\n };\n\n _this.createOnMouseDown = function (i) {\n return function (e) {\n // do nothing if disabled or right click\n if (_this.props.disabled || e.button === 2) {\n return;\n } // Prevent controlled updates from happending while mouse is moving\n\n\n _this.setState({\n pending: true\n });\n\n var position = _this.getMousePosition(e);\n\n _this.start(i, position[0]);\n\n addHandlers(_this.getMouseEventMap());\n pauseEvent(e);\n };\n };\n\n _this.createOnTouchStart = function (i) {\n return function (e) {\n if (_this.props.disabled || e.touches.length > 1) {\n return;\n } // Prevent controlled updates from happending while touch is moving\n\n\n _this.setState({\n pending: true\n });\n\n var position = _this.getTouchPosition(e);\n\n _this.startPosition = position; // don't know yet if the user is trying to scroll\n\n _this.isScrolling = undefined;\n\n _this.start(i, position[0]);\n\n addHandlers(_this.getTouchEventMap());\n stopPropagation(e);\n };\n };\n\n _this.handleResize = function () {\n // setTimeout of 0 gives element enough time to have assumed its new size if\n // it is being resized\n var resizeTimeout = window.setTimeout(function () {\n // drop this timeout from pendingResizeTimeouts to reduce memory usage\n _this.pendingResizeTimeouts.shift();\n\n _this.resize();\n }, 0);\n\n _this.pendingResizeTimeouts.push(resizeTimeout);\n };\n\n _this.renderThumb = function (style, i) {\n var className = _this.props.thumbClassName + \" \" + _this.props.thumbClassName + \"-\" + i + \" \" + (_this.state.index === i ? _this.props.thumbActiveClassName : '');\n var props = {\n 'ref': function ref(r) {\n _this[\"thumb\" + i] = r;\n },\n 'key': _this.props.thumbClassName + \"-\" + i,\n className: className,\n style: style,\n 'onMouseDown': _this.createOnMouseDown(i),\n 'onTouchStart': _this.createOnTouchStart(i),\n 'onFocus': _this.createOnKeyDown(i),\n 'tabIndex': 0,\n 'role': 'slider',\n 'aria-orientation': _this.props.orientation,\n 'aria-valuenow': _this.state.value[i],\n 'aria-valuemin': _this.props.min,\n 'aria-valuemax': _this.props.max,\n 'aria-label': Array.isArray(_this.props.ariaLabel) ? _this.props.ariaLabel[i] : _this.props.ariaLabel,\n 'aria-labelledby': Array.isArray(_this.props.ariaLabelledby) ? _this.props.ariaLabelledby[i] : _this.props.ariaLabelledby\n };\n var state = {\n index: i,\n value: prepareOutValue(_this.state.value),\n valueNow: _this.state.value[i]\n };\n\n if (_this.props.ariaValuetext) {\n props['aria-valuetext'] = typeof _this.props.ariaValuetext === 'string' ? _this.props.ariaValuetext : _this.props.ariaValuetext(state);\n }\n\n return _this.props.renderThumb(props, state);\n };\n\n _this.renderTrack = function (i, offsetFrom, offsetTo) {\n var props = {\n key: _this.props.trackClassName + \"-\" + i,\n className: _this.props.trackClassName + \" \" + _this.props.trackClassName + \"-\" + i,\n style: _this.buildTrackStyle(offsetFrom, _this.state.upperBound - offsetTo)\n };\n var state = {\n index: i,\n value: prepareOutValue(_this.state.value)\n };\n return _this.props.renderTrack(props, state);\n };\n\n var value = sanitizeInValue(_props.value);\n\n if (!value.length) {\n value = sanitizeInValue(_props.defaultValue);\n } // array for storing resize timeouts ids\n\n\n _this.pendingResizeTimeouts = [];\n var zIndices = [];\n\n for (var i = 0; i < value.length; i += 1) {\n value[i] = trimAlignValue(value[i], _props);\n zIndices.push(i);\n }\n\n _this.state = {\n index: -1,\n upperBound: 0,\n sliderLength: 0,\n value: value,\n zIndices: zIndices\n };\n return _this;\n }\n\n var _proto = ReactSlider.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n if (typeof window !== 'undefined') {\n window.addEventListener('resize', this.handleResize);\n this.resize();\n }\n } // Keep the internal `value` consistent with an outside `value` if present.\n // This basically allows the slider to be a controlled component.\n ;\n\n ReactSlider.getDerivedStateFromProps = function getDerivedStateFromProps(props, state) {\n var value = sanitizeInValue(props.value);\n\n if (!value.length) {\n return null;\n } // Do not allow controlled upates to happen while we have pending updates\n\n\n if (state.pending) {\n return null;\n }\n\n return {\n value: value.map(function (item) {\n return trimAlignValue(item, props);\n })\n };\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n // If an upperBound has not yet been determined (due to the component being hidden\n // during the mount event, or during the last resize), then calculate it now\n if (this.state.upperBound === 0) {\n this.resize();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.clearPendingResizeTimeouts();\n\n if (typeof window !== 'undefined') {\n window.removeEventListener('resize', this.handleResize);\n }\n };\n\n _proto.onEnd = function onEnd(eventMap) {\n if (eventMap) {\n removeHandlers(eventMap);\n }\n\n if (this.hasMoved) {\n this.fireChangeEvent('onAfterChange');\n } // Allow controlled updates to continue\n\n\n this.setState({\n pending: false\n });\n this.hasMoved = false;\n };\n\n _proto.getValue = function getValue() {\n return prepareOutValue(this.state.value);\n };\n\n _proto.getClosestIndex = function getClosestIndex(pixelOffset) {\n var minDist = Number.MAX_VALUE;\n var closestIndex = -1;\n var value = this.state.value;\n var l = value.length;\n\n for (var i = 0; i < l; i += 1) {\n var offset = this.calcOffset(value[i]);\n var dist = Math.abs(pixelOffset - offset);\n\n if (dist < minDist) {\n minDist = dist;\n closestIndex = i;\n }\n }\n\n return closestIndex;\n };\n\n _proto.getMousePosition = function getMousePosition(e) {\n return [e[\"page\" + this.axisKey()], e[\"page\" + this.orthogonalAxisKey()]];\n };\n\n _proto.getTouchPosition = function getTouchPosition(e) {\n var touch = e.touches[0];\n return [touch[\"page\" + this.axisKey()], touch[\"page\" + this.orthogonalAxisKey()]];\n };\n\n _proto.getKeyDownEventMap = function getKeyDownEventMap() {\n return {\n keydown: this.onKeyDown,\n keyup: this.onKeyUp,\n focusout: this.onBlur\n };\n };\n\n _proto.getMouseEventMap = function getMouseEventMap() {\n return {\n mousemove: this.onMouseMove,\n mouseup: this.onMouseUp\n };\n };\n\n _proto.getTouchEventMap = function getTouchEventMap() {\n return {\n touchmove: this.onTouchMove,\n touchend: this.onTouchEnd\n };\n };\n\n _proto.getValueFromPosition = function getValueFromPosition(position) {\n var diffValue = position / (this.state.sliderLength - this.state.thumbSize) * (this.props.max - this.props.min);\n return trimAlignValue(this.state.startValue + diffValue, this.props);\n };\n\n _proto.getDiffPosition = function getDiffPosition(position) {\n var diffPosition = position - this.state.startPosition;\n\n if (this.props.invert) {\n diffPosition *= -1;\n }\n\n return diffPosition;\n } // create the `keydown` handler for the i-th thumb\n ;\n\n _proto.resize = function resize() {\n var slider = this.slider,\n thumb = this.thumb0;\n\n if (!slider || !thumb) {\n return;\n }\n\n var sizeKey = this.sizeKey(); // For the slider size, we want to use the client width/height, excluding any borders\n\n var sliderRect = slider.getBoundingClientRect();\n var sliderSize = slider[sizeKey];\n var sliderMax = sliderRect[this.posMaxKey()];\n var sliderMin = sliderRect[this.posMinKey()]; // For the thumb size, we want to use the outer width/height, including any borders\n\n var thumbRect = thumb.getBoundingClientRect();\n var thumbSize = thumbRect[sizeKey.replace('client', '').toLowerCase()];\n var upperBound = sliderSize - thumbSize;\n var sliderLength = Math.abs(sliderMax - sliderMin);\n\n if (this.state.upperBound !== upperBound || this.state.sliderLength !== sliderLength || this.state.thumbSize !== thumbSize) {\n this.setState({\n upperBound: upperBound,\n sliderLength: sliderLength,\n thumbSize: thumbSize\n });\n }\n } // calculates the offset of a thumb in pixels based on its value.\n ;\n\n _proto.calcOffset = function calcOffset(value) {\n var range = this.props.max - this.props.min;\n\n if (range === 0) {\n return 0;\n }\n\n var ratio = (value - this.props.min) / range;\n return ratio * this.state.upperBound;\n } // calculates the value corresponding to a given pixel offset, i.e. the inverse of `calcOffset`.\n ;\n\n _proto.calcValue = function calcValue(offset) {\n var ratio = offset / this.state.upperBound;\n return ratio * (this.props.max - this.props.min) + this.props.min;\n };\n\n _proto.calcOffsetFromPosition = function calcOffsetFromPosition(position) {\n var slider = this.slider;\n var sliderRect = slider.getBoundingClientRect();\n var sliderMax = sliderRect[this.posMaxKey()];\n var sliderMin = sliderRect[this.posMinKey()]; // The `position` value passed in is the mouse position based on the window height.\n // The slider bounding rect is based on the viewport, so we must add the window scroll\n // offset to normalize the values.\n\n var windowOffset = window[\"page\" + this.axisKey() + \"Offset\"];\n var sliderStart = windowOffset + (this.props.invert ? sliderMax : sliderMin);\n var pixelOffset = position - sliderStart;\n\n if (this.props.invert) {\n pixelOffset = this.state.sliderLength - pixelOffset;\n }\n\n pixelOffset -= this.state.thumbSize / 2;\n return pixelOffset;\n } // Snaps the nearest thumb to the value corresponding to `position`\n // and calls `callback` with that thumb's index.\n ;\n\n _proto.forceValueFromPosition = function forceValueFromPosition(position, callback) {\n var _this2 = this;\n\n var pixelOffset = this.calcOffsetFromPosition(position);\n var closestIndex = this.getClosestIndex(pixelOffset);\n var nextValue = trimAlignValue(this.calcValue(pixelOffset), this.props); // Clone this.state.value since we'll modify it temporarily\n // eslint-disable-next-line zillow/react/no-access-state-in-setstate\n\n var value = this.state.value.slice();\n value[closestIndex] = nextValue; // Prevents the slider from shrinking below `props.minDistance`\n\n for (var i = 0; i < value.length - 1; i += 1) {\n if (value[i + 1] - value[i] < this.props.minDistance) {\n return;\n }\n }\n\n this.fireChangeEvent('onBeforeChange');\n this.hasMoved = true;\n this.setState({\n value: value\n }, function () {\n callback(closestIndex);\n\n _this2.fireChangeEvent('onChange');\n });\n } // clear all pending timeouts to avoid error messages after unmounting\n ;\n\n _proto.clearPendingResizeTimeouts = function clearPendingResizeTimeouts() {\n do {\n var nextTimeout = this.pendingResizeTimeouts.shift();\n clearTimeout(nextTimeout);\n } while (this.pendingResizeTimeouts.length);\n };\n\n _proto.start = function start(i, position) {\n var thumbRef = this[\"thumb\" + i];\n\n if (thumbRef) {\n thumbRef.focus();\n }\n\n var zIndices = this.state.zIndices; // remove wherever the element is\n\n zIndices.splice(zIndices.indexOf(i), 1); // add to end\n\n zIndices.push(i);\n this.setState(function (prevState) {\n return {\n startValue: prevState.value[i],\n startPosition: position !== undefined ? position : prevState.startPosition,\n index: i,\n zIndices: zIndices\n };\n });\n };\n\n _proto.moveUpByStep = function moveUpByStep(step) {\n if (step === void 0) {\n step = this.props.step;\n }\n\n var oldValue = this.state.value[this.state.index];\n var newValue = trimAlignValue(oldValue + step, this.props);\n this.move(Math.min(newValue, this.props.max));\n };\n\n _proto.moveDownByStep = function moveDownByStep(step) {\n if (step === void 0) {\n step = this.props.step;\n }\n\n var oldValue = this.state.value[this.state.index];\n var newValue = trimAlignValue(oldValue - step, this.props);\n this.move(Math.max(newValue, this.props.min));\n };\n\n _proto.move = function move(newValue) {\n var _this$state = this.state,\n index = _this$state.index,\n value = _this$state.value;\n var length = value.length; // Short circuit if the value is not changing\n\n var oldValue = value[index];\n\n if (newValue === oldValue) {\n return;\n } // Trigger only before the first movement\n\n\n if (!this.hasMoved) {\n this.fireChangeEvent('onBeforeChange');\n }\n\n this.hasMoved = true; // if \"pearling\" (= thumbs pushing each other) is disabled,\n // prevent the thumb from getting closer than `minDistance` to the previous or next thumb.\n\n var _this$props = this.props,\n pearling = _this$props.pearling,\n max = _this$props.max,\n min = _this$props.min,\n minDistance = _this$props.minDistance;\n\n if (!pearling) {\n if (index > 0) {\n var valueBefore = value[index - 1];\n\n if (newValue < valueBefore + minDistance) {\n // eslint-disable-next-line no-param-reassign\n newValue = valueBefore + minDistance;\n }\n }\n\n if (index < length - 1) {\n var valueAfter = value[index + 1];\n\n if (newValue > valueAfter - minDistance) {\n // eslint-disable-next-line no-param-reassign\n newValue = valueAfter - minDistance;\n }\n }\n }\n\n value[index] = newValue; // if \"pearling\" is enabled, let the current thumb push the pre- and succeeding thumbs.\n\n if (pearling && length > 1) {\n if (newValue > oldValue) {\n this.pushSucceeding(value, minDistance, index);\n trimSucceeding(length, value, minDistance, max);\n } else if (newValue < oldValue) {\n this.pushPreceding(value, minDistance, index);\n trimPreceding(length, value, minDistance, min);\n }\n } // Normally you would use `shouldComponentUpdate`,\n // but since the slider is a low-level component,\n // the extra complexity might be worth the extra performance.\n\n\n this.setState({\n value: value\n }, this.fireChangeEvent.bind(this, 'onChange'));\n };\n\n _proto.pushSucceeding = function pushSucceeding(value, minDistance, index) {\n var i;\n var padding;\n\n for (i = index, padding = value[i] + minDistance; value[i + 1] !== null && padding > value[i + 1]; i += 1, padding = value[i] + minDistance) {\n // eslint-disable-next-line no-param-reassign\n value[i + 1] = alignValue(padding, this.props);\n }\n };\n\n _proto.pushPreceding = function pushPreceding(value, minDistance, index) {\n for (var i = index, padding = value[i] - minDistance; value[i - 1] !== null && padding < value[i - 1]; i -= 1, padding = value[i] - minDistance) {\n // eslint-disable-next-line no-param-reassign\n value[i - 1] = alignValue(padding, this.props);\n }\n };\n\n _proto.axisKey = function axisKey() {\n if (this.props.orientation === 'vertical') {\n return 'Y';\n } // Defaults to 'horizontal';\n\n\n return 'X';\n };\n\n _proto.orthogonalAxisKey = function orthogonalAxisKey() {\n if (this.props.orientation === 'vertical') {\n return 'X';\n } // Defaults to 'horizontal'\n\n\n return 'Y';\n };\n\n _proto.posMinKey = function posMinKey() {\n if (this.props.orientation === 'vertical') {\n return this.props.invert ? 'bottom' : 'top';\n } // Defaults to 'horizontal'\n\n\n return this.props.invert ? 'right' : 'left';\n };\n\n _proto.posMaxKey = function posMaxKey() {\n if (this.props.orientation === 'vertical') {\n return this.props.invert ? 'top' : 'bottom';\n } // Defaults to 'horizontal'\n\n\n return this.props.invert ? 'left' : 'right';\n };\n\n _proto.sizeKey = function sizeKey() {\n if (this.props.orientation === 'vertical') {\n return 'clientHeight';\n } // Defaults to 'horizontal'\n\n\n return 'clientWidth';\n };\n\n _proto.fireChangeEvent = function fireChangeEvent(event) {\n if (this.props[event]) {\n this.props[event](prepareOutValue(this.state.value), this.state.index);\n }\n };\n\n _proto.buildThumbStyle = function buildThumbStyle(offset, i) {\n var style = {\n position: 'absolute',\n touchAction: 'none',\n willChange: this.state.index >= 0 ? this.posMinKey() : '',\n zIndex: this.state.zIndices.indexOf(i) + 1\n };\n style[this.posMinKey()] = offset + \"px\";\n return style;\n };\n\n _proto.buildTrackStyle = function buildTrackStyle(min, max) {\n var obj = {\n position: 'absolute',\n willChange: this.state.index >= 0 ? this.posMinKey() + \",\" + this.posMaxKey() : ''\n };\n obj[this.posMinKey()] = min;\n obj[this.posMaxKey()] = max;\n return obj;\n };\n\n _proto.buildMarkStyle = function buildMarkStyle(offset) {\n var _ref;\n\n return _ref = {\n position: 'absolute'\n }, _ref[this.posMinKey()] = offset, _ref;\n };\n\n _proto.renderThumbs = function renderThumbs(offset) {\n var length = offset.length;\n var styles = [];\n\n for (var i = 0; i < length; i += 1) {\n styles[i] = this.buildThumbStyle(offset[i], i);\n }\n\n var res = [];\n\n for (var _i = 0; _i < length; _i += 1) {\n res[_i] = this.renderThumb(styles[_i], _i);\n }\n\n return res;\n };\n\n _proto.renderTracks = function renderTracks(offset) {\n var tracks = [];\n var lastIndex = offset.length - 1;\n tracks.push(this.renderTrack(0, 0, offset[0]));\n\n for (var i = 0; i < lastIndex; i += 1) {\n tracks.push(this.renderTrack(i + 1, offset[i], offset[i + 1]));\n }\n\n tracks.push(this.renderTrack(lastIndex + 1, offset[lastIndex], this.state.upperBound));\n return tracks;\n };\n\n _proto.renderMarks = function renderMarks() {\n var _this3 = this;\n\n var marks = this.props.marks;\n var range = this.props.max - this.props.min + 1;\n\n if (typeof marks === 'boolean') {\n marks = Array.from({\n length: range\n }).map(function (_, key) {\n return key;\n });\n } else if (typeof marks === 'number') {\n marks = Array.from({\n length: range\n }).map(function (_, key) {\n return key;\n }).filter(function (key) {\n return key % marks === 0;\n });\n }\n\n return marks.map(parseFloat).sort(function (a, b) {\n return a - b;\n }).map(function (mark) {\n var offset = _this3.calcOffset(mark);\n\n var props = {\n key: mark,\n className: _this3.props.markClassName,\n style: _this3.buildMarkStyle(offset)\n };\n return _this3.props.renderMark(props);\n });\n };\n\n _proto.render = function render() {\n var _this4 = this;\n\n var offset = [];\n var value = this.state.value;\n var l = value.length;\n\n for (var i = 0; i < l; i += 1) {\n offset[i] = this.calcOffset(value[i], i);\n }\n\n var tracks = this.props.withTracks ? this.renderTracks(offset) : null;\n var thumbs = this.renderThumbs(offset);\n var marks = this.props.marks ? this.renderMarks() : null;\n return /*#__PURE__*/React.createElement('div', {\n ref: function ref(r) {\n _this4.slider = r;\n },\n style: {\n position: 'relative'\n },\n className: this.props.className + (this.props.disabled ? ' disabled' : ''),\n onMouseDown: this.onSliderMouseDown,\n onClick: this.onSliderClick\n }, tracks, thumbs, marks);\n };\n\n return ReactSlider;\n}(React.Component);\n\nReactSlider.displayName = 'ReactSlider';\nReactSlider.defaultProps = {\n min: 0,\n max: 100,\n step: 1,\n pageFn: function pageFn(step) {\n return step * 10;\n },\n minDistance: 0,\n defaultValue: 0,\n orientation: 'horizontal',\n className: 'slider',\n thumbClassName: 'thumb',\n thumbActiveClassName: 'active',\n trackClassName: 'track',\n markClassName: 'mark',\n withTracks: true,\n pearling: false,\n disabled: false,\n snapDragDisabled: false,\n invert: false,\n marks: [],\n renderThumb: function renderThumb(props) {\n return /*#__PURE__*/React.createElement(\"div\", _extends({}, props, {\n __self: ReactSlider,\n __source: {\n fileName: _jsxFileName,\n lineNumber: 353,\n columnNumber: 31\n }\n }));\n },\n renderTrack: function renderTrack(props) {\n return /*#__PURE__*/React.createElement(\"div\", _extends({}, props, {\n __self: ReactSlider,\n __source: {\n fileName: _jsxFileName,\n lineNumber: 354,\n columnNumber: 31\n }\n }));\n },\n renderMark: function renderMark(props) {\n return /*#__PURE__*/React.createElement(\"span\", _extends({}, props, {\n __self: ReactSlider,\n __source: {\n fileName: _jsxFileName,\n lineNumber: 355,\n columnNumber: 30\n }\n }));\n }\n};\nexport default ReactSlider;"],"sourceRoot":""}