@material-ui/core
Version:
React components that implement Google's Material Design.
119 lines (96 loc) • 3.82 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/builtin/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/builtin/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/builtin/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/builtin/possibleConstructorReturn"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/builtin/inherits"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _reactEventListener = _interopRequireDefault(require("react-event-listener"));
var _debounce = _interopRequireDefault(require("debounce"));
var styles = {
width: '100px',
height: '100px',
position: 'absolute',
top: '-10000px',
overflow: 'scroll',
msOverflowStyle: 'scrollbar'
};
/**
* @ignore - internal component.
* The component is originates from https://github.com/STORIS/react-scrollbar-size.
* It has been moved into the core in order to minimize the bundle size.
*/
var ScrollbarSize =
/*#__PURE__*/
function (_React$Component) {
(0, _inherits2.default)(ScrollbarSize, _React$Component);
function ScrollbarSize() {
var _ref;
var _temp, _this;
(0, _classCallCheck2.default)(this, ScrollbarSize);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return (0, _possibleConstructorReturn2.default)(_this, (_temp = _this = (0, _possibleConstructorReturn2.default)(this, (_ref = ScrollbarSize.__proto__ || Object.getPrototypeOf(ScrollbarSize)).call.apply(_ref, [this].concat(args))), _this.setMeasurements = function () {
if (!_this.node) {
return;
}
_this.scrollbarHeight = _this.node.offsetHeight - _this.node.clientHeight;
_this.scrollbarWidth = _this.node.offsetWidth - _this.node.clientWidth;
}, _this.handleResize = (0, _debounce.default)(function () {
var onChange = _this.props.onChange;
var prevHeight = _this.scrollbarHeight;
var prevWidth = _this.scrollbarWidth;
_this.setMeasurements();
if (prevHeight !== _this.scrollbarHeight || prevWidth !== _this.scrollbarWidth) {
onChange({
scrollbarHeight: _this.scrollbarHeight,
scrollbarWidth: _this.scrollbarWidth
});
}
}, 166), _temp));
}
(0, _createClass2.default)(ScrollbarSize, [{
key: "componentDidMount",
value: function componentDidMount() {
this.setMeasurements();
this.props.onLoad({
scrollbarHeight: this.scrollbarHeight,
scrollbarWidth: this.scrollbarWidth
});
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
this.handleResize.clear();
}
}, {
key: "render",
// Corresponds to 10 frames at 60 Hz.
value: function render() {
var _this2 = this;
var onChange = this.props.onChange;
return _react.default.createElement("div", null, onChange ? _react.default.createElement(_reactEventListener.default, {
target: "window",
onResize: this.handleResize
}) : null, _react.default.createElement("div", {
style: styles,
ref: function ref(node) {
_this2.node = node;
}
}));
}
}]);
return ScrollbarSize;
}(_react.default.Component);
ScrollbarSize.propTypes = process.env.NODE_ENV !== "production" ? {
onChange: _propTypes.default.func.isRequired,
onLoad: _propTypes.default.func.isRequired
} : {};
var _default = ScrollbarSize;
exports.default = _default;
;