define(["jquery", "util", "channels", "storage"], function ($, util, channels, storage) {
var recorder = util.Module("recorder");
var assert = util.assert;
var channel = null;
var baseUrl = null;
var clientId = "recorder";
function display(el) {
el = $(el);
var toggles = el.attr("data-toggles");
if (toggles) {
$(toggles).hide();
}
el.show();
}
recorder.start = function (options) {
$(function () {
$("#record").css({height: $(window).height() - 50});
$("#restart").click(function () {
location.reload();
});
$("#select").click(function () {
$("#record").select();
});
recorder.activate(options);
});
};
recorder.activate = function (options) {
var match;
baseUrl = options.baseUrl;
recorder.shareId = TogetherJS.startup._joinShareId;
if (! recorder.shareId) {
match = /\&togetherjs=([^&]+)/.exec(location.hash);
if (! match) {
display("#no-session-id");
return;
}
recorder.shareId = match[1];
}
var hubBase = options.defaultHubBase;
match = /\&hubBase=([^&]+)/.exec(location.hash);
if (match) {
hubBase = match[1];
}
hubBase = hubBase.replace(/\/*$/, "");
var url = hubBase + "/hub/" + recorder.shareId;
channel = channels.WebSocketChannel(url);
channel.onmessage = function (msg) {
if (msg.type == "hello-back") {
display("#connected");
}
if (msg.type == "hello") {
sendHello(true);
}
if (msg.type == "get-logs") {
sendLogs(msg);
return;
}
recorder.logMessage(msg);
};
sendHello(false);
};
function sendHello(helloBack) {
var msg = {
type: helloBack ? "hello-back" : "hello",
name: "Recorder 'bot",