1 $expires = 30; //クッキーの保持日数
\r
2 $afk_time = 1000 * 60 * 60; //AFKと判定する時間(ミリ秒で指定すること)
\r
3 $log_file_name = "logfile%d.txt"; //ログファイル名(%dはそのままにしておくこと)
\r
4 $pastlogfile_pattern = "logfile%d(_+.*)?\.txt"; //過去ログと判定する正規表現
\r
5 $system_name = "system"; //システム発言を表す名前(chat.phpと同じにすること)
\r
6 $entered_message = "%sが入室しました";
\r
7 $quited_message = "%sが退室しました";
\r
8 $system_msg_color ="#000000";
\r
9 $profile_link = "/profile/detail?name=%n" //プロフィールシステムへのリンク先(%nで名前を表す)
\r
10 $fanble_message = "[color=blue]%s ファンブル![/color]";
\r
11 $critical_message = "[color=red]%s クリティカル![/color]";
\r
12 $send_message = "%sからの送信 %s";
\r
13 $failed_connect_message = "接続に失敗しました";
\r
14 $invaild_name_message = "名前を空欄にすることはできません";
\r
15 $free_password1 = "最初に入室する人が自由にパスワードを設定できます"; //自由パスワードメッセージ1
\r
16 $free_password2 = "この部屋は使用されています。パスワードを入力してください"; //自由パスワードメッセージ2
\r
17 $fixed_password = "この部屋にはパスワードが設定されています"; //固定パスワードルーム
\r
18 $hidden_log_to_rom = "この部屋ではROMできないようになっています"; //ROM禁止ルーム
\r
19 $romcount_msg = "ROM(%d人)" //ROMカウント
\r
22 $prefix_filelist = "!";
\r
23 $socket = new Object();
\r
29 $(document).ready(function(){
\r
33 var temp = $.cookie("name");
\r
34 if(temp) document.enter_form.name.value = temp;
\r
35 temp = $.cookie("color_index");
\r
36 if(temp) document.enter_form.color.selectedIndex = temp;
\r
38 $("input[name=sid]").click(sidEventListener);
\r
39 $("input[name=enter]").click(enterEventListener);
\r
40 $("input[name=quit]").click(quitEventListener);
\r
41 $("input[name=help]").click(function(e){
\r
42 $("#help_frame").css("display","block");
\r
44 $("input[name=close]").click(function(e){
\r
45 $("#help_frame").css("display","none");
\r
47 $("#whisper_list_view").click(function(e){
\r
48 $("#whisper_list").toggle();
\r
50 $("#decoration_list_view").click(function(e){
\r
51 $("#decoration_list").toggle();
\r
53 document.chat_form.onsubmit = function(){return false;};
\r
54 document.enter_form.onsubmit = function(){return false;};
\r
56 $socket = io.connect(location.hostname + "/" + document.chat_form.rno.value + "?token="+ encodeURIComponent(document.chat_form._csrf.value));
\r
57 $socket.on("error",getErrorMessage);
\r
58 $socket.on("send roominfo",sendRoomInfoListerner);
\r
59 $socket.on("send romcount",sendRomCountListerner);
\r
60 $socket.on("connect",function(){
\r
61 $socket.on("req pastlog",pastLogEventListerner);
\r
62 $socket.on("req msg",getMessageEventListerner);
\r
66 function sendRomCountListerner(count)
\r
72 function sendRoomInfoListerner(info)
\r
79 msg = $free_password2;
\r
81 msg = $free_password1;
\r
83 }else if(info.type == 2){
\r
84 msg = $fixed_password;
\r
86 }else if(info.type == 3){
\r
87 msg = $hidden_log_to_rom;
\r
91 $("#enter_message").append(msg);
\r
98 function CreateColorList()
\r
100 var c = new Array("00","33","66","99","CC","FF");
\r
101 for(var r = 0; r < c.length; r++){
\r
102 for(var g = 0; g < c.length; g++){
\r
103 for(var b = 0; b < c.length; b++){
\r
104 var t = document.createElement("option");
\r
105 t.value = "#"+c[r]+c[g]+c[b];
\r
106 t.style.backgroundColor = "#"+c[r]+c[g]+c[b];
\r
107 t.appendChild(document.createTextNode("#"+c[r]+c[g]+c[b]));
\r
108 $("#enter_frame form select[name=color]").append(t);
\r
114 function getCurretLog()
\r
116 var rno = document.chat_form.rno.value;
\r
117 var url = sprintf($log_file_name,rno);
\r
118 $socket.emit("get pastLog",url);
\r
121 function pastLogEventListerner(msg)
\r
123 if(IsRomMode() && $roominfo.type != 0 && $roominfo.admin == false)
\r
125 for(var i = 0; i < msg.length; i++)
\r
126 ParseMessage(msg[i]);
\r
130 function getMessageEventListerner(msg)
\r
132 if(IsRomMode() && $roominfo.type != 0)
\r
136 if( document.getElementById("bell").checked == true && msg.name != document.enter_form.name.value)
\r
137 document.getElementById("NoticeSound").play();
\r
140 var $messageTag = null;
\r
141 function ParseMessage(msg)
\r
143 var util = new Util();
\r
144 msg.message = util.htmlspecialchars(msg.message);
\r
145 var childtag = $GetCommandParser.parse(msg);
\r
147 if(childtag == null)
\r
149 if(typeof(childtag) == "string")
\r
150 childtag = $("<span/>").append(childtag);
\r
152 var trtag = $("<tr/>");
\r
153 var namepart,msgpart;
\r
155 var color = $system_msg_color;
\r
158 var date = new Date(Date.parse(msg.date));
\r
159 var name = util.htmlspecialchars(msg.name);
\r
160 if(name != $system_name)
\r
162 color = $names[name].color;
\r
163 $names[name].time = date.getTime();
\r
164 namepart = $("<a/>")
\r
165 .attr("href",GetNameLink(name))
\r
166 .attr("target","_blank")
\r
167 .css("color",color)
\r
170 namepart = $("<span/>").append(name);
\r
173 namepart.append("@" + msg.ip);
\r
174 trtag.append($("<td/>").append(namepart));
\r
177 .append("(" + date.toFormat("YYYY/MM/DD HH:MI:SS") +")")
\r
178 .css("color",color);
\r
179 trtag.append($("<td/>").append(msgpart));
\r
181 if($messageTag == null)
\r
182 $messageTag = $("#message");
\r
184 $messageTag.prepend(trtag);
\r
187 function GetNameLink(name)
\r
189 var util = new Util();
\r
190 if($names[name].mailto == "")
\r
191 return $profile_link.replace("%n",encodeURIComponent(name));
\r
192 return "mailto:" + util.htmlspecialchars($names[name].mailto);
\r
195 function createNameList()
\r
197 var date = new Date();
\r
198 $("#whisper_list").empty();
\r
199 $("#whisper_list").append("<ul></ul>");
\r
201 $("#namelist").empty();
\r
202 $("#namelist").append("<ul></ul>");
\r
203 $("#namelist > ul").append($("<li/>").append(sprintf($romcount_msg,$romcount)));
\r
205 for(var name in $names)
\r
207 var diff = date.getTime() - $names[name].time;
\r
208 if(diff >= $afk_time)
\r
210 if(name != $system_name)
\r
212 var atag = $("<a/>")
\r
213 .attr("href",GetNameLink(name))
\r
214 .attr("target","_blank")
\r
215 .css("color",$names[name].color)
\r
217 var spantag = $("<span/>")
\r
218 .click(clickNameEventListener)
\r
220 $("#whisper_list > ul").append($("<li/>").append(spantag));
\r
221 $("#namelist > ul").append($("<li/>").append(atag));
\r
226 function clickNameEventListener(e)
\r
228 document.chat_form.message.value = "/tell " + $(this).text();
\r
229 document.chat_form.message.focus();
\r
234 var text = GetSelection(document.chat_form.message);
\r
235 ReplaceSelection(document.chat_form.message,sprintf("[b]%s[/b]",text));
\r
238 function AddItalic()
\r
240 var text = GetSelection(document.chat_form.message);
\r
241 ReplaceSelection(document.chat_form.message,sprintf("[i]%s[/i]",text));
\r
244 function AddStrike()
\r
246 var text = GetSelection(document.chat_form.message);
\r
247 ReplaceSelection(document.chat_form.message,sprintf("[s]%s[/s]",text));
\r
250 function AddFontSize(size)
\r
252 var text = GetSelection(document.chat_form.message);
\r
253 ReplaceSelection(document.chat_form.message,sprintf("[size=%f]%s[/size]",size,text));
\r
256 function GetSelection(element)
\r
258 if (document.selection) {
\r
260 var sel = document.selection.createRange();
\r
262 } else if (element.selectionStart || element.selectionStart === 0) {
\r
263 var startPos = element.selectionStart;
\r
264 var endPos = element.selectionEnd;
\r
265 var scrollTop = element.scrollTop;
\r
266 return element.value.substring(startPos,endPos);
\r
272 function ReplaceSelection(element,text)
\r
274 if (document.selection) {
\r
276 var sel = document.selection.createRange();
\r
278 } else if (element.selectionStart || element.selectionStart === 0) {
\r
279 var startPos = element.selectionStart;
\r
280 var endPos = element.selectionEnd;
\r
281 element.value = element.value.substring(0, startPos) + text + element.value.substring(endPos, element.value.length);
\r
283 element.value = text;
\r
287 function enterEventListener()
\r
289 if(document.enter_form.name.value == "")
\r
291 alert($invaild_name_message);
\r
295 $("#enter_frame").css("display","none");
\r
296 $("#chat_frame").css("display","block");
\r
298 var color = document.enter_form.color.options[document.enter_form.color.selectedIndex].value;
\r
300 $.cookie("name",document.enter_form.name.value,{ expires: $expires });
\r
301 $.cookie("color_index",document.enter_form.color.selectedIndex,{ expires: $expires });
\r
303 $socket.json.emit("join",{name:document.enter_form.name.value,color:color,mailto:document.enter_form.mailto.value,password:document.enter_form.password.value});
\r
306 function quitEventListener(){
\r
307 $socket.json.emit("quit",{name:document.enter_form.name.value});
\r
309 $("#enter_frame").css("display","block");
\r
310 $("#chat_frame").css("display","none");
\r
312 if($roominfo.type != 0 && $roominfo.admin == false)
\r
314 $("#message").empty();
\r
315 $("#namelist").empty();
\r
320 $socket.json.emit("get pastLogList",{rno:document.chat_form.rno.value});
\r
323 function sidEventListener(){
\r
325 name:document.enter_form.name.value,
\r
326 message:document.chat_form.message.value
\r
328 msg.message = $PostCommandParser.parse(msg);
\r
330 if(msg.message != null && msg.message != "")
\r
331 $socket.json.emit("send msg",msg);
\r
333 document.chat_form.message.value ="";
\r
336 function ReflushChatMessage(flag)
\r
338 if(flag) $("#message").empty();
\r
341 function getErrorMessage(text)
\r
344 alert($failed_connect_message);
\r
349 function IsRomMode()
\r
351 return $("#chat_frame").css("display") == "none";
\r
354 //NameCollectionクラス
\r
355 function GetNameCollection(text)
\r
357 var output = new Array();
\r
358 var list = text.split("\n");
\r
359 for(var i = 0; i < list.length; i++)
\r
363 output.push(new NameElement(list[i]));
\r
369 // NamesElementsクラス
\r
371 function NameElement(s)
\r
373 this.data = s.split("<>");
\r
374 this.getName = function()
\r
376 return this.data[0];
\r
381 function CreateNameInfo(time,color,mailto)
\r
383 var result = { time:time,color:color,mailto:""};
\r
384 if(typeof(mailto) != "undifined")
\r
385 result.mailto = mailto;
\r
394 this.get_random_number = function (a,b)
\r
396 return Math.floor(a + Math.random() * b);
\r
399 this.htmlspecialchars = function (ch) {
\r
400 ch = ch.replace(/&/g,"&") ;
\r
401 ch = ch.replace(/"/g,""") ;
\r
402 ch = ch.replace(/'/g,"'") ;
\r
403 ch = ch.replace(/</g,"<") ;
\r
404 ch = ch.replace(/>/g,">") ;
\r