JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
fix palette, go bright on bold
[watch-my-terminal.git] / index.html
index e55e8c0..e70dfc7 100644 (file)
@@ -1,9 +1,91 @@
-<script src="/socket.io/socket.io.js"></script>
-<script>
-  var socket = io.connect('http://localhost');
-  socket.on('news', function (data) {
-    console.log(data);
-    socket.emit('my other event', { my: 'data' });
-    socket.emit('jason', { is: 'large and in charge' });
-  });
-</script>
+<!DOCTYPE html>
+<html lang="en">
+<head>
+       <title>Remote Terminal Viewer</title>
+       <script src="/jquery.js"></script>
+       <script src="/socket.io/socket.io.js"></script>
+       <script>
+               $(function() {
+                       // 8-14 are bolded versions
+                       var palette = [
+                               '2e3436',
+                               'cc0000',
+                               '4e9a06',
+                               'c4a000',
+                               '3465a4',
+                               '75507b',
+                               '06989a',
+                               'd3d7cf',
+                               '555753',
+                               'ef2929',
+                               '8ae234',
+                               'fce94f',
+                               '729fcf',
+                               'ad7fa8',
+                               '34e2e2',
+                               'eeeeec'
+                       ];
+                       var $body = $('body');
+                       var socket = io.connect('http://localhost');
+                       var color_to_css = function(i) {
+                               index = i & 0xff
+                               // lighten the basic 8 colors when they're bold
+                               if (i & 0x10000 && index < 8) {
+                                       index += 8;
+                               }
+                               return 'color: #' + palette[index] + '; ';
+                       }
+                       var bg_color_to_css = function(i) {
+                               return 'background-' + color_to_css((i&0x10000) | ((i&0xff00) >> 8));
+                       }
+                       var stylize = function (txt, style) {
+                               if (txt.length == 0 || style == 0) {
+                                       return txt
+                               }
+                               css = ''
+                               if(style & 0x10000) css += 'font-weight: bold; ';
+                               if(style & 0x20000) css += 'text-decoration: underline; ';
+                               if(style & 0x40000) css += 'text-decoration: underline; '; // blink
+                               if(style & 0x80000) css += 'text-decoration: line-through; '; // invisible
+                               if(style & 0x000ff) css += color_to_css(style);
+                               if(style & 0x0ff00) css += bg_color_to_css(style);
+                               return $('<span style="'+css+'"></span>').text(txt);
+                       }
+                       socket.on('init', function (v) {
+                               $body.children().remove();
+                               for(i in v.text) {
+                                       div = $('<div>');
+                                       txt = ''
+                                       a = 0;
+                                       for(j in v.text[i]) {
+                                               if(v.attributes[i][j] != a) {
+                                                       if(txt.length) {
+                                                               div.append(stylize(txt, a));
+                                                               txt = ''
+                                                       }
+                                                       a = v.attributes[i][j]
+                                               }
+                                               txt += v.text[i][j]
+                                       }
+                                       if(txt.length) {
+                                               div.append(stylize(txt, a));
+                                       }
+                                       $body.append(div);
+                               }
+                       });
+               });
+       </script>
+       <style>
+               body {
+                       color: #d3d7cf;
+                       background: #2e3436;
+                       font-family: monospace;
+                       font-size: 12px;
+                       line-height: 14px;
+                       white-space: pre;
+               }
+       </style>
+</head>
+<body>
+</body>
+</html>