mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-23 01:45:05 +08:00
62 lines
1.3 KiB
TypeScript
62 lines
1.3 KiB
TypeScript
import * as React from 'react';
|
|
import { findDOMNode } from 'react-dom';
|
|
import ResizeObserver from 'resize-observer-polyfill';
|
|
|
|
type DomElement = Element | null;
|
|
|
|
interface ResizeObserverProps {
|
|
children?: React.ReactNode;
|
|
disabled?: boolean;
|
|
onResize?: () => void;
|
|
}
|
|
|
|
class ReactResizeObserver extends React.Component<ResizeObserverProps, {}> {
|
|
resizeObserver: ResizeObserver | null = null;
|
|
|
|
componentDidMount() {
|
|
this.onComponentUpdated();
|
|
}
|
|
|
|
componentDidUpdate() {
|
|
this.onComponentUpdated();
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
this.destroyObserver();
|
|
}
|
|
|
|
onComponentUpdated() {
|
|
const { disabled } = this.props;
|
|
const element = findDOMNode(this) as DomElement;
|
|
if (!this.resizeObserver && !disabled && element) {
|
|
// Add resize observer
|
|
this.resizeObserver = new ResizeObserver(this.onResize);
|
|
this.resizeObserver.observe(element);
|
|
} else if (disabled) {
|
|
// Remove resize observer
|
|
this.destroyObserver();
|
|
}
|
|
}
|
|
|
|
onResize = () => {
|
|
const { onResize } = this.props;
|
|
if (onResize) {
|
|
onResize();
|
|
}
|
|
};
|
|
|
|
destroyObserver() {
|
|
if (this.resizeObserver) {
|
|
this.resizeObserver.disconnect();
|
|
this.resizeObserver = null;
|
|
}
|
|
}
|
|
|
|
render() {
|
|
const { children = null } = this.props;
|
|
return children;
|
|
}
|
|
}
|
|
|
|
export default ReactResizeObserver;
|