module.exports = function SocketStateDirectiveFactory(socket, growl, gettext) { return { restrict: 'EA', template: require('./socket-state.jade'), // scope: { // } link: function (scope) { var hasFailedOnce = false socket.on('connect', function () { scope.$apply(function () { scope.socketState = 'connect' }) }) socket.on('connecting', function () { scope.$apply(function () { scope.socketState = 'connecting' }) }) socket.on('disconnect', function () { scope.$apply(function () { scope.socketState = 'disconnect' }) hasFailedOnce = true }) socket.on('connect_failed', function () { scope.$apply(function () { scope.socketState = 'connect_failed' }) hasFailedOnce = true }) socket.on('error', function () { scope.$apply(function () { scope.socketState = 'error' }) hasFailedOnce = true }) socket.on('reconnect_failed', function () { scope.$apply(function () { scope.socketState = 'reconnect_failed' }) hasFailedOnce = true }) socket.on('reconnect', function () { scope.$apply(function () { scope.socketState = 'reconnect' }) hasFailedOnce = true }) socket.on('reconnecting', function () { scope.$apply(function () { scope.socketState = 'reconnecting' }) hasFailedOnce = true }) scope.$watch('socketState', function (newValue, oldValue) { if (newValue) { if (newValue === 'connecting' && oldValue) { growl.info('

WebSocket

' + gettext('Connecting...'), {ttl: 1000}) } else if (newValue === 'connect' && oldValue === 'connecting') { if (hasFailedOnce) { growl.success('

WebSocket

' + gettext('Connected successfully.') + '', {ttl: 2000}) } } else { switch (newValue) { case 'disconnect': growl.error('

WebSocket

' + gettext('Disconnected.
Socket connection was lost, try again reloading the page.'), {ttl: -1}) break; case 'connect_failed': growl.error('

WebSocket

' + gettext('Error while connecting.'), {ttl: -1}) break; case 'error': growl.error('

WebSocket

' + gettext('Error.'), {ttl: -1}) break; case 'reconnect_failed': growl.error('

WebSocket

' + gettext('Error while reconnecting.'), {ttl: -1}) break; case 'reconnect': growl.success('

WebSocket

' + gettext('Reconnected successfully.'), {ttl: -1}) break; case 'reconnecting': growl.error('

WebSocket

' + gettext('Reconnecting...') + '', {ttl: -1}) break; } } } }) } } }