React & Redux based notifications center.
Thanks to Redux, the notification objects are maintained within Redux Store's State and are fired by Actions.
npm install --save redux-notifs
or
yarn add redux-notifs
import { combineReducers } from 'redux'
import { notifsReducer } from 'redux-notifs';
combineReducers({
notifs: notifsReducer,
// ... other reducers ...
})
import { Provider } from 'react-redux'
import { Notifs } from 'redux-notifs';
<Provider store={store}>
<React.Fragment>
<Notifs />
// ... other things like router ...
</React.Fragment>
</Provider>
redux-notifs
uses react-css-transition-group with the following classes:
- .notif-transition-enter
- .notif-transition-enter-active
- .notif-transition-leave
- .notif-transition-leave-active
To import the default stylesheet:
import 'redux-notifs/lib/styles.css';
Thanks to Redux, sending notification is simply done by firing an Action
:
import { connect } from 'redux-connect';
import { sendNotification } from 'redux-notifications';
class Demo extends React.Component {
sendNotification = () => {
this.props.dispatch(sendNotification({
message: 'hello world',
kind: 'info',
dismissAfter: 2000
}));
};
render() {
<button onClick={this.sendNotification}>Send Notification</button>
}
}
const DemoController = connect(null, { sendNotification })(Demo);
The notification message, can be one of:
string
,integer
,element
orarray
containing these types.
The notification kind, can be one of:
info
,success
,warning
,danger
.
Set an ID for the notification. If not set, defaults to Date.now().
Auto dismiss the notification after the given number of milliseconds.
Pass a custom classname to the component.
The base className for each Notif component. Can be used to override CSS styles.
Define the react-transition-group enter timeout is milliseconds.
Define the react-transition-group leave timeout is milliseconds.
Label for action click
Function when action is clicked. Requires
actionLabel
prop
git clone https://github.com/zero-t4/redux-notifs.git
cd redux-notifs
yarn
yarn start
Listening on localhost:9000