Built in identd server
[KiwiIRC.git] / client / assets / dev / index.html.tmpl
CommitLineData
8eb39b80
D
1<!DOCTYPE html>\r
2<html>\r
3<head>\r
4<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> \r
ecc47600 5<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">\r
8eb39b80
D
6<base target="_blank">\r
7\r
8<title> KiwiIRC </title>\r
9\r
10<link rel="stylesheet" type="text/css" href="<%base_path%>/assets/css/style.css" />\r
11<link rel="stylesheet" type="text/css" href="<%base_path%>/assets/css/font-awesome.css" />\r
12<!--[if IE 7]>\r
13<link rel="stylesheet" type="text/css" href="/kiwi/assets/css/font-awesome-ie7.css" />\r
14<![endif]-->\r
15</head>\r
16<body>\r
17 <div id="kiwi" class="theme_relaxed">\r
18 <div id="toolbar">\r
19 <div class="app_tools">\r
20 <ul class="main">\r
21 <li class="settings"><i class="icon-cogs" title="Settings"></i></li>\r
155d9f1d 22 <li><a href="https://kiwiirc.com/" target="_blank"><img src="<%base_path%>/assets/img/ico.png" alt="KiwiIRC" title="KiwiIRC" /></a></li>\r
8eb39b80
D
23 </ul>\r
24 </div>\r
25\r
26 <div id="tabs">\r
27 <ul class="panellist channels"></ul>\r
28 <ul class="panellist applets"></ul>\r
29 </div>\r
30\r
31 <div id="topic">\r
32 <div contenteditable="true"></div>\r
33 </div>\r
34\r
35 <div id="status_message"></div>\r
36 </div>\r
37\r
38 <div id="memberlists_resize_handle"></div>\r
39\r
40 <div id="panels">\r
41 <div class="panel_container container1"></div>\r
42 </div>\r
43\r
44 <div id="memberlists"></div>\r
45\r
46 <div id="controlbox">\r
47 <div class="input">\r
48 <span class="nick"> </span>\r
49 <div class="input_wrap"><textarea class="inp"></textarea></div>\r
50 </div>\r
51 </div>\r
52 </div>\r
53\r
54\r
55\r
56\r
57\r
58 \r
59 <script type="text/html" id="tmpl_userbox">\r
60 <div class="userbox">\r
61 <a class="query"><i class="icon-comment"></i>Message</a>\r
62 <a class="info"><i class="icon-info-sign"></i>Info</a>\r
63 <a class="slap"><i class="icon-user-md"></i>Slap!</a>\r
64\r
65 <div class="divider-horizontal"></div>\r
66 </div>\r
67 </script>\r
68 \r
69 <script type="text/html" id="tmpl_nickchange">\r
70 <form class="nickchange">\r
71 <label for="nickchange">New nick:</label> <input type="text" mozactionhint="done" autocomplete="off" spellcheck="false"/> <button>Change</button> <a class="cancel">Cancel</a>\r
72 </form>\r
73 </script>\r
74\r
75 <script type="text/html" id="tmpl_server_select">\r
76 <div class="server_select">\r
77\r
43ad0845 78 <div class="server_details" style="position:relative;float:left;width:320px;padding-right:3em;margin-top:50px;">\r
8eb39b80
D
79 <div class="status">Think of a nickname..</div>\r
80\r
81 <form>\r
82 <div class="basic">\r
bac3c32e
D
83 <table>\r
84 <tr class="nick">\r
85 <td><label for="server_select_nick">Nickname</label></td>\r
86 <td><input type="text" class="nick" id="server_select_nick"></td>\r
87 </tr>\r
88\r
89 <tr class="have_pass">\r
90 <td colspan="2">\r
91 <label for="server_select_show_pass">I have a password</label> <input type="checkbox" id="server_select_show_pass" style="width:auto;" />\r
92 </td>\r
93 </tr>\r
94\r
95 <tr class="pass">\r
96 <td><label for="server_select_password">Password</label></td>\r
97 <td><input type="password" class="password" id="server_select_password"></td>\r
98 </tr>\r
99\r
100 <tr class="channel">\r
101 <td><label for="server_select_channel">Channel</label></td>\r
102 <td><input type="text" class="channel" id="server_select_channel"><input type="hidden" class="channel_key"></td>\r
103 </tr>\r
104\r
105 <tr class="start">\r
106 <td colspan="2"><button type="submit">Start..</button></td>\r
107 </tr>\r
108 </table>\r
109\r
110 <a href="" onclick="return false;" class="show_more">Server and network</a>\r
8eb39b80
D
111 </div>\r
112\r
bf3d49ee 113\r
bac3c32e
D
114 <div class="more">\r
115 <table>\r
116 <tr class="server">\r
117 <td><label for="server_select_server">Server</label></td>\r
118 <td><input type="text" class="server" id="server_select_server"></td>\r
119 <tr>\r
120\r
121 <tr class="port">\r
122 <td><label for="server_select_port">Port</label></td>\r
123 <td><input type="text" class="port" id="server_select_port"></td>\r
124 </tr>\r
125\r
126 <tr class="ssl">\r
127 <td><label for="server_select_ssl">SSL</label></td>\r
128 <td><input type="checkbox" class="ssl" id="server_select_ssl"></td>\r
129 </tr>\r
130 </table>\r
8eb39b80
D
131 </div>\r
132 </form>\r
133\r
134 <div class="divider-verticle"></div>\r
135 </div>\r
136\r
43ad0845 137 <div class="about_kiwi" style="position:relative;float:left;width:320px;margin-left:3em;color:#555555;">\r
155d9f1d 138 <a class="kiwi_logo" href="https://kiwiirc.com/" target="_blank">\r
8eb39b80
D
139 <img src="<%base_path%>/assets/img/ico.png" alt="KiwiIRC Logo" title="Kiwi IRC" /> <br />\r
140 <h1>Powered by Kiwi IRC</h1>\r
141 </a>\r
142\r
143 <p style="font-style:italic;">A <strong>hand-crafted IRC client</strong> that you can enjoy. Designed to be used <strong>easily</strong> and <strong>freely</strong>.</p>\r
144\r
155d9f1d 145 <p style="font-size:0.9em;margin-top:2em;">Peek at the <a href="https://kiwiirc.com/">Kiwi IRC homepage</a> for more information or to find out how to embed it on your own website. Looking for source code? Try the <a href="http://github.com/prawnsalad/KiwiIRC/">GitHub</a> page. This network of people may not be associated with Kiwi IRC itself.</p>\r
8eb39b80
D
146 </div>\r
147 </div>\r
148 </script>\r
149\r
150 <script type="text/html" id="tmpl_applet_settings">\r
93fa049c
D
151 <div class="settings">\r
152 ​<table>\r
153 <tr>\r
039a3156
D
154 <td class="label">Theme</td>\r
155 <td class="setting">\r
93fa049c 156 <select class="setting-theme">\r
93fa049c 157 <option value="relaxed">Relaxed</option>\r
43ad0845 158 <option value="mini">Mini</option>\r
93fa049c 159 <option value="cli">CLI</option>\r
e48a02c8 160 <option value="basic">Basic</option>\r
93fa049c
D
161 </select>\r
162 </td>\r
163 </tr>\r
164 <tr>\r
039a3156
D
165 <td class="label">Channel list</td>\r
166 <td class="setting">\r
167 <select class="setting-channel_list_style">\r
168 <option value="list">List</option>\r
169 <option value="tabs">Tabs</option>\r
170 </select>\r
171\r
172 <i style="font-size:0.9em;">Lots of channels? `List` may be more suited</i>\r
173 </td>\r
174 </tr>\r
175 <tr>\r
176 <td class="label">Scrollback</td>\r
177 <td class="setting"><input type="text" class="setting-scrollback" value="150" /></td>\r
93fa049c
D
178 </tr>\r
179\r
180 <tr>\r
039a3156
D
181 <td class="label">Show joins/parts</td>\r
182 <td class="setting"><input type="checkbox" class="setting-show_joins_parts" /></td>\r
93fa049c 183 </tr>\r
93fa049c 184\r
039a3156
D
185 <tr class="save">\r
186 <td colspan="2"><button class="save">Save</button>​​​​​​​​​</td>\r
187 </tr>\r
188 </table>\r
8eb39b80
D
189 </div>\r
190 </script>\r
191\r
192\r
193 <script type="text/html" id="tmpl_channel_list">\r
194 <div>\r
195 <table style="margin:1em 2em;">\r
196 <thead style="font-weight: bold;">\r
197 <tr>\r
198 <td>Channel Name</td>\r
199 <td>Users</td>\r
200 <td style="padding-left: 2em;">Topic</td>\r
201 </tr>\r
202 </thead>\r
203 <tbody style="vertical-align: top;">\r
204 </tbody>\r
205 </table>\r
206 </div>\r
207 </script>\r
208\r
209\r
22373da6
D
210 <script type="text/html" id="tmpl_script_editor">\r
211 <div style="height:100%;">\r
212 <style>\r
213 #kiwi .script_editor .toolbar { padding: 10px 20px; }\r
214 #kiwi .script_editor .toolbar span.status { margin-left:2em; font-style:italic; }\r
215 #kiwi .script_editor .toolbar button { height:30px; padding:0 1em; }\r
216 #kiwi .script_editor .toolbar button i { font-size:1.2em; margin-left:3px; }\r
217 </style>\r
218 <div class="script_editor" style="height:100%; position:relative;">\r
219 <div class="toolbar"><button class="btn_save">Save <i class="icon-save"></i></button><span class="status"></span></div>\r
220 <div class="editor" style="position:absolute;top:50px;bottom:0px;left:0px;right:0px;"></div>\r
221 </div>\r
222 </div>\r
223 </script>\r
224\r
225\r
8eb39b80
D
226<script>\r
227/* Script loader (https://github.com/ded/script.js) */\r
228(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)\r
229\r
230\r
231\r
232\r
233 function getQueryVariable(variable) {\r
234 var query = window.location.search.substring(1);\r
235 var vars = query.split('&');\r
236 for (var i = 0; i < vars.length; i++) {\r
237 var pair = vars[i].split('=');\r
238 if (decodeURIComponent(pair[0]) == variable) {\r
239 return decodeURIComponent(pair[1]);\r
240 }\r
241 }\r
242 }\r
243\r
244 window.onload = function () {\r
245\r
246 // Common dependancies that are required at all times\r
247 var scripts = [\r
f9ff7686 248 ['jquery-1.8.2.min.js', 'lodash.min.js'],\r
8eb39b80
D
249 'backbone.min.js'\r
250 ];\r
251\r
252 // If in debug mode, load each development script\r
253 if (getQueryVariable('debug')) {\r
254 console.log('Loading debugging scripts');\r
255 scripts = scripts.concat([\r
256 'dev/app.js',\r
257 [\r
258 'dev/model_application.js',\r
259 'dev/model_gateway.js'\r
260 ],\r
261 [\r
262 'dev/model_panellist.js',\r
263 'dev/model_panel.js',\r
264 'dev/model_member.js',\r
265 'dev/model_memberlist.js'\r
266 ],\r
267 \r
268 [\r
269 'dev/model_query.js',\r
270 'dev/model_channel.js',\r
271 'dev/model_server.js',\r
272 'dev/model_applet.js'\r
273 ],\r
274\r
275 [\r
276 'dev/applet_settings.js',\r
277 'dev/applet_nickserv.js',\r
22373da6
D
278 'dev/applet_chanlist.js',\r
279 'dev/applet_scripteditor.js'\r
8eb39b80
D
280 ],\r
281\r
282 [\r
890a9b91 283 'dev/model_pluginmanager.js',\r
5bed0536 284 'dev/model_datastore.js',\r
8eb39b80
D
285 'dev/utils.js',\r
286 'dev/view.js'\r
287 ]\r
288 ]);\r
289 } else {\r
290 scripts.push('kiwi.min.js?<%cache_buster%>');\r
291 }\r
292\r
293\r
294 // Run after all dependancies have been loaded\r
295 function startApp () {\r
296 var opts = {\r
297 container: $('#kiwi'),\r
93e84f75 298 base_path: base_path,\r
8eb39b80
D
299\r
300 // Override the kiwi_server to use. (Think: running on standalone client..)\r
93e84f75
D
301 //kiwi_server: 'http://kiwiirc.com:80',\r
302\r
2eec3842
D
303 server_settings: <%server_settings%>,\r
304 client_plugins: <%client_plugins%>\r
8eb39b80
D
305 };\r
306\r
eaaf73b0
D
307 // Start the app\r
308 kiwi.start(opts);\r
2eec3842
D
309\r
310 // Load any plugins\r
311 if (opts.client_plugins && opts.client_plugins.length > 0) {\r
312 _.each(opts.client_plugins, function (plugin_url) {\r
313 kiwi.plugins.load(plugin_url);\r
314 });\r
315 }\r
8eb39b80
D
316 }\r
317\r
318\r
319 // Load each script\r
320 var cur_script = 0;\r
321 function loadNextScript () {\r
322 var to_load,\r
323 base = base_path + '/assets/';\r
324\r
325 // Start the kiwi app if all scripts have been loaded\r
326 if (cur_script === scripts.length) {\r
327 startApp();\r
328 return;\r
329 }\r
330\r
331 if (typeof scripts[cur_script] === 'string') {\r
332 to_load = base + scripts[cur_script];\r
333 } else {\r
334 to_load = [];\r
335 for(var idx in scripts[cur_script]) {\r
336 to_load.push(base + scripts[cur_script][idx]);\r
337 }\r
338 }\r
339 \r
340 $script(to_load, loadNextScript);\r
341\r
342 cur_script++;\r
343 }\r
344\r
345 // Entry path for the kiwi application\r
346 var base_path = '<%base_path%>';\r
347\r
348 // Start loading scripts\r
349 loadNextScript();\r
350 };\r
351</script>\r
352</body>\r
2dd6a025 353</html>