EventTarget.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. 'use strict';
  2. /**
  3. * Class representing an event.
  4. *
  5. * @private
  6. */
  7. class Event {
  8. /**
  9. * Create a new `Event`.
  10. *
  11. * @param {String} type The name of the event
  12. * @param {Object} target A reference to the target to which the event was dispatched
  13. */
  14. constructor (type, target) {
  15. this.target = target;
  16. this.type = type;
  17. }
  18. }
  19. /**
  20. * Class representing a message event.
  21. *
  22. * @extends Event
  23. * @private
  24. */
  25. class MessageEvent extends Event {
  26. /**
  27. * Create a new `MessageEvent`.
  28. *
  29. * @param {(String|Buffer|ArrayBuffer|Buffer[])} data The received data
  30. * @param {WebSocket} target A reference to the target to which the event was dispatched
  31. */
  32. constructor (data, target) {
  33. super('message', target);
  34. this.data = data;
  35. }
  36. }
  37. /**
  38. * Class representing a close event.
  39. *
  40. * @extends Event
  41. * @private
  42. */
  43. class CloseEvent extends Event {
  44. /**
  45. * Create a new `CloseEvent`.
  46. *
  47. * @param {Number} code The status code explaining why the connection is being closed
  48. * @param {String} reason A human-readable string explaining why the connection is closing
  49. * @param {WebSocket} target A reference to the target to which the event was dispatched
  50. */
  51. constructor (code, reason, target) {
  52. super('close', target);
  53. this.wasClean = target._closeFrameReceived && target._closeFrameSent;
  54. this.reason = reason;
  55. this.code = code;
  56. }
  57. }
  58. /**
  59. * Class representing an open event.
  60. *
  61. * @extends Event
  62. * @private
  63. */
  64. class OpenEvent extends Event {
  65. /**
  66. * Create a new `OpenEvent`.
  67. *
  68. * @param {WebSocket} target A reference to the target to which the event was dispatched
  69. */
  70. constructor (target) {
  71. super('open', target);
  72. }
  73. }
  74. /**
  75. * This provides methods for emulating the `EventTarget` interface. It's not
  76. * meant to be used directly.
  77. *
  78. * @mixin
  79. */
  80. const EventTarget = {
  81. /**
  82. * Register an event listener.
  83. *
  84. * @param {String} method A string representing the event type to listen for
  85. * @param {Function} listener The listener to add
  86. * @public
  87. */
  88. addEventListener (method, listener) {
  89. if (typeof listener !== 'function') return;
  90. function onMessage (data) {
  91. listener.call(this, new MessageEvent(data, this));
  92. }
  93. function onClose (code, message) {
  94. listener.call(this, new CloseEvent(code, message, this));
  95. }
  96. function onError (event) {
  97. event.type = 'error';
  98. event.target = this;
  99. listener.call(this, event);
  100. }
  101. function onOpen () {
  102. listener.call(this, new OpenEvent(this));
  103. }
  104. if (method === 'message') {
  105. onMessage._listener = listener;
  106. this.on(method, onMessage);
  107. } else if (method === 'close') {
  108. onClose._listener = listener;
  109. this.on(method, onClose);
  110. } else if (method === 'error') {
  111. onError._listener = listener;
  112. this.on(method, onError);
  113. } else if (method === 'open') {
  114. onOpen._listener = listener;
  115. this.on(method, onOpen);
  116. } else {
  117. this.on(method, listener);
  118. }
  119. },
  120. /**
  121. * Remove an event listener.
  122. *
  123. * @param {String} method A string representing the event type to remove
  124. * @param {Function} listener The listener to remove
  125. * @public
  126. */
  127. removeEventListener (method, listener) {
  128. const listeners = this.listeners(method);
  129. for (var i = 0; i < listeners.length; i++) {
  130. if (listeners[i] === listener || listeners[i]._listener === listener) {
  131. this.removeListener(method, listeners[i]);
  132. }
  133. }
  134. }
  135. };
  136. module.exports = EventTarget;