xpra icon
Bug tracker and wiki

Ticket #1689: test.html

File test.html, 7.7 KB (added by Antoine Martin, 2 years ago)

page similar to the client, clipboard works here...

Line 
1<html>
2        <head>
3                <title>xpra websockets client</title>
4                <meta charset="utf-8">
5                <meta name="description" content="xpra websockets client">
6
7                <link rel="stylesheet" href="css/client.css">
8                <link rel="stylesheet" href="css/spinner.css">
9
10                <script type="text/javascript" src="js/lib/jquery.js"></script>
11        </head>
12        <body>
13                <div id="dpi" style="width: 1in; height: 1in; left: -100%; top: -100%; position: absolute;">
14                </div>
15
16                <div id="progress" class="overlay" style="display: none">
17                        <p id="progress-label"></p>
18                        <p id="progress-details"></p>
19                        <progress id="progress-bar" max="100" value="10"></progress>
20                </div>
21
22                <div id="screen" style="width: 100%; height:100%;">
23                </div>
24
25                <div class="notifications">
26                </div>
27
28                <div id="1" class="wmclass-XTerm window window-NORMAL ui-draggable ui-draggable-handle ui-resizable wmclass-xterm windowinfocus" style="opacity: 1; z-index: 7501; width: 499px; height: 346px; left: 0px; top: -40px; cursor: url(&quot;&quot;) 11 12, auto;"><div id="spinner1" class="spinneroverlay" style="display: none;"><div class="spinnermiddle"><div class="spinner"></div></div></div><div id="head1" class="windowhead"> <span class="windowicon"><img src="" id="windowicon1"></span> <span class="windowtitle" id="title1" style="left: 32px;">antoine@desktop:~/projects/Xpra/trunk/src</span> <span class="windowbuttons"> <span id="maximize1"><img src="../icons/maximize.png"></span> <span id="close1"><img src="../icons/close.png"></span> </span></div><canvas width="499" height="316"></canvas><div class="ui-resizable-handle ui-resizable-n" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-e" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-s" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-w" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-ne" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-se ui-icon ui-icon-gripsmall-diagonal-se" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-sw" style="z-index: 90;"></div><div class="ui-resizable-handle ui-resizable-nw" style="z-index: 90;"></div></div></div>
29
30            <div contenteditable="true">
31                    <textarea id="pasteboard" onblur="this.focus()" autofocus="autofocus" style="display: block; position: absolute; left: -99em;"></textarea>
32            </div>
33
34                <script>
35
36                            var pasteboard = $('#pasteboard');
37                            console.log("pasteboard=", pasteboard);
38                                if (true) {
39                                    //clipboard hooks:
40                                    $(document).on('paste', '[contenteditable]', function(e) {
41                                                var paste_data = (e.originalEvent || e).clipboardData.getData('text/plain');
42                                                console.log("paste event, data=", paste_data);
43                                        return false;
44                                        });
45                                    $(document).on('copy','[contenteditable]',function(e) {
46                                        console.log("copy event");
47                                        return true;
48                                        });
49                                    $(document).on('cut','[contenteditable]',function(e) {
50                                        var clipboard_buffer = client.get_clipboard_buffer();
51                                        $('#pasteboard').text(decodeURIComponent(escape(clipboard_buffer)));
52                                        $('#pasteboard').select();
53                                                console.log("cut event, clipboard buffer=", clipboard_buffer);
54                                        return true;
55                                        });
56                                        $('#screen').on('click', function (e) {
57                                                //console.log("click pending=", client.clipboard_pending, "buffer=", client.clipboard_buffer);
58                                                if (false) {
59                                                var clipboard_buffer = client.get_clipboard_buffer();
60                                                $('#pasteboard').text(clipboard_buffer);
61                                                $('#pasteboard').select();
62                                                        client.log("click event, with pending clipboard buffer=", clipboard_buffer);
63                                                        //for IE:
64                                                        var success = true;
65                                                        if (window.clipboardData && window.clipboardData.setData) {
66                                                        clipboardData.setData("Text", this.clipboard_buffer);
67                                                        }
68                                                    else {
69                                                                success = document.execCommand('copy');
70                                                                //console.log("copy success=", success);
71                                                        }
72                                                        if (success) {
73                                                        client.clipboard_pending = false;
74                                                        }
75                                                }
76                                        });
77                                }
78                                //keyboard input for tablets:
79                                pasteboard.on("input", function(e) {
80                                        var txt = pasteboard.val();
81                                        pasteboard.val("");
82                                        client._debug("oninput:", txt);
83                                        if (!client.topwindow) {
84                                                return;
85                                        }
86                                        for (var i = 0, len = txt.length; i < len; i++) {
87                                                var str = txt[i];
88                                                var keycode = str.charCodeAt(0);
89                                                try {
90                                                        modifiers = [];
91                                                        keyval = keycode;
92                                                        group = 0;
93                                                        packet = ["key-action", client.topwindow, str, true, modifiers, keyval, str, keycode, group];
94                                                        client._debug(packet);
95                                                        client.send(packet);
96                                                        packet = ["key-action", client.topwindow, str, false, modifiers, keyval, str, keycode, group];
97                                                        client._debug(packet);
98                                                        client.send(packet);
99                                                }
100                                                catch (e) {
101                                                        client.error("input handling error: "+e);
102                                                }
103                                        }
104                                });
105                </script>
106        </body>
107</html>