UNPKG

react-misc-toolbox

Version:

[ ] imageviewer | gradual scroll [ ] imageviewer | cancellable scroll

274 lines (209 loc) 10.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _regenerator = require('babel-runtime/regenerator'); var _regenerator2 = _interopRequireDefault(_regenerator); var _asyncToGenerator2 = require('babel-runtime/helpers/asyncToGenerator'); var _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2); var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _ScrollNavHorizontal$; var _style = require('styled-jsx/style'); var _style2 = _interopRequireDefault(_style); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _SVGPrev = require('./svg/SVGPrev'); var _SVGPrev2 = _interopRequireDefault(_SVGPrev); var _SVGNext = require('./svg/SVGNext'); var _SVGNext2 = _interopRequireDefault(_SVGNext); var _recompose = require('recompose'); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _RTGCSSTransitionFade = require('./RTGCSSTransitionFade'); var _RTGCSSTransitionFade2 = _interopRequireDefault(_RTGCSSTransitionFade); var _helperFunctions = require('./helperFunctions'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var interval = void 0; var ScrollNavHorizontal = function (_React$Component) { (0, _inherits3.default)(ScrollNavHorizontal, _React$Component); function ScrollNavHorizontal() { var _ref, _this2 = this; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, ScrollNavHorizontal); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = ScrollNavHorizontal.__proto__ || (0, _getPrototypeOf2.default)(ScrollNavHorizontal)).call.apply(_ref, [this].concat(args))), _this), _this.handleScroll = (0, _asyncToGenerator3.default)( /*#__PURE__*/_regenerator2.default.mark(function _callee() { var _this$props, containerClass, containerRef, leeway, setShowLeft, setShowRight, showLog, containerElement; return _regenerator2.default.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _this$props = _this.props, containerClass = _this$props.containerClass, containerRef = _this$props.containerRef, leeway = _this$props.leeway, setShowLeft = _this$props.setShowLeft, setShowRight = _this$props.setShowRight, showLog = _this$props.showLog; containerElement = (0, _helperFunctions.getElement)({ ref: containerRef, className: containerClass }); _context.next = 4; return (0, _helperFunctions.delay)(500); case 4: showLog && console.log('// handleScroll // ', 'containerElement.scrollLeft + leeway: ', containerElement.scrollLeft + leeway, 'scrollWidth: ', containerElement.scrollWidth, 'clientWidth: ', containerElement.clientWidth, 'diff: ', containerElement.scrollWidth - containerElement.clientWidth); if (!(containerElement.scrollLeft === 0 || containerElement.scrollWidth === containerElement.clientWidth)) { _context.next = 11; break; } _context.next = 8; return setShowLeft(false); case 8: clearInterval(interval); _context.next = 14; break; case 11: if (!(containerElement.scrollLeft > 0)) { _context.next = 14; break; } _context.next = 14; return setShowLeft(true); case 14: if (!(containerElement.scrollLeft + leeway >= containerElement.scrollWidth - containerElement.clientWidth || containerElement.scrollWidth === containerElement.clientWidth)) { _context.next = 20; break; } _context.next = 17; return setShowRight(false); case 17: clearInterval(interval); _context.next = 23; break; case 20: if (!(containerElement.scrollWidth >= containerElement.clientWidth)) { _context.next = 23; break; } _context.next = 23; return setShowRight(true); case 23: case 'end': return _context.stop(); } } }, _callee, _this2); })), _this.renderNav = function (direction) { var _this$props2 = _this.props, containerClass = _this$props2.containerClass, height = _this$props2.height, width = _this$props2.width, showLeft = _this$props2.showLeft, showRight = _this$props2.showRight, containerRef = _this$props2.containerRef; var containerElement = (0, _helperFunctions.getElement)({ ref: containerRef, className: containerClass }); var autoHeight = containerElement && containerElement.clientHeight; var autoWidth = 18; var startScroll = function startScroll(e) { e.stopPropagation(); clearInterval(interval); if (containerElement) { interval = setInterval(function () { return direction === 'left' ? containerElement.scrollLeft -= 20 : containerElement.scrollLeft += 20; }, 50); } }; var endScroll = function endScroll(e) { e.stopPropagation(); clearInterval(interval); }; return _react2.default.createElement( _RTGCSSTransitionFade2.default, { style: { width: width ? width : autoWidth, height: height ? height : autoHeight }, onMouseDown: function onMouseDown(e) { return startScroll(e); }, onMouseUp: function onMouseUp(e) { return endScroll(e); }, onTouchStart: function onTouchStart(e) { return startScroll(e); }, onTouchEnd: function onTouchEnd(e) { return endScroll(e); }, className: 'scrollnavhorizontal__scroller scrollnavhorizontal__scroller--' + direction, 'in': direction === 'left' ? showLeft : showRight }, _react2.default.createElement(_style2.default, { styleId: '1090513052', css: '.scrollnavhorizontal__scroller{-webkit-transition:opacity 1000ms ease-in-out,background-color 300ms ease-out;transition:opacity 1000ms ease-in-out,background-color 300ms ease-out;background-color:rgba(89,27,100,0.521);z-index:3;height:10rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;cursor:pointer;}.scrollnavhorizontal__scroller svg{background:white;}.scrollnavhorizontal__scroller:hover{background-color:rgba(89,27,100,0.267);}.scrollnavhorizontal__scroller:active{background-color:#591b64;}.scrollnavhorizontal__scroller--left{left:0;}.scrollnavhorizontal__scroller--right{right:0;}' }), direction === 'left' ? _react2.default.createElement(_SVGPrev2.default, { size: width ? width : autoWidth }) : _react2.default.createElement(_SVGNext2.default, { size: width ? width : autoWidth }) ); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(ScrollNavHorizontal, [{ key: 'componentDidMount', value: function componentDidMount() { var _props = this.props, containerClass = _props.containerClass, containerRef = _props.containerRef; this.handleScroll(); var containerElement = (0, _helperFunctions.getElement)({ ref: containerRef, className: containerClass }); containerElement.addEventListener('scroll', this.handleScroll); window.addEventListener('resize', this.handleScroll); } }, { key: 'componentDidUpdate', value: function componentDidUpdate(prevProps) { prevProps.numberOfItems !== this.props.numberOfItems && this.handleScroll(); } }, { key: 'componentWillUnmount', value: function componentWillUnmount() { clearInterval(interval); var _props2 = this.props, containerClass = _props2.containerClass, containerRef = _props2.containerRef; var containerElement = (0, _helperFunctions.getElement)({ ref: containerRef, className: containerClass }); containerElement.removeEventListener('scroll', this.handleScroll); window.removeEventListener('resize', this.handleScroll); } }, { key: 'render', value: function render() { return typeof window !== 'undefined' && _react2.default.createElement( _react2.default.Fragment, null, this.renderNav('left'), this.props.children, this.renderNav('right') ); } }]); return ScrollNavHorizontal; }(_react2.default.Component); ScrollNavHorizontal.defaultProps = { showLog: false, leeway: 0 }; ScrollNavHorizontal.propTypes = (_ScrollNavHorizontal$ = { containerClass: _propTypes2.default.string, leeway: _propTypes2.default.number, width: _propTypes2.default.number, showLeft: _propTypes2.default.bool.isRequired, showRight: _propTypes2.default.bool.isRequired, setShowLeft: _propTypes2.default.func.isRequired }, (0, _defineProperty3.default)(_ScrollNavHorizontal$, 'setShowLeft', _propTypes2.default.func.isRequired), (0, _defineProperty3.default)(_ScrollNavHorizontal$, 'numberOfItems', _propTypes2.default.number), _ScrollNavHorizontal$); var enhance = (0, _recompose.compose)((0, _recompose.withState)('showLeft', 'setShowLeft', false), (0, _recompose.withState)('showRight', 'setShowRight', false), (0, _recompose.onlyUpdateForKeys)(['showLeft', 'showRight', 'numberOfItems', 'children'])); exports.default = enhance(ScrollNavHorizontal);