Skip to content

Commit

Permalink
refactor: convert text ellipsis to functional component
Browse files Browse the repository at this point in the history
  • Loading branch information
chaofan232 committed Oct 22, 2021
1 parent 6dffcbe commit 7d6e07c
Showing 1 changed file with 36 additions and 60 deletions.
96 changes: 36 additions & 60 deletions src/components/TextEllipsis/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,66 +4,42 @@ import React from 'react';
import Popover from '../Popover';
import './styles.scss';

class TextEllipsisComponent extends React.PureComponent {
static propTypes = {
children: PropTypes.node.isRequired,
/**
* Can use `placement` and `trigger` props from <a href="/popover">Popover</a> to control popover.
*/
popoverProps: PropTypes.shape(_.pick(Popover.propTypes, ['placement', 'trigger'])),
};
const TextEllipsis = ({ popoverProps, children }) => {
const containerRef = React.useRef();
const [truncated, setTruncated] = React.useState(false);

static defaultProps = {
popoverProps: {
placement: 'top',
trigger: 'hover',
},
};
React.useLayoutEffect(() => {
const nextTruncateState = containerRef.current.scrollWidth > containerRef.current.clientWidth;

constructor(props) {
super(props);

this.container = React.createRef();
}

state = {
truncated: false,
};

componentDidMount() {
this.setTruncate();
}

componentDidUpdate() {
this.setTruncate();
}

setTruncate() {
const nextTruncateState = this.container.current.scrollWidth > this.container.current.clientWidth;
if (this.state.truncated !== nextTruncateState) {
this.setState({
truncated: nextTruncateState,
});
if (truncated !== nextTruncateState) {
setTruncated(nextTruncateState);
}
}

render() {
const { popoverProps } = this.props;
const { truncated } = this.state;

return (
<Popover
{...popoverProps}
{...(truncated === false ? { triggers: 'disabled' } : {})}
popoverContent={this.props.children}
className="aui--text-ellipsis-wrapper"
>
<div data-testid="text-ellipsis" className="text-ellipsis-component" ref={this.container}>
{this.props.children}
</div>
</Popover>
);
}
}

export default TextEllipsisComponent;
}, [truncated]);

return (
<Popover
{...popoverProps}
{...(truncated === false ? { triggers: 'disabled' } : {})}
popoverContent={children}
className="aui--text-ellipsis-wrapper"
>
<div data-testid="text-ellipsis" className="text-ellipsis-component" ref={containerRef}>
{children}
</div>
</Popover>
);
};

TextEllipsis.propTypes = {
children: PropTypes.node.isRequired,
popoverProps: PropTypes.shape(_.pick(Popover.propTypes, ['placement', 'trigger'])),
};

TextEllipsis.defaultProps = {
popoverProps: {
placement: 'top',
trigger: 'hover',
},
};

export default TextEllipsis;

0 comments on commit 7d6e07c

Please sign in to comment.