UNPKG

react-reflex

Version:

Flex layout component for advanced React web applications

231 lines (194 loc) 8.18 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _utilities = require("./utilities"); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactDom = _interopRequireDefault(require("react-dom")); var _react = _interopRequireDefault(require("react")); /////////////////////////////////////////////////////////// // ReflexSplitter // By Philippe Leefsma // December 2016 // /////////////////////////////////////////////////////////// var ReflexSplitter = /*#__PURE__*/ function (_React$Component) { (0, _inherits2.default)(ReflexSplitter, _React$Component); (0, _createClass2.default)(ReflexSplitter, null, [{ key: "isA", ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// value: function isA(element) { if (!element) { return false; } //https://github.com/leefsmp/Re-Flex/issues/49 return process.env.NODE_ENV === 'development' ? element.type === _react.default.createElement(ReflexSplitter, null).type : element.type === ReflexSplitter; } ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// }]); function ReflexSplitter(props) { var _this; (0, _classCallCheck2.default)(this, ReflexSplitter); _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(ReflexSplitter).call(this, props)); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "onMouseMove", function (event) { if (_this.state.active) { _this.props.events.emit('resize', { index: _this.props.index, event: event }); if (_this.props.onResize) { _this.props.onResize({ domElement: _reactDom.default.findDOMNode((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this))), component: (0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)) }); } event.stopPropagation(); event.preventDefault(); } }); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "onMouseDown", function (event) { _this.setState({ active: true }); if (_this.props.onStartResize) { // cancels resize from controller // if needed by returning true // to onStartResize if (_this.props.onStartResize({ domElement: _reactDom.default.findDOMNode((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this))), component: (0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)) })) { return; } } _this.props.events.emit('startResize', { index: _this.props.index, event: event }); }); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "onMouseUp", function (event) { if (_this.state.active) { _this.setState({ active: false }); if (_this.props.onStopResize) { _this.props.onStopResize({ domElement: _reactDom.default.findDOMNode((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this))), component: (0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)) }); } _this.props.events.emit('stopResize', { index: _this.props.index, event: event }); } }); _this.state = { active: false }; _this.document = props.document; return _this; } ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// (0, _createClass2.default)(ReflexSplitter, [{ key: "componentDidMount", value: function componentDidMount() { if (!this.document) { return; } this.document.addEventListener('touchend', this.onMouseUp); this.document.addEventListener('mouseup', this.onMouseUp); this.document.addEventListener('mousemove', this.onMouseMove, { passive: false }); this.document.addEventListener('touchmove', this.onMouseMove, { passive: false }); } ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// }, { key: "componentWillUnmount", value: function componentWillUnmount() { if (!this.document) { return; } this.document.removeEventListener('mouseup', this.onMouseUp); this.document.removeEventListener('touchend', this.onMouseUp); this.document.removeEventListener('mousemove', this.onMouseMove); this.document.removeEventListener('touchmove', this.onMouseMove); if (this.state.active) { this.props.events.emit('stopResize', { index: this.props.index, event: null }); } } ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// }, { key: "render", ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// value: function render() { var className = [_utilities.Browser.isMobile() ? 'reflex-thin' : ''].concat((0, _toConsumableArray2.default)(this.props.className.split(' ')), [this.state.active ? 'active' : '', 'reflex-splitter']).join(' ').trim(); return _react.default.createElement("div", (0, _extends2.default)({}, (0, _utilities.getDataProps)(this.props), { onTouchStart: this.onMouseDown, onMouseDown: this.onMouseDown, style: this.props.style, className: className, id: this.props.id }), this.props.children); } }]); return ReflexSplitter; }(_react.default.Component); exports.default = ReflexSplitter; (0, _defineProperty2.default)(ReflexSplitter, "propTypes", { children: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.node), _propTypes.default.node]), onStartResize: _propTypes.default.func, onStopResize: _propTypes.default.func, className: _propTypes.default.string, propagate: _propTypes.default.bool, onResize: _propTypes.default.func, style: _propTypes.default.object ///////////////////////////////////////////////////////// // // ///////////////////////////////////////////////////////// }); (0, _defineProperty2.default)(ReflexSplitter, "defaultProps", { document: typeof document !== 'undefined' ? document : null, onStartResize: null, onStopResize: null, propagate: false, onResize: null, className: '', style: {} ///////////////////////////////////////////////////////// // Determines if element is a splitter // or wraps a splitter // ///////////////////////////////////////////////////////// });