import PropTypes from "prop-types"; import { PureComponent } from "react"; import { createPortal } from "react-dom"; import { FormattedMessage, injectIntl, defineMessages } from "react-intl"; import classNames from "classnames"; import { Icon } from "mastodon/components/icon"; const messages = defineMessages({ show: { id: "column_header.show_settings", defaultMessage: "Show settings" }, hide: { id: "column_header.hide_settings", defaultMessage: "Hide settings" }, moveLeft: { id: "column_header.moveLeft_settings", defaultMessage: "Move column to the left" }, moveRight: { id: "column_header.moveRight_settings", defaultMessage: "Move column to the right" }, }); class ColumnHeader extends PureComponent { static contextTypes = { router: PropTypes.object, identity: PropTypes.object, }; static propTypes = { intl: PropTypes.object.isRequired, title: PropTypes.node, icon: PropTypes.string, active: PropTypes.bool, multiColumn: PropTypes.bool, extraButton: PropTypes.node, showBackButton: PropTypes.bool, children: PropTypes.node, pinned: PropTypes.bool, placeholder: PropTypes.bool, onPin: PropTypes.func, onMove: PropTypes.func, onClick: PropTypes.func, appendContent: PropTypes.node, collapseIssues: PropTypes.bool, }; state = { collapsed: true, animating: false, }; handleToggleClick = (e) => { e.stopPropagation(); this.setState({ collapsed: !this.state.collapsed, animating: true }); }; handleTitleClick = () => { this.props.onClick?.(); }; handleMoveLeft = () => { this.props.onMove(-1); }; handleMoveRight = () => { this.props.onMove(1); }; handleBackClick = () => { const { router } = this.context; if (router.history.location?.state?.fromMastodon) { router.history.goBack(); } else { router.history.push("/"); } }; handleTransitionEnd = () => { this.setState({ animating: false }); }; handlePin = () => { if (!this.props.pinned) { this.context.router.history.replace("/"); } this.props.onPin(); }; render () { const { router } = this.context; const { title, icon, active, children, pinned, multiColumn, extraButton, showBackButton, intl: { formatMessage }, placeholder, appendContent, collapseIssues } = this.props; const { collapsed, animating } = this.state; const wrapperClassName = classNames("column-header__wrapper", { "active": active, }); const buttonClassName = classNames("column-header", { "active": active, }); const collapsibleClassName = classNames("column-header__collapsible", { "collapsed": collapsed, "animating": animating, }); const collapsibleButtonClassName = classNames("column-header__button", { "active": !collapsed, }); let extraContent, pinButton, moveButtons, backButton, collapseButton; if (children) { extraContent = (