2018-05-28 03:23:56 +09:00
|
|
|
import PropTypes from 'prop-types';
|
2023-05-28 23:38:10 +09:00
|
|
|
import { PureComponent } from 'react';
|
|
|
|
|
2018-05-28 03:23:56 +09:00
|
|
|
import { injectIntl, defineMessages } from 'react-intl';
|
2023-05-28 23:38:10 +09:00
|
|
|
|
2023-05-09 10:11:56 +09:00
|
|
|
import { Icon } from 'flavours/glitch/components/icon';
|
2018-05-28 03:23:56 +09:00
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
load_more: { id: 'status.load_more', defaultMessage: 'Load more' },
|
|
|
|
});
|
|
|
|
|
2023-05-28 21:18:23 +09:00
|
|
|
class LoadGap extends PureComponent {
|
2018-05-28 03:23:56 +09:00
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
disabled: PropTypes.bool,
|
|
|
|
maxId: PropTypes.string,
|
|
|
|
onClick: PropTypes.func.isRequired,
|
|
|
|
intl: PropTypes.object.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
handleClick = () => {
|
|
|
|
this.props.onClick(this.props.maxId);
|
2023-02-04 04:52:07 +09:00
|
|
|
};
|
2018-05-28 03:23:56 +09:00
|
|
|
|
|
|
|
render () {
|
|
|
|
const { disabled, intl } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<button className='load-more load-gap' disabled={disabled} onClick={this.handleClick} aria-label={intl.formatMessage(messages.load_more)}>
|
2019-09-09 23:41:41 +09:00
|
|
|
<Icon id='ellipsis-h' />
|
2018-05-28 03:23:56 +09:00
|
|
|
</button>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2023-03-25 07:15:25 +09:00
|
|
|
|
|
|
|
export default injectIntl(LoadGap);
|