mirror of
https://github.com/funamitech/mastodon
synced 2025-01-08 02:44:18 +09:00
46 lines
1.2 KiB
TypeScript
46 lines
1.2 KiB
TypeScript
|
import { useCallback } from 'react';
|
||
|
|
||
|
import { FormattedMessage } from 'react-intl';
|
||
|
|
||
|
import { ReactComponent as ArrowBackIcon } from '@material-symbols/svg-600/outlined/arrow_back.svg';
|
||
|
|
||
|
import { Icon } from 'mastodon/components/icon';
|
||
|
import { ButtonInTabsBar } from 'mastodon/features/ui/util/columns_context';
|
||
|
|
||
|
import { useAppHistory } from './router';
|
||
|
|
||
|
type OnClickCallback = () => void;
|
||
|
|
||
|
function useHandleClick(onClick?: OnClickCallback) {
|
||
|
const history = useAppHistory();
|
||
|
|
||
|
return useCallback(() => {
|
||
|
if (onClick) {
|
||
|
onClick();
|
||
|
} else if (history.location.state?.fromMastodon) {
|
||
|
history.goBack();
|
||
|
} else {
|
||
|
history.push('/');
|
||
|
}
|
||
|
}, [history, onClick]);
|
||
|
}
|
||
|
|
||
|
export const ColumnBackButton: React.FC<{ onClick: OnClickCallback }> = ({
|
||
|
onClick,
|
||
|
}) => {
|
||
|
const handleClick = useHandleClick(onClick);
|
||
|
|
||
|
const component = (
|
||
|
<button onClick={handleClick} className='column-back-button'>
|
||
|
<Icon
|
||
|
id='chevron-left'
|
||
|
icon={ArrowBackIcon}
|
||
|
className='column-back-button__icon'
|
||
|
/>
|
||
|
<FormattedMessage id='column_back_button.label' defaultMessage='Back' />
|
||
|
</button>
|
||
|
);
|
||
|
|
||
|
return <ButtonInTabsBar>{component}</ButtonInTabsBar>;
|
||
|
};
|