query (" SELECT hlstats_Players.lastName, hlstats_Players.game FROM hlstats_Players WHERE hlstats_Players.playerId = $player "); if ($db->num_rows() != 1) { error("No such player '$player'."); } $playerdata = $db->fetch_array(); $pl_name = $playerdata['lastName']; if (strlen($pl_name) > 10) { $pl_shortname = substr($pl_name, 0, 8) . '...'; } else { $pl_shortname = $pl_name; } $pl_name = htmlspecialchars($pl_name, ENT_COMPAT); $pl_shortname = htmlspecialchars($pl_shortname, ENT_COMPAT); $game = $playerdata['game']; $db->query (" SELECT hlstats_Games.name FROM hlstats_Games WHERE hlstats_Games.code = '$game' "); if ($db->num_rows() != 1) { $gamename = ucfirst($game); } else { list($gamename) = $db->fetch_row(); } pageHeader ( array ($gamename, 'Event History', $pl_name), array ( $gamename=>$g_options['scripturl'] . "?game=$game", 'Player Rankings'=>$g_options['scripturl'] . "?mode=players&game=$game", 'Player Details'=>$g_options['scripturl'] . "?mode=playerinfo&player=$player", 'Event History'=>'' ), $playername ); flush(); $table = new Table ( array ( new TableColumn ( 'eventTime', 'Date', 'width=20' ), new TableColumn ( 'eventType', 'Type', 'width=10&align=center' ), new TableColumn ( 'eventDesc', 'Description', 'width=40&sort=no&append=.&embedlink=yes' ), new TableColumn ( 'serverName', 'Server', 'width=20' ), new TableColumn ( 'map', 'Map', 'width=10' ) ), 'eventTime', 'eventTime', 'eventType', false, 50, 'page', 'sort', 'sortorder' ); $surl = $g_options['scripturl']; // This would be better done with a UNION query, I think, but MySQL doesn't // support them yet. (NOTE you need MySQL 3.23 for temporary table support.) $db->query (" DROP TABLE IF EXISTS hlstats_EventHistory "); $db->query (" CREATE TEMPORARY TABLE hlstats_EventHistory ( eventType VARCHAR(32) NOT NULL, eventTime DATETIME NOT NULL, eventDesc VARCHAR(255) NOT NULL, serverName VARCHAR(255) NOT NULL, map VARCHAR(64) NOT NULL ) DEFAULT CHARSET=utf8 "); function insertEvents ($table, $select) { global $db; $select = str_replace("", "hlstats_Events_$table", $select); $db->query (" INSERT INTO hlstats_EventHistory ( eventType, eventTime, eventDesc, serverName, map ) $select "); } insertEvents ('TeamBonuses', " SELECT 'Team Bonus',
.eventTime, CONCAT('My team received a points bonus of ', bonus, ' for triggering \"', IFNULL(hlstats_Actions.description,'Unknown'), '\"'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Actions ON
.actionId = hlstats_Actions.id LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player AND hlstats_Actions.game = '$game' "); if ($g_options["Mode"] == "LAN") { $uqIdStr = "IP Address:"; } else { $uqIdStr = "Unique ID:"; } insertEvents ('Connects', " SELECT 'Connect',
.eventTime, CONCAT('I connected to the server'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('Disconnects', " SELECT 'Disconnect',
.eventTime, 'I left the game', IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('Entries', " SELECT 'Entry',
.eventTime, 'I entered the game', IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('Frags', " SELECT 'Kill',
.eventTime, CONCAT('I killed %A%$surl?mode=playerinfo&player=', victimId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A%', ' with ', weapon), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.victimId WHERE
.killerId = $player AND
.headshot = 0 "); insertEvents ('Frags', " SELECT 'Kill',
.eventTime, CONCAT('I killed %A%$surl?mode=playerinfo&player=', victimId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A%', ' with a headshot from ', weapon), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.victimId WHERE
.killerId = $player AND
.headshot = 1 "); insertEvents ('Frags', " SELECT 'Death',
.eventTime, CONCAT('%A%$surl?mode=playerinfo&player=', killerId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A%', ' killed me with ', weapon), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.killerId WHERE
.victimId = $player "); insertEvents ('Teamkills', " SELECT 'Team Kill',
.eventTime, CONCAT('I killed teammate %A%$surl?mode=playerinfo&player=', victimId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A%', ' with ', weapon), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.victimId WHERE
.killerId = $player "); insertEvents ('Teamkills', " SELECT 'Friendly Fire',
.eventTime, CONCAT('My teammate %A%$surl?mode=playerinfo&player=', killerId, '%', IFNULL(hlstats_Players.lastName, 'Unknown'), '%/A%', ' killed me with ', weapon), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.killerId WHERE
.victimId = $player "); insertEvents ('ChangeRole', " SELECT 'Role',
.eventTime, CONCAT('I changed role to ', role), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('ChangeName', " SELECT 'Name',
.eventTime, CONCAT('I changed my name from \"', oldName, '\" to \"', newName, '\"'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('PlayerActions', " SELECT 'Action',
.eventTime, CONCAT('I received a points bonus of ', bonus, ' for triggering \"', IFNULL(hlstats_Actions.description,'Unknown'), '\"'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Actions ON hlstats_Actions.id =
.actionId WHERE
.playerId = $player AND hlstats_Actions.game = '$game' "); insertEvents ('PlayerPlayerActions', " SELECT 'Action',
.eventTime, CONCAT('I received a points bonus of ', bonus, ' for triggering \"', IFNULL(hlstats_Actions.description,'Unknown'), '\" against %A%$surl?mode=playerinfo&player=', victimId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A%'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Actions ON hlstats_Actions.id =
.actionId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.victimId WHERE
.playerId = $player AND hlstats_Actions.game = '$game' "); insertEvents ('PlayerPlayerActions', " SELECT 'Action',
.eventTime, CONCAT('%A%$surl?mode=playerinfo&player=',
.playerId, '%', IFNULL(hlstats_Players.lastName,'Unknown'), '%/A% triggered \"', IFNULL(hlstats_Actions.description,'Unknown'), '\" against me'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Actions ON hlstats_Actions.id =
.actionId LEFT JOIN hlstats_Players ON hlstats_Players.playerId =
.playerId WHERE
.victimId = $player AND hlstats_Actions.game = '$game' "); insertEvents ('Suicides', " SELECT 'Suicide',
.eventTime, CONCAT('I committed suicide with \"', weapon, '\"'), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId WHERE
.playerId = $player "); insertEvents ('ChangeTeam', " SELECT 'Team',
.eventTime, IF(hlstats_Teams.name IS NULL, CONCAT('I joined team \"', team, '\"'), CONCAT('I joined team \"', team, '\" (', hlstats_Teams.name, ')')), IFNULL(hlstats_Servers.name, 'Unknown'),
.map FROM
LEFT JOIN hlstats_Servers ON hlstats_Servers.serverId =
.serverId LEFT JOIN hlstats_Teams ON hlstats_Teams.code =
.team WHERE
.playerId = $player AND hlstats_Teams.game = '$game' "); $result = $db->query (" SELECT hlstats_EventHistory.eventTime, hlstats_EventHistory.eventType, hlstats_EventHistory.eventDesc, hlstats_EventHistory.serverName, hlstats_EventHistory.map FROM hlstats_EventHistory ORDER BY $table->sort $table->sortorder, $table->sort2 $table->sortorder LIMIT $table->startitem, $table->numperpage "); $resultCount = $db->query (" SELECT COUNT(*) FROM hlstats_EventHistory "); list($numitems) = $db->fetch_row($resultCount); ?>
0) { $table->draw($result, $numitems, 95); } ?>

Go to: ">'s Statistics