101 lines
2.7 KiB
JavaScript
101 lines
2.7 KiB
JavaScript
|
/**
|
||
|
* Buttons widget for controlling the notification clearing mode.
|
||
|
* In idle state, the cleaning mode button is shown. When the mode is active,
|
||
|
* a Confirm and Abort buttons are shown in its place.
|
||
|
*/
|
||
|
|
||
|
|
||
|
// Package imports //
|
||
|
import React from 'react';
|
||
|
import PropTypes from 'prop-types';
|
||
|
import { defineMessages, injectIntl } from 'react-intl';
|
||
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
||
|
|
||
|
// Mastodon imports //
|
||
|
|
||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||
|
|
||
|
const messages = defineMessages({
|
||
|
enter : { id: 'notification_purge.start', defaultMessage: 'Enter notification cleaning mode' },
|
||
|
accept : { id: 'notification_purge.confirm', defaultMessage: 'Dismiss selected notifications' },
|
||
|
abort : { id: 'notification_purge.abort', defaultMessage: 'Leave cleaning mode' },
|
||
|
});
|
||
|
|
||
|
@injectIntl
|
||
|
export default class NotificationPurgeButtons extends ImmutablePureComponent {
|
||
|
|
||
|
static propTypes = {
|
||
|
// Nukes all marked notifications
|
||
|
onDeleteMarkedNotifications : PropTypes.func.isRequired,
|
||
|
// Enables or disables the mode
|
||
|
// and also clears the marked status of all notifications
|
||
|
onEnterCleaningMode : PropTypes.func.isRequired,
|
||
|
// Active state, changed via onStateChange()
|
||
|
active: PropTypes.bool.isRequired,
|
||
|
// i18n
|
||
|
intl: PropTypes.object.isRequired,
|
||
|
};
|
||
|
|
||
|
onEnterBtnClick = () => {
|
||
|
this.props.onEnterCleaningMode(true);
|
||
|
}
|
||
|
|
||
|
onAcceptBtnClick = () => {
|
||
|
this.props.onDeleteMarkedNotifications();
|
||
|
}
|
||
|
|
||
|
onAbortBtnClick = () => {
|
||
|
this.props.onEnterCleaningMode(false);
|
||
|
}
|
||
|
|
||
|
render () {
|
||
|
const { intl, active } = this.props;
|
||
|
|
||
|
const msgEnter = intl.formatMessage(messages.enter);
|
||
|
const msgAccept = intl.formatMessage(messages.accept);
|
||
|
const msgAbort = intl.formatMessage(messages.abort);
|
||
|
|
||
|
let enterButton, acceptButton, abortButton;
|
||
|
|
||
|
if (active) {
|
||
|
acceptButton = (
|
||
|
<button
|
||
|
className='active'
|
||
|
aria-label={msgAccept}
|
||
|
title={msgAccept}
|
||
|
onClick={this.onAcceptBtnClick}
|
||
|
>
|
||
|
<i className='fa fa-check' />
|
||
|
</button>
|
||
|
);
|
||
|
abortButton = (
|
||
|
<button
|
||
|
className='active'
|
||
|
aria-label={msgAbort}
|
||
|
title={msgAbort}
|
||
|
onClick={this.onAbortBtnClick}
|
||
|
>
|
||
|
<i className='fa fa-times' />
|
||
|
</button>
|
||
|
);
|
||
|
} else {
|
||
|
enterButton = (
|
||
|
<button
|
||
|
aria-label={msgEnter}
|
||
|
title={msgEnter}
|
||
|
onClick={this.onEnterBtnClick}
|
||
|
>
|
||
|
<i className='fa fa-eraser' />
|
||
|
</button>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<div className='column-header__notif-cleaning-buttons'>
|
||
|
{acceptButton}{abortButton}{enterButton}
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
}
|