import PropTypes from 'prop-types'; import React from 'react'; import { HotKeys } from 'react-hotkeys'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { injectIntl, FormattedMessage } from 'react-intl'; import { connect } from 'react-redux'; import { Link } from 'react-router-dom'; import { fetchBirthdayReminders } from 'soapbox/actions/accounts'; import { openModal } from 'soapbox/actions/modal'; import Icon from 'soapbox/components/icon'; import { makeGetAccount } from 'soapbox/selectors'; const mapStateToProps = (state, props) => { const me = state.get('me'); const getAccount = makeGetAccount(); const birthdays = state.getIn(['user_lists', 'birthday_reminders', me]); if (birthdays && birthdays.size > 0) { return { birthdays, account: getAccount(state, birthdays.first()), }; } return { birthdays, }; }; export default @connect(mapStateToProps) @injectIntl class BirthdayReminders extends ImmutablePureComponent { static propTypes = { birthdays: ImmutablePropTypes.orderedSet, intl: PropTypes.object.isRequired, dispatch: PropTypes.func.isRequired, }; componentDidMount() { const { dispatch } = this.props; const date = new Date(); const day = date.getDate(); const month = date.getMonth() + 1; dispatch(fetchBirthdayReminders(day, month)); } getHandlers() { return { open: this.handleOpenBirthdaysModal, }; } handleOpenBirthdaysModal = () => { const { dispatch } = this.props; dispatch(openModal('BIRTHDAYS')); } renderMessage() { const { birthdays, account } = this.props; const link = ( ); if (birthdays.size === 1) { return ; } return ( ), }} /> ); } render() { const { birthdays } = this.props; if (!birthdays || birthdays.size === 0) return null; return (
{this.renderMessage()}
); } }