File: web-worker.html

package info (click to toggle)
node-sockjs-client 1.6.1%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 1,424 kB
  • sloc: javascript: 4,966; sh: 7; makefile: 2
file content (126 lines) | stat: -rw-r--r-- 4,083 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  <meta charset="UTF-8" />

  <link href="" rel="icon" type="image/x-icon" />

  <script type="text/javascript" src="lib/sockjs.js"></script>
  <script type="text/javascript" src="static/jquery.min.js"></script>

  <script type="text/javascript" src="config.js"></script>
</head>
<body>
<form>
  <select id="transport">
  <option value="">- any - </option>
  <option value="websocket">websocket</option>
  <option value="xdr-streaming">xdr-streaming</option>
  <option value="xhr-streaming">xhr-streaming</option>
  <option value="eventsource">eventsource</option>
  <option value="iframe-eventsource">iframe-eventsource</option>
  <option value="htmlfile">htmlfile</option>
  <option value="iframe-htmlfile">iframe-htmlfile</option>
  <option value="xdr-polling">xdr-polling</option>
  <option value="xhr-polling">xhr-polling</option>
  <option value="iframe-xhr-polling">iframe-xhr-polling</option>
  <option value="jsonp-polling">jsonp-polling</option>
  </select>
  <input type="checkbox" id="sameOrigin" checked>Same Origin?
  <input type="button" value="Connect" id="connect">
  <input type="button" value="Disconnect" id="disconnect" disabled="yes">
</form>

  Latency: <code id="latency"></code><br>
  <code id="logs" style="height:200px; overflow:auto; display: block; border: 1px gray solid;">
  </code>

<script>
  /* global $, clientOptions */
  'use strict';
  function log(a) {
    if ('console' in window && 'log' in window.console) {
        console.log(a);
    }
    $('#logs').append($('<code>').text(a));
    $('#logs').append($('<br>'));
    $('#logs').scrollTop($('#logs').scrollTop() + 10000);
  }

  var worker;
  function send() {
    worker.postMessage(JSON.stringify({ type: 'message', data: JSON.stringify({ t: (new Date()).getTime()}) }));
  }
  function onopen() {
    log('connected');
    $('#sameOrigin').attr('disabled', true);
    send();
  }
  function onclose(code, reason) {
    log('disconnected ' + code + ', ' + reason);
    $('#connect').each(function(_,e){
      e.disabled = '';
    });
    $('#disconnect').attr('disabled', true);
    $('#sameOrigin').attr('disabled', false);
  }

  var i = 0;
  function xonmessage(e) {
    var msg = JSON.parse(e);
    var td = (new Date()).getTime() - msg.t;
    $('#latency').text('' + i + '  ' + td + ' ms');
    i += 1;
    send();
  }

  $('#connect').click(function() {
      $('#connect').attr('disabled', true);
      $('#disconnect').each(function(_,e){
        e.disabled = '';
      });
      var transport = $('#transport').val() || undefined;
      log('[connecting] ' + transport);
      var url;
      if ($('#sameOrigin').prop('checked')) {
        if (window.location.origin) {
          url = window.location.origin;
        } else {
          url = window.location.protocol + '//' + window.location.hostname +
            (window.location.port ? ':' + window.location.port : '');
        }
      } else {
        url = clientOptions.url;
      }
      worker = new Worker('lib/worker.js');
      worker.onmessage = function (e) {
        var msg = JSON.parse(e.data);
        switch (msg.type) {
          case 'message':
            xonmessage(msg.data);
            break;
          case 'open':
            onopen();
            break;
          case 'close':
            onclose(msg.code, msg.reason);
            break;
          case 'error':
            console.error(msg.data);
            break;
          default:
            console.error('unknown type: ' + msg.type);
        }
      };

      worker.postMessage(JSON.stringify({ type: 'open', url: url + '/echo', transports: transport }));
  });
  $('#disconnect').click(function() {
    $('#disconnect').attr('disabled', true);
    log('[disconnecting]');
    worker.postMessage(JSON.stringify({ type: 'close' }));
  });
</script>
</body>
</html>