aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkedama <kedama@foresdon.jp>2018-12-19 00:43:50 +0900
committerEugen Rochko <eugen@zeonfederated.com>2018-12-18 16:43:50 +0100
commit5bf100f87be571e86305f3ab244183fc46f1ede2 (patch)
tree649498b8ebdf3cfa3542d59b066b026ca87e8074
parentdd85700a3e06ecec424ffc9f623f9407b007b229 (diff)
downloadmastodon-5bf100f87be571e86305f3ab244183fc46f1ede2.tar
mastodon-5bf100f87be571e86305f3ab244183fc46f1ede2.tar.gz
mastodon-5bf100f87be571e86305f3ab244183fc46f1ede2.tar.bz2
mastodon-5bf100f87be571e86305f3ab244183fc46f1ede2.zip
Back to the getting-started when pins the timeline. (#9561)
-rw-r--r--app/javascript/mastodon/components/column_header.js24
1 files changed, 19 insertions, 5 deletions
diff --git a/app/javascript/mastodon/components/column_header.js b/app/javascript/mastodon/components/column_header.js
index 457508d13..f68e4155e 100644
--- a/app/javascript/mastodon/components/column_header.js
+++ b/app/javascript/mastodon/components/column_header.js
@@ -37,6 +37,14 @@ class ColumnHeader extends React.PureComponent {
animating: false,
};
+ historyBack = () => {
+ if (window.history && window.history.length === 1) {
+ this.context.router.history.push('/');
+ } else {
+ this.context.router.history.goBack();
+ }
+ }
+
handleToggleClick = (e) => {
e.stopPropagation();
this.setState({ collapsed: !this.state.collapsed, animating: true });
@@ -55,16 +63,22 @@ class ColumnHeader extends React.PureComponent {
}
handleBackClick = () => {
- if (window.history && window.history.length === 1) this.context.router.history.push('/');
- else this.context.router.history.goBack();
+ this.historyBack();
}
handleTransitionEnd = () => {
this.setState({ animating: false });
}
+ handlePin = () => {
+ if (!this.props.pinned) {
+ this.historyBack();
+ }
+ this.props.onPin();
+ }
+
render () {
- const { title, icon, active, children, pinned, onPin, multiColumn, extraButton, showBackButton, intl: { formatMessage } } = this.props;
+ const { title, icon, active, children, pinned, multiColumn, extraButton, showBackButton, intl: { formatMessage } } = this.props;
const { collapsed, animating } = this.state;
const wrapperClassName = classNames('column-header__wrapper', {
@@ -95,7 +109,7 @@ class ColumnHeader extends React.PureComponent {
}
if (multiColumn && pinned) {
- pinButton = <button key='pin-button' className='text-btn column-header__setting-btn' onClick={onPin}><i className='fa fa fa-times' /> <FormattedMessage id='column_header.unpin' defaultMessage='Unpin' /></button>;
+ pinButton = <button key='pin-button' className='text-btn column-header__setting-btn' onClick={this.handlePin}><i className='fa fa fa-times' /> <FormattedMessage id='column_header.unpin' defaultMessage='Unpin' /></button>;
moveButtons = (
<div key='move-buttons' className='column-header__setting-arrows'>
@@ -104,7 +118,7 @@ class ColumnHeader extends React.PureComponent {
</div>
);
} else if (multiColumn) {
- pinButton = <button key='pin-button' className='text-btn column-header__setting-btn' onClick={onPin}><i className='fa fa fa-plus' /> <FormattedMessage id='column_header.pin' defaultMessage='Pin' /></button>;
+ pinButton = <button key='pin-button' className='text-btn column-header__setting-btn' onClick={this.handlePin}><i className='fa fa fa-plus' /> <FormattedMessage id='column_header.pin' defaultMessage='Pin' /></button>;
}
if (!pinned && (multiColumn || showBackButton)) {