69 lines
1.7 KiB
JavaScript
69 lines
1.7 KiB
JavaScript
// @flow
|
|
|
|
import React from 'react';
|
|
import { View } from 'react-native';
|
|
import { connect } from 'react-redux';
|
|
|
|
import AbstractNotificationsContainer, {
|
|
_abstractMapStateToProps,
|
|
type Props as AbstractProps
|
|
} from './AbstractNotificationsContainer';
|
|
import Notification from './Notification';
|
|
import styles from './styles';
|
|
|
|
type Props = AbstractProps & {
|
|
|
|
/**
|
|
* Any custom styling applied to the notifications container.
|
|
*/
|
|
style: Object
|
|
};
|
|
|
|
/**
|
|
* Implements a React {@link Component} which displays notifications and handles
|
|
* automatic dismissmal after a notification is shown for a defined timeout
|
|
* period.
|
|
*
|
|
* @extends {Component}
|
|
*/
|
|
class NotificationsContainer
|
|
extends AbstractNotificationsContainer<Props> {
|
|
|
|
/**
|
|
* Implements React's {@link Component#render()}.
|
|
*
|
|
* @inheritdoc
|
|
* @returns {ReactElement}
|
|
*/
|
|
render() {
|
|
const { _notifications } = this.props;
|
|
|
|
if (!_notifications || !_notifications.length) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<View
|
|
pointerEvents = 'box-none'
|
|
style = { [
|
|
styles.notificationContainer,
|
|
this.props.style
|
|
] } >
|
|
{
|
|
_notifications.map(
|
|
({ props, uid }) => (
|
|
<Notification
|
|
{ ...props }
|
|
key = { uid }
|
|
onDismissed = { this._onDismissed }
|
|
uid = { uid } />))
|
|
}
|
|
</View>
|
|
);
|
|
}
|
|
|
|
_onDismissed: number => void;
|
|
}
|
|
|
|
export default connect(_abstractMapStateToProps)(NotificationsContainer);
|