react-perfect-scrollbar
Version:
A react wrapper for perfect-scrollbar
232 lines (196 loc) • 8.72 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _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; };
var _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; }; }();
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _perfectScrollbar = require('perfect-scrollbar');
var _perfectScrollbar2 = _interopRequireDefault(_perfectScrollbar);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _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; }
function _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; }
var handlerNameByEvent = {
'ps-scroll-y': 'onScrollY',
'ps-scroll-x': 'onScrollX',
'ps-scroll-up': 'onScrollUp',
'ps-scroll-down': 'onScrollDown',
'ps-scroll-left': 'onScrollLeft',
'ps-scroll-right': 'onScrollRight',
'ps-y-reach-start': 'onYReachStart',
'ps-y-reach-end': 'onYReachEnd',
'ps-x-reach-start': 'onXReachStart',
'ps-x-reach-end': 'onXReachEnd'
};
Object.freeze(handlerNameByEvent);
var ScrollBar = function (_Component) {
_inherits(ScrollBar, _Component);
function ScrollBar(props) {
_classCallCheck(this, ScrollBar);
var _this = _possibleConstructorReturn(this, (ScrollBar.__proto__ || Object.getPrototypeOf(ScrollBar)).call(this, props));
_this.handleRef = _this.handleRef.bind(_this);
_this._handlerByEvent = {};
return _this;
}
_createClass(ScrollBar, [{
key: 'componentDidMount',
value: function componentDidMount() {
if (this.props.option) {
console.warn('react-perfect-scrollbar: the "option" prop has been deprecated in favor of "options"');
}
this._ps = new _perfectScrollbar2.default(this._container, this.props.options || this.props.option);
// hook up events
this._updateEventHook();
this._updateClassName();
}
}, {
key: 'componentDidUpdate',
value: function componentDidUpdate(prevProps) {
this._updateEventHook(prevProps);
this.updateScroll();
if (prevProps.className !== this.props.className) {
this._updateClassName();
}
}
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
var _this2 = this;
// unhook up evens
Object.keys(this._handlerByEvent).forEach(function (key) {
var value = _this2._handlerByEvent[key];
if (value) {
_this2._container.removeEventListener(key, value, false);
}
});
this._handlerByEvent = {};
this._ps.destroy();
this._ps = null;
}
}, {
key: '_updateEventHook',
value: function _updateEventHook() {
var _this3 = this;
var prevProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
// hook up events
Object.keys(handlerNameByEvent).forEach(function (key) {
var callback = _this3.props[handlerNameByEvent[key]];
var prevCallback = prevProps[handlerNameByEvent[key]];
if (callback !== prevCallback) {
if (prevCallback) {
var prevHandler = _this3._handlerByEvent[key];
_this3._container.removeEventListener(key, prevHandler, false);
_this3._handlerByEvent[key] = null;
}
if (callback) {
var handler = function handler() {
return callback(_this3._container);
};
_this3._container.addEventListener(key, handler, false);
_this3._handlerByEvent[key] = handler;
}
}
});
}
}, {
key: '_updateClassName',
value: function _updateClassName() {
var className = this.props.className;
var psClassNames = this._container.className.split(' ').filter(function (name) {
return name.match(/^ps([-_].+|)$/);
}).join(' ');
if (this._container) {
this._container.className = 'scrollbar-container' + (className ? ' ' + className : '') + (psClassNames ? ' ' + psClassNames : '');
}
}
}, {
key: 'updateScroll',
value: function updateScroll() {
this.props.onSync(this._ps);
}
}, {
key: 'handleRef',
value: function handleRef(ref) {
this._container = ref;
this.props.containerRef(ref);
}
}, {
key: 'render',
value: function render() {
var _props = this.props,
className = _props.className,
style = _props.style,
option = _props.option,
options = _props.options,
containerRef = _props.containerRef,
onScrollY = _props.onScrollY,
onScrollX = _props.onScrollX,
onScrollUp = _props.onScrollUp,
onScrollDown = _props.onScrollDown,
onScrollLeft = _props.onScrollLeft,
onScrollRight = _props.onScrollRight,
onYReachStart = _props.onYReachStart,
onYReachEnd = _props.onYReachEnd,
onXReachStart = _props.onXReachStart,
onXReachEnd = _props.onXReachEnd,
component = _props.component,
onSync = _props.onSync,
children = _props.children,
remainProps = _objectWithoutProperties(_props, ['className', 'style', 'option', 'options', 'containerRef', 'onScrollY', 'onScrollX', 'onScrollUp', 'onScrollDown', 'onScrollLeft', 'onScrollRight', 'onYReachStart', 'onYReachEnd', 'onXReachStart', 'onXReachEnd', 'component', 'onSync', 'children']);
var Comp = component;
return _react2.default.createElement(
Comp,
_extends({ style: style, ref: this.handleRef }, remainProps),
children
);
}
}]);
return ScrollBar;
}(_react.Component);
exports.default = ScrollBar;
ScrollBar.defaultProps = {
className: '',
style: undefined,
option: undefined,
options: undefined,
containerRef: function containerRef() {},
onScrollY: undefined,
onScrollX: undefined,
onScrollUp: undefined,
onScrollDown: undefined,
onScrollLeft: undefined,
onScrollRight: undefined,
onYReachStart: undefined,
onYReachEnd: undefined,
onXReachStart: undefined,
onXReachEnd: undefined,
onSync: function onSync(ps) {
return ps.update();
},
component: 'div'
};
ScrollBar.propTypes = {
children: _propTypes.PropTypes.node.isRequired,
className: _propTypes.PropTypes.string,
style: _propTypes.PropTypes.object,
option: _propTypes.PropTypes.object,
options: _propTypes.PropTypes.object,
containerRef: _propTypes.PropTypes.func,
onScrollY: _propTypes.PropTypes.func,
onScrollX: _propTypes.PropTypes.func,
onScrollUp: _propTypes.PropTypes.func,
onScrollDown: _propTypes.PropTypes.func,
onScrollLeft: _propTypes.PropTypes.func,
onScrollRight: _propTypes.PropTypes.func,
onYReachStart: _propTypes.PropTypes.func,
onYReachEnd: _propTypes.PropTypes.func,
onXReachStart: _propTypes.PropTypes.func,
onXReachEnd: _propTypes.PropTypes.func,
onSync: _propTypes.PropTypes.func,
component: _propTypes.PropTypes.string
};
module.exports = exports['default'];