mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2025-01-22 02:00:40 +00:00
parent
8b8bf4649c
commit
46d86de030
@ -651,7 +651,7 @@ Fetch the roomlist from the server and update it in the GUI.
|
||||
for room in data.returnValues
|
||||
li = $ '<li></li>'
|
||||
li.addClass 'active' if room.active
|
||||
$("""<a href="#{room.link}">#{room.title}</a>""").addClass('timsChatRoom').data('roomID', room.roomID).appendTo li
|
||||
$("""<a href="#{room.link}">#{room.title} <span class="badge">#{WCF.String.formatNumeric room.userCount}</span></a>""").addClass('timsChatRoom').data('roomID', room.roomID).appendTo li
|
||||
$('#timsChatRoomList ul').append li
|
||||
|
||||
if window.history?.replaceState?
|
||||
|
@ -23,6 +23,13 @@ class Room extends \chat\data\CHATDatabaseObject implements \wcf\system\request\
|
||||
*/
|
||||
protected static $databaseTableIndexName = 'roomID';
|
||||
|
||||
/**
|
||||
* cached users
|
||||
*
|
||||
* @var array<\wcf\data\user\UserProfile>
|
||||
*/
|
||||
protected static $users = null;
|
||||
|
||||
/**
|
||||
* @see \wcf\data\chat\room\ChatRoom::getTitle();
|
||||
*/
|
||||
@ -133,36 +140,27 @@ class Room extends \chat\data\CHATDatabaseObject implements \wcf\system\request\
|
||||
return \wcf\system\WCF::getLanguage()->get($this->topic);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the number of users currently active in this room.
|
||||
*
|
||||
* @return integer
|
||||
*/
|
||||
public function countUsers() {
|
||||
$sql = "SELECT
|
||||
COUNT(*)
|
||||
FROM
|
||||
wcf".WCF_N."_user
|
||||
WHERE
|
||||
chatRoomID = ?";
|
||||
$stmt = WCF::getDB()->prepareStatement($sql);
|
||||
$stmt->execute(array($this->roomID));
|
||||
|
||||
return $stmt->fetchColumn();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the users that are currently active in this room.
|
||||
*
|
||||
* @return \wcf\data\user\UserProfileList
|
||||
* @return array<\wcf\data\user\UserProfile>
|
||||
*/
|
||||
public function getUsers() {
|
||||
$userList = new \wcf\data\user\UserProfileList();
|
||||
$userList->getConditionBuilder()->add('user_table.chatRoomID = ?', array($this->roomID));
|
||||
if (self::$users === null) {
|
||||
$userList = new \wcf\data\user\UserProfileList();
|
||||
$userList->getConditionBuilder()->add('user_table.chatRoomID IS NOT NULL', array());
|
||||
|
||||
$userList->readObjects();
|
||||
$users = $userList->getObjects();
|
||||
|
||||
foreach ($users as $user) {
|
||||
if (!isset(self::$users[$user->chatRoomID])) self::$users[$user->chatRoomID] = array();
|
||||
self::$users[$user->chatRoomID][] = $user;
|
||||
}
|
||||
}
|
||||
if (!isset(self::$users[$this->roomID])) self::$users[$this->roomID] = array();
|
||||
|
||||
$userList->readObjects();
|
||||
|
||||
return $userList;
|
||||
return self::$users[$this->roomID];
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -149,7 +149,8 @@ class RoomAction extends \wcf\data\AbstractDatabaseObjectAction implements \wcf\
|
||||
'object' => $room
|
||||
)),
|
||||
'roomID' => $room->roomID,
|
||||
'active' => $room->roomID == $this->parameters['room']->roomID
|
||||
'active' => $room->roomID == $this->parameters['room']->roomID,
|
||||
'userCount' => count($room->getUsers())
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -46,7 +46,7 @@ class NewMessagesPage extends \wcf\page\AbstractPage {
|
||||
/**
|
||||
* All the users that are currently in the room $this->room.
|
||||
*
|
||||
* @var array<\wcf\data\user\User>
|
||||
* @var array<\wcf\data\user\UserProfile>
|
||||
*/
|
||||
public $users = array();
|
||||
|
||||
@ -114,7 +114,7 @@ class NewMessagesPage extends \wcf\page\AbstractPage {
|
||||
$json['messages'][] = $message->jsonify(true);
|
||||
}
|
||||
|
||||
\wcf\system\user\storage\UserStorageHandler::getInstance()->loadStorage(array_keys($this->users->getObjects()));
|
||||
\wcf\system\user\storage\UserStorageHandler::getInstance()->loadStorage(array_keys($this->users));
|
||||
|
||||
foreach ($this->users as $user) {
|
||||
$json['users'][] = array(
|
||||
|
Loading…
x
Reference in New Issue
Block a user