react-reflex
Version:
Flex layout component for advanced React web applications
191 lines (163 loc) • 5.34 kB
JavaScript
import _extends from "@babel/runtime/helpers/extends";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
///////////////////////////////////////////////////////////
// ReflexSplitter
// By Philippe Leefsma
// December 2016
//
///////////////////////////////////////////////////////////
import { Browser, getDataProps } from './utilities';
import PropTypes from 'prop-types';
import ReactDOM from 'react-dom';
import React from 'react';
export default class ReflexSplitter extends React.Component {
/////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
static isA(element) {
if (!element) {
return false;
} //https://github.com/leefsmp/Re-Flex/issues/49
return process.env.NODE_ENV === 'development' ? element.type === React.createElement(ReflexSplitter, null).type : element.type === ReflexSplitter;
} /////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
constructor(props) {
super(props);
_defineProperty(this, "onMouseMove", event => {
if (this.state.active) {
this.props.events.emit('resize', {
index: this.props.index,
event
});
if (this.props.onResize) {
this.props.onResize({
domElement: ReactDOM.findDOMNode(this),
component: this
});
}
event.stopPropagation();
event.preventDefault();
}
});
_defineProperty(this, "onMouseDown", 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.findDOMNode(this),
component: this
})) {
return;
}
}
this.props.events.emit('startResize', {
index: this.props.index,
event
});
});
_defineProperty(this, "onMouseUp", event => {
if (this.state.active) {
this.setState({
active: false
});
if (this.props.onStopResize) {
this.props.onStopResize({
domElement: ReactDOM.findDOMNode(this),
component: this
});
}
this.props.events.emit('stopResize', {
index: this.props.index,
event
});
}
});
this.state = {
active: false
};
this.document = props.document;
} /////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
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
});
} /////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
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
});
}
} /////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
render() {
const className = [Browser.isMobile() ? 'reflex-thin' : '', ...this.props.className.split(' '), this.state.active ? 'active' : '', 'reflex-splitter'].join(' ').trim();
return React.createElement("div", _extends({}, getDataProps(this.props), {
onTouchStart: this.onMouseDown,
onMouseDown: this.onMouseDown,
style: this.props.style,
className: className,
id: this.props.id
}), this.props.children);
}
}
_defineProperty(ReflexSplitter, "propTypes", {
children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),
onStartResize: PropTypes.func,
onStopResize: PropTypes.func,
className: PropTypes.string,
propagate: PropTypes.bool,
onResize: PropTypes.func,
style: PropTypes.object /////////////////////////////////////////////////////////
//
//
/////////////////////////////////////////////////////////
});
_defineProperty(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
//
/////////////////////////////////////////////////////////
});