+<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<body>
<div id="kiwi">
<div id="toolbar">
- <ul class="panellist channels"></ul>
+ <div id="tabs">
+ <ul class="panellist channels"></ul>
+ <ul class="panellist applets"></ul>
+ </div>
<div id="topic">
<input type="text" />
</div>
+
+ <div id="status_message"></div>
</div>
<div id="panels">
<input type="text" class="server" id="server_select_server"> <br />
<label for="server_select_channel">Channel</label>
<input type="text" class="channel" id="server_select_channel"> <br />
+ <br />
+ <label for="server_select_port">Port</label>
+ <input type="text" class="port" id="server_select_port"> <br />
+ <label for="server_select_password">Password</label>
+ <input type="text" class="password" id="server_select_password"> <br />
+ <label for="server_select_ssl">SSL</label>
+ <input type="checkbox" class="ssl" id="server_select_ssl">
</div>
</form>
</div>
</script>
+ <script type="text/x-jquery-tmpl" id="tmpl_applet_settings">
+ <div>
+ <select class="theme">
+ <option value="default">Default</option>
+ <option value="relaxed">Relaxed</option>
+ <option value="cli">CLI</option>
+ </select>
+ <button class="save">Save</button>
+ </div>
+ </script>
+
+
+ <script type="text/x=x-jquery-tmpl" id="tmpl_channel_list">
+ <table style="margin:1em 2em;">
+ <thead style="font-weight: bold;">
+ <tr>
+ <td>Channel Name</td>
+ <td>Users</td>
+ <td style="padding-left: 2em;">Topic</td>
+ </tr>
+ </thead>
+ <tbody style="vertical-align: top;">
+ </tbody>
+ </table>
+ </script>
+
+
<script>
+/* Script loader (https://github.com/ded/script.js) */
+(function(a,b,c){typeof c["module"]!="undefined"&&c.module.exports?c.module.exports=b():typeof c["define"]!="undefined"&&c["define"]=="function"&&c.define.amd?define(a,b):c[a]=b()})("$script",function(){function p(a,b){for(var c=0,d=a.length;c<d;++c)if(!b(a[c]))return j;return 1}function q(a,b){p(a,function(a){return!b(a)})}function r(a,b,i){function o(a){return a.call?a():d[a]}function t(){if(!--n){d[m]=1,l&&l();for(var a in f)p(a.split("|"),o)&&!q(f[a],o)&&(f[a]=[])}}a=a[k]?a:[a];var j=b&&b.call,l=j?b:i,m=j?a.join(""):b,n=a.length;return setTimeout(function(){q(a,function(a){if(h[a])return m&&(e[m]=1),h[a]==2&&t();h[a]=1,m&&(e[m]=1),s(!c.test(a)&&g?g+a+".js":a,t)})},0),r}function s(c,d){var e=a.createElement("script"),f=j;e.onload=e.onerror=e[o]=function(){if(e[m]&&!/^c|loade/.test(e[m])||f)return;e.onload=e[o]=null,f=1,h[c]=2,d()},e.async=1,e.src=c,b.insertBefore(e,b.firstChild)}var a=document,b=a.getElementsByTagName("head")[0],c=/^https?:\/\//,d={},e={},f={},g,h={},i="string",j=!1,k="push",l="DOMContentLoaded",m="readyState",n="addEventListener",o="onreadystatechange";return!a[m]&&a[n]&&(a[n](l,function t(){a.removeEventListener(l,t,j),a[m]="complete"},j),a[m]="loading"),r.get=s,r.order=function(a,b,c){(function d(e){e=a.shift(),a.length?r(e,d):r(e,b,c)})()},r.path=function(a){g=a},r.ready=function(a,b,c){a=a[k]?a:[a];var e=[];return!q(a,function(a){d[a]||e[k](a)})&&p(a,function(a){return d[a]})?b():!function(a){f[a]=f[a]||[],f[a][k](b),c&&c(e)}(a.join("|")),r},r},this)
+
+
+
function getQueryVariable(variable) {
var query = window.location.search.substring(1);
// Common dependancies that are required at all times
var scripts = [
- 'jquery-1.7.1.min.js',
- 'underscore-min.js',
- 'backbone-git.js',
- 'http://localhost:7778/socket.io/socket.io.js',
+ ['jquery-1.7.1.min.js', 'underscore-min.js'],
+ 'backbone-git.js'
];
// If in debug mode, load each development script
if (getQueryVariable('debug')) {
+ console.log('Loading debugging scripts');
scripts = scripts.concat([
- 'dev/utils.js',
- 'dev/model.js',
- 'dev/model_application.js',
- 'dev/model_gateway.js',
- 'dev/view.js'
+ 'dev/app.js',
+ [
+ 'dev/model_application.js',
+ 'dev/model_gateway.js'
+ ],
+ [
+ 'dev/model_panellist.js',
+ 'dev/model_panel.js',
+ 'dev/model_member.js',
+ 'dev/model_memberlist.js'
+ ],
+
+ [
+ 'dev/model_channel.js',
+ 'dev/model_server.js',
+ 'dev/model_applet.js'
+ ],
+
+ [
+ 'dev/applet_settings.js',
+ 'dev/applet_nickserv.js'
+ ],
+
+ [
+ 'dev/utils.js',
+ 'dev/view.js'
+ ]
]);
} else {
- scripts.push('kiwi.min.js');
+ scripts.push('kiwi.js');
}
// Run after all dependancies have been loaded
- function startApp () {
- // Only debug if set in the querystring
- if (!getQueryVariable('debug')) {
- manageDebug(false);
- } else {
- manageDebug(true);
- }
- kiwi.app = new kiwi.model.Application({container: $('#kiwi')});
- kiwi.app.start();
+ function startApp () {
+ var opts = {
+ container: $('#kiwi'),
+
+ // Override the kiwi_server to use. (Think: running on standalone client..)
+ kiwi_server: 'http://192.168.1.13:7778'
+ };
+
+ // Start the app by either the dev or closed environment
+ (kiwi && kiwi.global && kiwi.global.start(opts)) || (kiwi && kiwi.start(opts));
}
// Load each script
var cur_script = 0;
function loadNextScript () {
+ // Start the kiwi app if all scripts have been loaded
if (cur_script === scripts.length) {
startApp();
return;
}
- var el = document.createElement('script');
- el.onload = loadNextScript;
- el.src = scripts[cur_script];
- document.getElementsByTagName('head')[0].appendChild(el);
+ $script(scripts[cur_script], loadNextScript);
cur_script++;
}