From 94be4f33acc2dbf4e0047b1228b1afa932aed883 Mon Sep 17 00:00:00 2001 From: Claire Date: Sun, 14 Jan 2024 13:23:13 +0100 Subject: [PATCH] Rewrite `Permalink` as functional component --- .../flavours/glitch/components/permalink.jsx | 64 ++++++++----------- 1 file changed, 26 insertions(+), 38 deletions(-) diff --git a/app/javascript/flavours/glitch/components/permalink.jsx b/app/javascript/flavours/glitch/components/permalink.jsx index 522689541583ce..4a6da125e7fa89 100644 --- a/app/javascript/flavours/glitch/components/permalink.jsx +++ b/app/javascript/flavours/glitch/components/permalink.jsx @@ -1,50 +1,38 @@ import PropTypes from 'prop-types'; -import { PureComponent } from 'react'; +import { useCallback } from 'react'; -import { withOptionalRouter, WithOptionalRouterPropTypes } from 'flavours/glitch/utils/react_router'; +import { useAppHistory } from './router'; -class Permalink extends PureComponent { +const Permalink = ({ className, href, to, children, onInterceptClick, ...props }) => { + const history = useAppHistory(); - static propTypes = { - className: PropTypes.string, - href: PropTypes.string.isRequired, - to: PropTypes.string.isRequired, - children: PropTypes.node, - onInterceptClick: PropTypes.func, - ...WithOptionalRouterPropTypes, - }; - - handleClick = (e) => { + const handleClick = useCallback((e) => { if (e.button === 0 && !(e.ctrlKey || e.metaKey)) { - if (this.props.onInterceptClick && this.props.onInterceptClick()) { + if (onInterceptClick && onInterceptClick()) { e.preventDefault(); return; } - if (this.props.history) { + if (history) { e.preventDefault(); - this.props.history.push(this.props.to); + history.push(to); } } - }; - - render () { - const { - children, - className, - href, - to, - onInterceptClick, - ...other - } = this.props; - - return ( - - {children} - - ); - } - -} - -export default withOptionalRouter(Permalink); + }, [onInterceptClick, history, to]); + + return ( + + {children} + + ); +}; + +Permalink.propTypes = { + className: PropTypes.string, + href: PropTypes.string.isRequired, + to: PropTypes.string.isRequired, + children: PropTypes.node, + onInterceptClick: PropTypes.func, +}; + +export default Permalink;