diff --git a/src/NotificationSystem.jsx b/src/NotificationSystem.jsx index c11b4e1..f5c944f 100644 --- a/src/NotificationSystem.jsx +++ b/src/NotificationSystem.jsx @@ -162,6 +162,26 @@ var NotificationSystem = React.createClass({ }); }, + deleteNotification: function(notification) { + var self = this; + var uid = notification.uid ? notification.uid : notification; + Object.keys(this.refs).forEach(function(container) { + if (container.indexOf('container') > -1) { + Object.keys(self.refs[container].refs).forEach(function(_notification) { + if (_notification === 'notification-' + uid) { + console.log('remove ', _notification); + self.refs[container].refs[_notification]._removeNotification(); + } + }); + } + }); + this.state.notifications.forEach(function(item, index) { + if (item.uid === uid) { + self.state.notifications.splice(index, 1); + } + }); + }, + componentDidMount: function() { this._getStyles.setOverrideStyle(this.props.style); }, diff --git a/test/notification-system.test.js b/test/notification-system.test.js index e3aab6f..ea81859 100644 --- a/test/notification-system.test.js +++ b/test/notification-system.test.js @@ -164,6 +164,30 @@ describe('Notification Component', function() { done(); }); + it('should delete a notification using returned object', done => { + let notificationCreated = component.addNotification(defaultNotification); + let notification = TestUtils.scryRenderedDOMComponentsWithClass(instance, 'notification'); + expect(notification.length).toEqual(1); + + component.deleteNotification(notificationCreated); + //clock.tick(1000); + let notificationDeleted = TestUtils.scryRenderedDOMComponentsWithClass(instance, 'notification'); + expect(notificationDeleted.length).toEqual(0); + done(); + }); + + it('should delete a notification using uid', done => { + let notificationCreated = component.addNotification(defaultNotification); + let notification = TestUtils.scryRenderedDOMComponentsWithClass(instance, 'notification'); + expect(notification.length).toEqual(1); + + component.deleteNotification(notificationCreated.uid); + //clock.tick(200); + let notificationDeleted = TestUtils.scryRenderedDOMComponentsWithClass(instance, 'notification'); + expect(notificationDeleted.length).toEqual(0); + done(); + }); + it('should dismiss notification on click', done => { component.addNotification(notificationObj); let notification = TestUtils.findRenderedDOMComponentWithClass(instance, 'notification');