Файл: pages/account/chat.php
Строк: 116
<?php
session_start();
define('MinRating', 300);
function __autoload($name){ include("../classes/_class.".$name.".php");}
class Chat{
var $db;
function __construct(){
$config = new config;
$this->db = new db($config->HostDB, $config->UserDB, $config->PassDB, $config->BaseDB);
}
function send(){
//$res = $this->db->Query('SELECT `all_time_a`, `all_time_b`, `all_time_c`, `all_time_d`, `all_time_e` FROM `db_users_b` WHERE `user` = "'.$_SESSION["user"].'"');
//$row = $this->db->FetchArray();
//$rating = $row['all_time_a'] + $row['all_time_b'] + $row['all_time_c'] + $row['all_time_d'] + $row['all_time_e'];
// if($rating < MinRating)
// return '<span style="color:#f00">Минимальный рейтинг для отправки сообщений - '.MinRating.'</span>';
$res = $this->db->Query('SELECT `time_uban` FROM `db_chat_ban` WHERE `user` = "'.$_SESSION["user"].'"');
if($this->db->NumRows() > 0){
$row = $this->db->FetchArray();
if($row['time_uban'] > time())
return '<span style="color:#f00">Вы забанены до '.date('Y.m.d H:i', $row['time_uban']).'</span>';
}
if(trim($_POST['comment']) == NULL)
return '<span style="color:#f00">Введите сообщение</span>';
$res = $this->db->Query('SELECT `time` FROM `db_chat` WHERE `user` = "'.$_SESSION["user"].'" ORDER BY `id` DESC LIMIT 1');
$lasttime = $this->db->FetchRow();
if($lasttime > time()- 3)
return '<span style="color:#f00">Нельзя отправлять сообщения так часто.</span>';
$this->db->Query('INSERT INTO `db_chat` (`user`, `to`, `comment`, `time`) VALUES ("'.$_SESSION["user"].'", "'.$this->db->RealEscape($to).'", "'.$this->db->RealEscape($_POST['comment']).'", "'.time().'")');
$this->db->Query('DELETE FROM `db_chat` WHERE `id` < '.($this->db->LastInsert() - 100));
return '<span style="color:#0f0">Сообщение отправлено</span>';
}
function get(){
$res = $this->db->Query('SELECT `chat_moder` FROM `db_users_a` WHERE `user` = "'.$_SESSION["user"].'"');
$chat_moder = $this->db->FetchRow();
$res = $this->db->Query('SELECT * FROM `db_chat` ORDER BY `id` DESC');
$str = NULL;
while($row = $this->db->FetchArray()){
$str .= $this->get_str($row, $chat_moder);
}
return $str;
}
function get_str($row, $chat_moder){
$str = '<span class="user">'.htmlspecialchars($row['user']).'</span> <span class="time">('.date('Y.m.d в H:i:s', $row['time']).')</span>: '.$this->bb_code($row['comment']).'';
if($row['to'] == $_SESSION["user"])
$str = '<span class="to">'.$str.'</span>';
if($chat_moder == 1)
$str .= ' (<a href="/chat/edit/'.$row['id'].'" title="Редактировать">Редакт.</a>
<a href="/chat/del/'.$row['id'].'" title="Удалить">Удалить.</a>
<a href="/chat/ban/'.$row['user'].'" title="Забанить/Розбанить пользователя">Бан/Розбан</a>)';
$str = $str.'<br />';
if($row['type'] == 1){
if($chat_moder != 1 AND $row['to'] != $_SESSION["user"] AND $row['user'] != $_SESSION["user"])
$str = NULL;
else
$str = '<span class="private">'.$str.'</span>';
}
return $str;
}
function _echo($str){
echo $str;
}
function bb_code($str){
$str = htmlspecialchars($str);
$str = preg_replace('#[b](.+?)[/b]#', '<span style="font-weight:900;">$1</span>',$str);
$str = preg_replace('#[i](.+?)[/i]#', '<span style="font-style:italic;">$1</span>',$str);
$str = preg_replace('#[u](.+?)[/u]#', '<span style="text-decoration:underline;">$1</span>',$str);
$str = preg_replace('#[s](.+?)[/s]#', '<span style="text-decoration:line-through;">$1</span>',$str);
$str = preg_replace('#*smile*#', '<img src="/img/chat/smile/smile.gif" alt="" />',$str);
$str = preg_replace('#*sadness*#', '<img src="/img/chat/smile/sadness.gif" alt="" />',$str);
$str = preg_replace('#*laugh*#', '<img src="/img/chat/smile/laugh.gif" alt="" />',$str);
$str = preg_replace('#*wonder*#', '<img src="/img/chat/smile/wonder.gif" alt="" />',$str);
$str = preg_replace('#*tongue*#', '<img src="/img/chat/smile/tongue.gif" alt="" />',$str);
$str = preg_replace('#*dance*#', '<img src="/img/chat/smile/dance.gif" alt="" />',$str);
$str = preg_replace('#*THUMBS_UP*#', '<img src="/img/chat/smile/THUMBS_UP.gif" alt="" />',$str);
$str = preg_replace('#*dont*#', '<img src="/img/chat/smile/dont.gif" alt="" />',$str);
$str = preg_replace('#*kez_02*#', '<img src="/img/chat/smile/kez_02.gif" alt="" />',$str);
$str = preg_replace('#*alvarin_34*#', '<img src="/img/chat/smile/alvarin_34.gif" alt="" />',$str);
$str = preg_replace('#*drag_06*#', '<img src="/img/chat/smile/drag_06.gif" alt="" />',$str);
$str = preg_replace('#*kidrock_07*#', '<img src="/img/chat/smile/kidrock_07.gif" alt="" />',$str);
return $str;
}
}
$chat = new Chat();
if($_GET['p'] == 'send'){
$chat->_echo($chat->send());
}
if($_GET['p'] == 'get'){
$chat->_echo('
<script type="text/javascript">
$(function(){
$('#chat .history .user').click(function(){
$('#chat .message input[name="comment"]').val($(this).text() + ', ' + $('#chat .message input[name="comment"]').val());
$('#chat .message input[name="to"]').val($(this).text());
});
});
</script>'.$chat->get());
}
?>