Client plugins loading correctly with new HTML templates
[KiwiIRC.git] / client / src / index.html.tmpl
CommitLineData
8eb39b80
D
1<!DOCTYPE html>\r
2<html>\r
3<head>\r
2b3eb5b9 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
aa92fb91 10<link rel="shortcut icon" href="<%base_path%>/assets/img/favicon.ico">\r
2b3eb5b9 11\r
8eb39b80 12<link rel="stylesheet" type="text/css" href="<%base_path%>/assets/css/style.css" />\r
b20715f9 13<link rel="stylesheet" type="text/css" href="<%base_path%>/assets/css/font-awesome.min.css" />\r
8eb39b80
D
14<!--[if IE 7]>\r
15<link rel="stylesheet" type="text/css" href="/kiwi/assets/css/font-awesome-ie7.css" />\r
16<![endif]-->\r
17</head>\r
18<body>\r
8eb39b80 19\r
9aa4b87d
D
20 <script type="text/html" id="tmpl_application">\r
21 <div id="kiwi" class="theme_relaxed">\r
22 <div class="toolbar">\r
23 <div class="app_tools">\r
24 <ul class="main">\r
25 <li class="settings"><i class="icon-cogs" title="Settings"></i></li>\r
26 <li><a href="https://kiwiirc.com/" target="_blank"><img src="<%base_path%>/assets/img/ico.png" alt="KiwiIRC" title="KiwiIRC" /></a></li>\r
27 </ul>\r
28 </div>\r
8eb39b80 29\r
9aa4b87d 30 <div class="tabs"></div>\r
8eb39b80 31\r
9aa4b87d
D
32 <div class="topic">\r
33 <div contenteditable="true"></div>\r
34 </div>\r
8eb39b80 35\r
9aa4b87d 36 <div class="status_message"></div>\r
8eb39b80 37 </div>\r
8eb39b80 38\r
9aa4b87d 39 <div class="memberlists_resize_handle"></div>\r
8eb39b80 40\r
9aa4b87d
D
41 <div class="panels">\r
42 <div class="panel_container container1"></div>\r
43 </div>\r
8eb39b80 44\r
9aa4b87d 45 <div class="memberlists disabled"></div>\r
8eb39b80 46\r
9aa4b87d
D
47 <div class="controlbox">\r
48 <div class="input">\r
49 <span class="nick"> </span>\r
50 <div class="input_wrap"><textarea class="inp"></textarea></div>\r
51 <div class="input_tools"></div>\r
52 </div>\r
53 </div>\r
54 </div>\r
55 </script>\r
8eb39b80 56\r
64bdb2ff 57\r
8eb39b80
D
58 <script type="text/html" id="tmpl_userbox">\r
59 <div class="userbox">\r
17de6c75
D
60 <a class="close_menu if_op op"><i class="icon-star"></i><%= op %></a>\r
61 <a class="close_menu if_op deop"><i class="icon-star-empty"></i><%= de_op %></a>\r
62 <a class="close_menu if_op voice"><i class="icon-volume-up"></i><%= voice %></a>\r
63 <a class="close_menu if_op devoice"><i class="icon-volume-off"></i><%= de_voice %></a>\r
64 <a class="close_menu if_op kick"><i class="icon-remove"></i><%= kick %></a>\r
65 <a class="close_menu if_op ban"><i class="icon-ban-circle"></i><%= ban %></a>\r
66\r
67 <a class="close_menu query"><i class="icon-comment"></i><%= message %></a>\r
68 <a class="close_menu info"><i class="icon-info-sign"></i><%= info %></a>\r
69 <a class="close_menu slap"><i class="icon-user-md"></i><%= slap %></a>\r
8eb39b80
D
70 </div>\r
71 </script>\r
64bdb2ff 72\r
8eb39b80
D
73 <script type="text/html" id="tmpl_nickchange">\r
74 <form class="nickchange">\r
0d29c21f 75 <label for="nickchange"><%= new_nick %>:</label> <input type="text" mozactionhint="done" autocomplete="off" spellcheck="false"/> <button><%= change %></button> <a class="cancel"><%= cancel %></a>\r
8eb39b80
D
76 </form>\r
77 </script>\r
78\r
21e3d147
D
79 <script type="text/html" id="tmpl_new_connection_info">\r
80 <div style="margin:1em 20px;">\r
2c110a31 81 <img src="<%base_path%>/assets/img/ico.png" alt="KiwiIRC Logo" title="Kiwi IRC" style="display:block; margin:0 auto;"/> <br />\r
21e3d147
D
82 <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
83\r
84 <p style="font-size:0.9em;margin-top:2em;">Peek at the <a href="https://www.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
85 </div>\r
86 </script>\r
87\r
8eb39b80
D
88 <script type="text/html" id="tmpl_server_select">\r
89 <div class="server_select">\r
90\r
21e3d147
D
91 <div class="side_panel" style="position:absolute;top:0px;left:320px;">\r
92 <div class="content" style="position:relative;width:300px;">\r
93 </div>\r
94 </div>\r
95\r
3735e390 96 <div class="server_details" style="position:relative;width:320px;">\r
0d29c21f 97 <div class="status"><%= think_nick %></div>\r
8eb39b80
D
98\r
99 <form>\r
100 <div class="basic">\r
bac3c32e
D
101 <table>\r
102 <tr class="nick">\r
0d29c21f 103 <td><label for="server_select_nick"><%= nickname %></label></td>\r
bac3c32e
D
104 <td><input type="text" class="nick" id="server_select_nick"></td>\r
105 </tr>\r
106\r
107 <tr class="have_pass">\r
108 <td colspan="2">\r
0d29c21f 109 <label for="server_select_show_pass"><%= have_password %></label> <input type="checkbox" id="server_select_show_pass" style="width:auto;" />\r
bac3c32e
D
110 </td>\r
111 </tr>\r
112\r
113 <tr class="pass">\r
0d29c21f 114 <td><label for="server_select_password"><%= password %></label></td>\r
bac3c32e
D
115 <td><input type="password" class="password" id="server_select_password"></td>\r
116 </tr>\r
117\r
118 <tr class="channel">\r
0d29c21f 119 <td><label for="server_select_channel"><%= channel %></label></td>\r
700ef8ba
D
120 <td>\r
121 <div style="position:relative;">\r
122 <input type="text" class="channel" id="server_select_channel">\r
0d29c21f 123 <i class="icon-key" title="<%= channel_key %>"></i>\r
700ef8ba
D
124 </div>\r
125 </td>\r
9f67f0f2
JA
126 </tr>\r
127\r
128 <tr class="have_key">\r
129 <td colspan="2">\r
0d29c21f 130 <label for="server_select_show_channel_key"><%= require_key %></label> <input type="checkbox" id="server_select_show_channel_key" style="width:auto;" />\r
9f67f0f2
JA
131 </td>\r
132 </tr>\r
133\r
134 <tr class="key">\r
0d29c21f 135 <td><label for="server_select_channel_key"><%= key %></label></td>\r
b1e93bfa 136 <td><input type="password" class="channel_key" id="server_select_channel_key"></td>\r
bac3c32e
D
137 </tr>\r
138\r
139 <tr class="start">\r
6c800c47
D
140 <td></td>\r
141 <td><button type="submit"><%= start %></button></td>\r
bac3c32e
D
142 </tr>\r
143 </table>\r
144\r
e70e1023 145 <a href="" onclick="return false;" class="show_more"><%= server_network %> <i class="icon-caret-down"></i></a>\r
8eb39b80
D
146 </div>\r
147\r
bf3d49ee 148\r
bac3c32e
D
149 <div class="more">\r
150 <table>\r
151 <tr class="server">\r
0d29c21f 152 <td><label for="server_select_server"><%= server %></label></td>\r
bac3c32e
D
153 <td><input type="text" class="server" id="server_select_server"></td>\r
154 <tr>\r
155\r
156 <tr class="port">\r
0d29c21f 157 <td><label for="server_select_port"><%= port %></label></td>\r
bac3c32e
D
158 <td><input type="text" class="port" id="server_select_port"></td>\r
159 </tr>\r
160\r
161 <tr class="ssl">\r
162 <td><label for="server_select_ssl">SSL</label></td>\r
163 <td><input type="checkbox" class="ssl" id="server_select_ssl"></td>\r
164 </tr>\r
165 </table>\r
8eb39b80
D
166 </div>\r
167 </form>\r
168\r
155d9f1d 169 <a class="kiwi_logo" href="https://kiwiirc.com/" target="_blank">\r
0d29c21f 170 <h1><span><%= powered_by %></span> <img src="<%base_path%>/assets/img/ico.png" alt="KiwiIRC Logo" title="Kiwi IRC" /></h1>\r
8eb39b80 171 </a>\r
8eb39b80
D
172 </div>\r
173 </div>\r
174 </script>\r
175\r
176 <script type="text/html" id="tmpl_applet_settings">\r
5720c80a 177 <div class="settings_container">\r
41e7e25b
VC
178 <section>\r
179 <h6>Theme</h6>\r
f1bc407a 180 <div class="control-group">\r
41e7e25b
VC
181 <div class="thumbnails">\r
182 <a class="thumbnail" data-setting="theme" data-value="relaxed" href="#">\r
34edea2e 183 <div class="thumbnail_wrapper"><div class="theme_color" style="background-color: #e7e7e7;"></div></div>\r
41e7e25b
VC
184 <div class="caption"><u>Relaxed</u></div>\r
185 </a>\r
186 <a class="thumbnail" data-setting="theme" data-value="mini" href="#">\r
34edea2e 187 <div class="thumbnail_wrapper"><div class="theme_color" style="background-color: #fff;"></div></div>\r
41e7e25b
VC
188 <div class="caption"><u>Mini</u></div>\r
189 </a>\r
190 <a class="thumbnail" data-setting="theme" data-value="cli" href="#">\r
34edea2e 191 <div class="thumbnail_wrapper"><div class="theme_color" style="background-color: #222;"></div></div>\r
41e7e25b
VC
192 <div class="caption"><u>CLI</u></div>\r
193 </a>\r
194 <a class="thumbnail" data-setting="theme" data-value="basic" href="#">\r
34edea2e 195 <div class="thumbnail_wrapper"><div class="theme_color" style="background-color: #e7e7e7;"></div></div>\r
41e7e25b
VC
196 <div class="caption"><u>Basic</u></div>\r
197 </a>\r
198 </div>\r
199 </div>\r
200 </section>\r
201\r
202 <section>\r
203 <h6>Channels</h6>\r
f1bc407a 204 <div class="control-group">\r
41e7e25b
VC
205 <div class="radio">\r
206 <label>\r
207 <input type="radio" name="channel_list_style" data-setting="channel_list_style" value="tabs">\r
0d29c21f 208 <%= tabs %>\r
41e7e25b
VC
209 </label>\r
210 </div>\r
211 <div class="radio">\r
212 <label>\r
213 <input type="radio" name="channel_list_style" data-setting="channel_list_style" value="list">\r
0d29c21f 214 <%= list %><small class="text-muted">(<%= large_amounts_of_chans %>)</small>\r
41e7e25b
VC
215 </label>\r
216 </div>\r
217 </div>\r
218 </section>\r
219\r
220 <section>\r
221 <h6>Chat window</h6>\r
f1bc407a 222 <div class="control-group">\r
41e7e25b
VC
223 <div class="checkbox">\r
224 <label>\r
225 <input data-setting="show_joins_parts" type="checkbox">\r
0d29c21f 226 <%= join_part %>\r
41e7e25b
VC
227 </label>\r
228 </div>\r
229 <div class="checkbox">\r
230 <label>\r
231 <input data-setting="show_timestamps" type="checkbox">\r
0d29c21f 232 <%= timestamps %>\r
41e7e25b
VC
233 </label>\r
234 </div>\r
235 <div class="checkbox">\r
236 <label>\r
237 <input data-setting="mute_sounds" type="checkbox">\r
0d29c21f 238 <%= mute %>\r
41e7e25b
VC
239 </label>\r
240 </div>\r
2eacc942
JA
241 <div class="checkbox">\r
242 <label>\r
243 <input data-setting="show_emoticons" type="checkbox">\r
244 <%= emoticons %>\r
245 </label>\r
246 </div>\r
41e7e25b
VC
247 <label>\r
248 <input data-setting="scrollback" class="input-small" type="text" size="4" pattern="\d*">\r
0d29c21f 249 <span><%= scroll_history %></span>\r
41e7e25b
VC
250 </label>\r
251 </div>\r
252 </section>\r
ed5b9cd6 253\r
b54ef9a3 254 <section class="language">\r
0fa2ca42
JA
255 <h6>Language</h6>\r
256 <div class="control-group">\r
257 <select data-setting="locale">\r
0fa2ca42
JA
258 <% _.forEach(languages, function(lang) { %>\r
259 <option value="<%= lang.tag %>"><%= lang.language %></li>\r
260 <% }); %>\r
261 </select>\r
b54ef9a3
D
262 <br>\r
263 <small><%= locale_restart_needed %></small>\r
0fa2ca42
JA
264 </div>\r
265 </section>\r
266\r
9264ef74 267 <section class="protocol_handler">\r
0d29c21f 268 <h6><%= default_client %></h6>\r
ed5b9cd6 269 <div class="control-group">\r
0d29c21f 270 <button class="register_protocol"><%= make_default %></button>\r
ed5b9cd6 271 <br>\r
0d29c21f 272 <small><%= default_note %></small>\r
ed5b9cd6
JA
273 </div>\r
274 </section>\r
d70c63d4 275\r
ee2f0962 276 <section class="notification_enabler">\r
d70c63d4
K
277 <h6><%= html5_notifications %></h6>\r
278 <div class="control-group">\r
279 <button class="enable_notifications"><%= enable_notifications %></button>\r
280 </div>\r
281 </section>\r
282\r
8eb39b80
D
283 </div>\r
284 </script>\r
285\r
286\r
287 <script type="text/html" id="tmpl_channel_list">\r
288 <div>\r
289 <table style="margin:1em 2em;">\r
290 <thead style="font-weight: bold;">\r
291 <tr>\r
0d29c21f
JA
292 <td><%= channel_name %></td>\r
293 <td><%= users %></td>\r
294 <td style="padding-left: 2em;"><%= topic %></td>\r
8eb39b80
D
295 </tr>\r
296 </thead>\r
297 <tbody style="vertical-align: top;">\r
298 </tbody>\r
299 </table>\r
300 </div>\r
301 </script>\r
302\r
303\r
22373da6
D
304 <script type="text/html" id="tmpl_script_editor">\r
305 <div style="height:100%;">\r
306 <style>\r
8c3b8ed2
D
307 #kiwi .script_editor .se_toolbar { padding: 10px 20px; }\r
308 #kiwi .script_editor .se_toolbar span.status { margin-left:2em; font-style:italic; }\r
309 #kiwi .script_editor .se_toolbar button { height:30px; padding:0 1em; }\r
310 #kiwi .script_editor .se_toolbar button i { font-size:1.2em; margin-left:3px; }\r
22373da6
D
311 </style>\r
312 <div class="script_editor" style="height:100%; position:relative;">\r
0d29c21f 313 <div class="se_toolbar"><button class="btn_save"><%= save %><i class="icon-save"></i></button><span class="status"></span></div>\r
22373da6
D
314 <div class="editor" style="position:absolute;top:50px;bottom:0px;left:0px;right:0px;"></div>\r
315 </div>\r
316 </div>\r
317 </script>\r
318\r
319\r
497fcc38 320<script src="<%base_path%>/assets/libs/jquery-1.10.2.min.js"></script>\r
8eb39b80
D
321<script>\r
322/* Script loader (https://github.com/ded/script.js) */\r
323(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
324\r
325\r
64bdb2ff
D
326 // Avoid `console` errors in browsers that lack a console. (https://github.com/h5bp/html5-boilerplate)\r
327 function normalizeConsole() {\r
328 var method;\r
329 var noop = function () {};\r
330 var methods = [\r
331 'assert', 'clear', 'count', 'debug', 'dir', 'dirxml', 'error',\r
332 'exception', 'group', 'groupCollapsed', 'groupEnd', 'info', 'log',\r
333 'markTimeline', 'profile', 'profileEnd', 'table', 'time', 'timeEnd',\r
334 'timeStamp', 'trace', 'warn'\r
335 ];\r
336 var length = methods.length;\r
337 var console = (window.console = window.console || {});\r
338\r
339 while (length--) {\r
340 method = methods[length];\r
341\r
342 // Only stub undefined methods.\r
343 if (!console[method]) {\r
344 console[method] = noop;\r
345 }\r
346 }\r
347 };\r
348\r
8eb39b80
D
349 function getQueryVariable(variable) {\r
350 var query = window.location.search.substring(1);\r
351 var vars = query.split('&');\r
352 for (var i = 0; i < vars.length; i++) {\r
353 var pair = vars[i].split('=');\r
354 if (decodeURIComponent(pair[0]) == variable) {\r
355 return decodeURIComponent(pair[1]);\r
356 }\r
357 }\r
358 }\r
359\r
9aa4b87d 360 (function () {\r
cbcd1a23
JA
361 var base_path = '<%base_path%>', // Entry path for the kiwi application\r
362 scripts = [],\r
363 opts = {\r
9aa4b87d 364 container: $('body'),\r
bceb5db6
D
365 base_path: base_path,\r
366 settings_path: base_path + '/assets/settings.json'\r
8eb39b80
D
367 };\r
368\r
64bdb2ff
D
369 normalizeConsole();\r
370\r
040d9360
D
371 /**\r
372 * Job bootup manager\r
373 * Once all jobs have completed, call any registered completed functions\r
374 */\r
375 var jobs = new (function BootManager() {\r
376 var completed_jobs = { };\r
377\r
378 // Functions to call once all jobs have completed\r
379 var completed_callbacks = [];\r
380\r
381\r
382 function callCompletedFunctions(fn) {\r
383 $.each(completed_callbacks, function(idx, fn) {\r
384 fn();\r
385 });\r
386\r
387 completed_callbacks = [];\r
388 };\r
389\r
390\r
391 this.finishJob = function(job_name) {\r
392 if (typeof completed_jobs[job_name] === 'undefined') {\r
393 return;\r
394 }\r
395\r
396 completed_jobs[job_name] = true;\r
397\r
398 // Check if all our jobs have completed\r
399 var all_jobs_completed = true;\r
400 $.each(completed_jobs, function(idx, completed) {\r
401 if (!completed) {\r
402 all_jobs_completed = false;\r
403 return false;\r
404 }\r
405 });\r
406\r
407 if (all_jobs_completed) {\r
408 callCompletedFunctions();\r
409 }\r
410 };\r
411\r
412\r
413 this.onFinish = function(fn) {\r
414 completed_callbacks.push(fn);\r
415 };\r
416\r
417\r
418 this.registerJob = function(job_name) {\r
419 completed_jobs[job_name] = false;\r
420 };\r
421 })();\r
422\r
423\r
cbcd1a23 424 // Run after all dependancies have been loaded\r
040d9360 425 jobs.onFinish(function startApp() {\r
eaaf73b0 426 // Start the app\r
62c18d2d
D
427 kiwi.start(opts, function() {\r
428 // Load any plugins\r
429 if (opts.client_plugins && opts.client_plugins.length > 0) {\r
430 _.each(opts.client_plugins, function (plugin_url) {\r
431 kiwi.plugins.load(plugin_url);\r
432 });\r
433 }\r
434 });\r
040d9360 435 });\r
8eb39b80
D
436\r
437\r
438 // Load each script\r
040d9360 439 jobs.registerJob('load_scripts');\r
8eb39b80
D
440 var cur_script = 0;\r
441 function loadNextScript () {\r
442 var to_load,\r
c3511215 443 base = base_path + '/';\r
8eb39b80
D
444\r
445 // Start the kiwi app if all scripts have been loaded\r
446 if (cur_script === scripts.length) {\r
040d9360 447 jobs.finishJob('load_scripts');\r
8eb39b80
D
448 return;\r
449 }\r
450\r
451 if (typeof scripts[cur_script] === 'string') {\r
452 to_load = base + scripts[cur_script];\r
453 } else {\r
454 to_load = [];\r
455 for(var idx in scripts[cur_script]) {\r
456 to_load.push(base + scripts[cur_script][idx]);\r
457 }\r
458 }\r
64bdb2ff 459\r
8eb39b80
D
460 $script(to_load, loadNextScript);\r
461\r
462 cur_script++;\r
463 }\r
464\r
040d9360
D
465 // If we're not interested in debug libs, start loading production files\r
466 if (!getQueryVariable('debug')) {\r
c3511215 467 scripts.push(['assets/libs/lodash.min.js']);\r
040d9360 468 scripts.push([\r
c3511215
JA
469 'assets/libs/backbone.min.js',\r
470 'assets/libs/jed.js'\r
040d9360
D
471 ]);\r
472 scripts.push([\r
c3511215
JA
473 'assets/kiwi.min.js',\r
474 'assets/libs/engine.io.bundle.min.js'\r
040d9360
D
475 ]);\r
476\r
477 loadNextScript();\r
478 }\r
479\r
cbcd1a23 480 // Load application settings\r
040d9360 481 jobs.registerJob('load_settings');\r
bceb5db6 482 $.getJSON(opts.settings_path, function (data) {\r
cbcd1a23
JA
483 opts.server_settings = data.server_settings;\r
484 opts.client_plugins = data.client_plugins;\r
485 opts.translations = data.translations;\r
486 opts.locale = data.locale;\r
487\r
41cde9d3
D
488 if (typeof data.kiwi_server !== 'undefined')\r
489 opts.kiwi_server = data.kiwi_server;\r
490\r
040d9360
D
491 jobs.finishJob('load_settings');\r
492\r
493 // If debugging, grab the debug scripts and load them\r
494 if (getQueryVariable('debug')) {\r
495 scripts = scripts.concat(data.scripts);\r
496 loadNextScript();\r
497 }\r
cbcd1a23 498 });\r
9aa4b87d
D
499\r
500 jobs.registerJob('window_load');\r
501 window.onload = function() {\r
502 jobs.finishJob('window_load');\r
503 };\r
504 })();\r
8eb39b80
D
505</script>\r
506</body>\r
b1e93bfa 507</html>\r