http://git-wip-us.apache.org/repos/asf/activemq/blob/2ecf41d0/assembly/src/release/examples/mqtt/websocket/css/bootstrap.min.responsive.css ---------------------------------------------------------------------- diff --git a/assembly/src/release/examples/mqtt/websocket/css/bootstrap.min.responsive.css b/assembly/src/release/examples/mqtt/websocket/css/bootstrap.min.responsive.css new file mode 100644 index 0000000..bc3f2ab --- /dev/null +++ b/assembly/src/release/examples/mqtt/websocket/css/bootstrap.min.responsive.css @@ -0,0 +1,3 @@ + +.hidden{display:none;visibility:hidden;} +@media (max-width:480px){.nav-collapse{-webkit-transform:translate3d(0, 0, 0);} .page-header h1 small{display:block;line-height:18px;} input[class*="span"],select[class*="span"],textarea[class*="span"],.uneditable-input{display:block;width:100%;height:28px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;} .input-prepend input[class*="span"],.input-append input[class*="span"]{width:auto;} input[type="checkbox"],input[type="radio"]{border:1px solid #ccc;} .form-horizontal .control-group>label{float:none;width:auto;padding-top:0;text-align:left;} .form-horizontal .controls{margin-left:0;} .form-horizontal .control-list{padding-top:0;} .form-horizontal .form-actions{padding-left:10px;padding-right:10px;} .modal{position:absolute;top:10px;left:10px;right:10px;width:auto;margin:0;}.modal.fade.in{top:auto;} .modal-header .close{padding:10px;margin:-10px;} .carousel-caption{position:static;}}@media (max-width:768px){.container{width:a uto;padding:0 20px;} .row-fluid{width:100%;} .row{margin-left:0;} .row>[class*="span"],.row-fluid>[class*="span"]{float:none;display:block;width:auto;margin:0;}}@media (min-width:768px) and (max-width:980px){.row{margin-left:-20px;*zoom:1;}.row:before,.row:after{display:table;content:"";} .row:after{clear:both;} [class*="span"]{float:left;margin-left:20px;} .span1{width:42px;} .span2{width:104px;} .span3{width:166px;} .span4{width:228px;} .span5{width:290px;} .span6{width:352px;} .span7{width:414px;} .span8{width:476px;} .span9{width:538px;} .span10{width:600px;} .span11{width:662px;} .span12,.container{width:724px;} .offset1{margin-left:82px;} .offset2{margin-left:144px;} .offset3{margin-left:206px;} .offset4{margin-left:268px;} .offset5{margin-left:330px;} .offset6{margin-left:392px;} .offset7{margin-left:454px;} .offset8{margin-left:516px;} .offset9{margin-left:578px;} .offset10{margin-left:640px;} .offset11{margin-left:702px;} .row-fluid{width:100%;*zoom:1;}.row-fluid:before,.ro w-fluid:after{display:table;content:"";} .row-fluid:after{clear:both;} .row-fluid>[class*="span"]{float:left;margin-left:2.762430939%;} .row-fluid>[class*="span"]:first-child{margin-left:0;} .row-fluid .span1{width:5.801104972%;} .row-fluid .span2{width:14.364640883%;} .row-fluid .span3{width:22.928176794%;} .row-fluid .span4{width:31.491712705%;} .row-fluid .span5{width:40.055248616%;} .row-fluid .span6{width:48.618784527%;} .row-fluid .span7{width:57.182320438000005%;} .row-fluid .span8{width:65.74585634900001%;} .row-fluid .span9{width:74.30939226%;} .row-fluid .span10{width:82.87292817100001%;} .row-fluid .span11{width:91.436464082%;} .row-fluid .span12{width:99.999999993%;} input.span1,textarea.span1,.uneditable-input.span1{width:32px;} input.span2,textarea.span2,.uneditable-input.span2{width:94px;} input.span3,textarea.span3,.uneditable-input.span3{width:156px;} input.span4,textarea.span4,.uneditable-input.span4{width:218px;} input.span5,textarea.span5,.uneditable-input.span5{ width:280px;} input.span6,textarea.span6,.uneditable-input.span6{width:342px;} input.span7,textarea.span7,.uneditable-input.span7{width:404px;} input.span8,textarea.span8,.uneditable-input.span8{width:466px;} input.span9,textarea.span9,.uneditable-input.span9{width:528px;} input.span10,textarea.span10,.uneditable-input.span10{width:590px;} input.span11,textarea.span11,.uneditable-input.span11{width:652px;} input.span12,textarea.span12,.uneditable-input.span12{width:714px;}}@media (max-width:980px){body{padding-top:0;} .navbar-fixed-top{position:static;margin-bottom:18px;} .navbar-fixed-top .navbar-inner{padding:5px;} .navbar .container{width:auto;padding:0;} .navbar .brand{padding-left:10px;padding-right:10px;margin:0 0 0 -5px;} .navbar .nav-collapse{clear:left;} .navbar .nav{float:none;margin:0 0 9px;} .navbar .nav>li{float:none;} .navbar .nav>li>a{margin-bottom:2px;} .navbar .nav>.divider-vertical{display:none;} .navbar .nav>li>a,.navbar .dropdown-menu a{padding:6px 15px;font-weig ht:bold;color:#999999;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;} .navbar .dropdown-menu li+li a{margin-bottom:2px;} .navbar .nav>li>a:hover,.navbar .dropdown-menu a:hover{background-color:#222222;} .navbar .dropdown-menu{position:static;top:auto;left:auto;float:none;display:block;max-width:none;margin:0 15px;padding:0;background-color:transparent;border:none;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;} .navbar .dropdown-menu:before,.navbar .dropdown-menu:after{display:none;} .navbar .dropdown-menu .divider{display:none;} .navbar-form,.navbar-search{float:none;padding:9px 15px;margin:9px 0;border-top:1px solid #222222;border-bottom:1px solid #222222;-webkit-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.1);-moz-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.1);box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.1),0 1px 0 rgba(255, 255, 255, 0.1);} .navbar .nav.pull-right{float:none;margin-left:0;} .navbar-static .navbar-inner{padding-left:10px;padding-right:10px;} .btn-navbar{display:block;} .nav-collapse{overflow:hidden;height:0;}}@media (min-width:980px){.nav-collapse.collapse{height:auto !important;}}@media (min-width:1200px){.row{margin-left:-30px;*zoom:1;}.row:before,.row:after{display:table;content:"";} .row:after{clear:both;} [class*="span"]{float:left;margin-left:30px;} .span1{width:70px;} .span2{width:170px;} .span3{width:270px;} .span4{width:370px;} .span5{width:470px;} .span6{width:570px;} .span7{width:670px;} .span8{width:770px;} .span9{width:870px;} .span10{width:970px;} .span11{width:1070px;} .span12,.container{width:1170px;} .offset1{margin-left:130px;} .offset2{margin-left:230px;} .offset3{margin-left:330px;} .offset4{margin-left:430px;} .offset5{margin-left:530px;} .offset6{margin-left:630px;} .offset7{margin-left:730px;} .offset8{margin-left:830px;} .offset9{margin-left:930px;} . offset10{margin-left:1030px;} .offset11{margin-left:1130px;} .row-fluid{width:100%;*zoom:1;}.row-fluid:before,.row-fluid:after{display:table;content:"";} .row-fluid:after{clear:both;} .row-fluid>[class*="span"]{float:left;margin-left:2.564102564%;} .row-fluid>[class*="span"]:first-child{margin-left:0;} .row-fluid .span1{width:5.982905983%;} .row-fluid .span2{width:14.529914530000001%;} .row-fluid .span3{width:23.076923077%;} .row-fluid .span4{width:31.623931624%;} .row-fluid .span5{width:40.170940171000005%;} .row-fluid .span6{width:48.717948718%;} .row-fluid .span7{width:57.264957265%;} .row-fluid .span8{width:65.81196581200001%;} .row-fluid .span9{width:74.358974359%;} .row-fluid .span10{width:82.905982906%;} .row-fluid .span11{width:91.45299145300001%;} .row-fluid .span12{width:100%;} input.span1,textarea.span1,.uneditable-input.span1{width:60px;} input.span2,textarea.span2,.uneditable-input.span2{width:160px;} input.span3,textarea.span3,.uneditable-input.span3{width:260px;} inpu t.span4,textarea.span4,.uneditable-input.span4{width:360px;} input.span5,textarea.span5,.uneditable-input.span5{width:460px;} input.span6,textarea.span6,.uneditable-input.span6{width:560px;} input.span7,textarea.span7,.uneditable-input.span7{width:660px;} input.span8,textarea.span8,.uneditable-input.span8{width:760px;} input.span9,textarea.span9,.uneditable-input.span9{width:860px;} input.span10,textarea.span10,.uneditable-input.span10{width:960px;} input.span11,textarea.span11,.uneditable-input.span11{width:1060px;} input.span12,textarea.span12,.uneditable-input.span12{width:1160px;} .thumbnails{margin-left:-30px;} .thumbnails>li{margin-left:30px;}}
http://git-wip-us.apache.org/repos/asf/activemq/blob/2ecf41d0/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings-white.png ---------------------------------------------------------------------- diff --git a/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings-white.png b/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings-white.png new file mode 100644 index 0000000..a20760b Binary files /dev/null and b/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings-white.png differ http://git-wip-us.apache.org/repos/asf/activemq/blob/2ecf41d0/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings.png ---------------------------------------------------------------------- diff --git a/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings.png b/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings.png new file mode 100644 index 0000000..92d4445 Binary files /dev/null and b/assembly/src/release/examples/mqtt/websocket/img/glyphicons-halflings.png differ http://git-wip-us.apache.org/repos/asf/activemq/blob/2ecf41d0/assembly/src/release/examples/mqtt/websocket/index.html ---------------------------------------------------------------------- diff --git a/assembly/src/release/examples/mqtt/websocket/index.html b/assembly/src/release/examples/mqtt/websocket/index.html new file mode 100644 index 0000000..9b45268 --- /dev/null +++ b/assembly/src/release/examples/mqtt/websocket/index.html @@ -0,0 +1,198 @@ +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> + <title>Chat Example Using MQTT Over WebSockets</title> + <!--[if lt IE 9]> + <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script> + <![endif]--> + <link href="css/bootstrap.min.css" rel="stylesheet"> + <link href="css/bootstrap.min.responsive.css" rel="stylesheet"> + <style type="text/css"> + body { padding-top: 40px; } + </style> + </head> + + <body> + + <div class="navbar navbar-fixed-top"> + <div class="navbar-inner"> + <div class="container"> + <a class="brand" href="#">ActiveMQ MQTT WebSocket Chat Example</a> + </div> + </div> + </div> + + <div class="container-fluid"> + <div class="row-fluid"> + <div class="span6"> + <div id="connect"> + <div class="page-header"> + <h2>Server Login</h2> + </div> + <form class="form-horizontal" id='connect_form'> + <fieldset> + <div class="control-group"> + <label>Host</label> + <div class="controls"> + <input name=host id='connect_host' value='localhost' type="text"> + </div> + </div> + <div class="control-group"> + <label>Port</label> + <div class="controls"> + <input name=url id='connect_port' value='61623' type="text"> + </div> + </div> + <div class="control-group"> + <label>Client ID</label> + <div class="controls"> + <input id='connect_clientId' placeholder="id" value="example" type="text"> + </div> + </div> + <div class="control-group"> + <label>User ID</label> + <div class="controls"> + <input id='connect_user' placeholder="User ID" value="admin" type="text"> + </div> + </div> + <div class="control-group"> + <label>Password</label> + <div class="controls"> + <input id='connect_password' placeholder="User Password" value="password" type="password"> + </div> + </div> + <div class="control-group"> + <label>Destination</label> + <div class="controls"> + <input id='destination' placeholder="Destination" value="chat/general" type="text"> + </div> + </div> + <div class="form-actions"> + <button id='connect_submit' type="submit" class="btn btn-large btn-primary">Connect</button> + </div> + </fieldset> + </form> + </div> + <div id="connected" style="display:none"> + <div class="page-header"> + <h2>Chat Room</h2> + </div> + <div id="messages"> + </div> + <form class="well form-search" id='send_form'> + <button class="btn" type="button" id='disconnect' style="float:right">Disconnect</button> + <input class="input-medium" id='send_form_input' placeholder="Type your message here" class="span6"/> + <button class="btn" type="submit">Send</button> + </form> + </div> + </div> + <div class="span4"> + <div class="page-header"> + <h2>Debug Log</h2> + </div> + <pre id="debug"></pre> + </div> + </div> + </div> + + <!-- Scripts placed at the end of the document so the pages load faster --> + <script src='js/jquery-1.7.2.min.js'></script> + <script src="js/mqttws31.js"></script> + <script>//<![CDATA[ +$(document).ready(function(){ + if( !window.WebSocket) { + $("#connect").html("\ + <h1>Get a new Web Browser!</h1>\ + <p>\ + Your browser does not support WebSockets. This example will not work properly.<br>\ + Please use a Web Browser with WebSockets support (WebKit or Google Chrome).\ + </p>\ + "); + } else { + + var client, destination; + + $('#connect_form').submit(function() { + var host = $("#connect_host").val(); + var port = $("#connect_port").val(); + var clientId = $("#connect_clientId").val(); + var user = $("#connect_user").val(); + var password = $("#connect_password").val(); + + destination = $("#destination").val(); + + + client = new Messaging.Client(host, Number(port), clientId); + + client.onConnect = onConnect; + + client.onMessageArrived = onMessageArrived; + client.onConnectionLost = onConnectionLost; + + client.connect({ + userName:user, + password:password, + onSuccess:onConnect, + onFailure:onFailure + }); + return false; + }); + + // the client is notified when it is connected to the server. + var onConnect = function(frame) { + debug("connected to MQTT"); + $('#connect').fadeOut({ duration: 'fast' }); + $('#connected').fadeIn(); + client.subscribe(destination); + }; + + // this allows to display debug logs directly on the web page + var debug = function(str) { + $("#debug").append(document.createTextNode(str + "\n")); + }; + + $('#disconnect').click(function() { + client.disconnect(); + $('#connected').fadeOut({ duration: 'fast' }); + $('#connect').fadeIn(); + $("#messages").html("") + return false; + }); + + $('#send_form').submit(function() { + var text = $('#send_form_input').val(); + if (text) { + message = new Messaging.Message(text); + message.destinationName = destination; + client.send(message); + $('#send_form_input').val(""); + } + return false; + }); + + function onFailure(failure) { + debug("failure"); + debug(failure.errorMessage); + } + + function onMessageArrived(message) { + var p = document.createElement("p"); + var t = document.createTextNode(message.payloadString); + p.appendChild(t); + $("#messages").append(p); + } + + function onConnectionLost(responseObject) { + if (responseObject.errorCode !== 0) { + debug(client.clientId + ": " + responseObject.errorCode + "\n"); + } + } + + + } +}); + //]]></script> + + </body> +</html>
