* @author Slawkens * @copyright 2017 MyAAC * @link http://my-aac.org */ defined('MYAAC') or die('Direct access not allowed!'); $title = 'Highscores'; if($config['account_country'] && $config['highscores_country_box']) require(SYSTEM . 'countries.conf.php'); $list = isset($_GET['list']) ? $_GET['list'] : ''; $_page = isset($_GET['page']) ? $_GET['page'] : 0; $vocation = isset($_GET['vocation']) ? $_GET['vocation'] : NULL; $add_sql = ''; $config_vocations = $config['vocations']; if($config['highscores_vocation_box'] && isset($vocation)) { for($i = 1; $i < count($config_vocations) / 2; $i++) { if(strtolower($config_vocations[$i]) == $vocation) { $add_sql = 'AND ' . $db->fieldName('vocation') . ' = ' . $db->quote($i); break; } } } $skill = POT::SKILL__LEVEL; if(is_numeric($list)) { $list = intval($list); if($list >= POT::SKILL_FIRST && $list <= SKILL__LAST) $skill = $list; } else { switch($list) { case 'fist': $skill = POT::SKILL_FIST; break; case 'club': $skill = POT::SKILL_CLUB; break; case 'sword': $skill = POT::SKILL_SWORD; break; case 'axe': $skill = POT::SKILL_AXE; break; case 'distance': $skill = POT::SKILL_DIST; break; case 'shield': $skill = POT::SKILL_SHIELD; break; case 'fishing': $skill = POT::SKILL_FISH; break; case 'level': $skill = POT::SKILL_LEVEL; break; case 'magic': $skill = POT::SKILL__MAGLEVEL; break; case 'frags': if($config['highscores_frags'] && $config['otserv_version'] == TFS_03) $skill = 666; break; } } $promotion = ''; if(fieldExist('promotion', 'players')) $promotion = ',promotion'; $online = ''; if(fieldExist('online', 'players')) $online = ',online'; $deleted = 'deleted'; if(fieldExist('deletion', 'players')) $deleted = 'deletion'; $outfit_addons = false; $outfit = ''; if($config['highscores_outfit']) { $outfit = ', lookbody, lookfeet, lookhead, looklegs, looktype'; if(fieldExist('lookaddons', 'players')) { $outfit .= ', lookaddons'; $outfit_addons = true; } } $offset = $_page * $config['highscores_length']; if($skill <= POT::SKILL_LAST) { // skills if(fieldExist('skill_fist', 'players')) {// tfs 1.0 $skill_ids = array( POT::SKILL_FIST => 'skill_fist', POT::SKILL_CLUB => 'skill_club', POT::SKILL_SWORD => 'skill_sword', POT::SKILL_AXE => 'skill_axe', POT::SKILL_DIST => 'skill_dist', POT::SKILL_SHIELD => 'skill_shielding', POT::SKILL_FISH => 'skill_fishing', ); $skills = $db->query('SELECT accounts.country, players.id,players.name' . $online . ',level,vocation' . $promotion . $outfit . ', ' . $skill_ids[$skill] . ' as value FROM accounts,players WHERE players.id NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND players.' . $deleted . ' = 0 AND players.group_id < '.$config['highscores_groups_hidden'].' '.$add_sql.' AND players.id > 6 AND accounts.id = players.account_id ORDER BY ' . $skill_ids[$skill] . ' DESC LIMIT 101 OFFSET '.$offset); } else $skills = $db->query('SELECT accounts.country, players.id,players.name' . $online . ',value,level,vocation' . $promotion . $outfit . ' FROM accounts,players,player_skills WHERE players.id NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND players.' . $deleted . ' = 0 AND players.group_id < '.$config['highscores_groups_hidden'].' '.$add_sql.' AND players.id > 6 AND players.id = player_skills.player_id AND player_skills.skillid = '.$skill.' AND accounts.id = players.account_id ORDER BY value DESC, count DESC LIMIT 101 OFFSET '.$offset); } else if($skill == 666 && $config['otserv_version'] == TFS_03) // frags { $skills = $db->query('SELECT accounts.country, players.id,players.name' . $online . ',level,vocation' . $promotion . $outfit . ',COUNT(`player_killers`.`player_id`) as value' . ' FROM `accounts`, `players`, `player_killers` ' . ' WHERE players.id NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND players.' . $deleted . ' = 0 AND players.group_id < '.$config['highscores_groups_hidden'].' '.$add_sql.' AND players.id = player_killers.player_id AND accounts.id = players.account_id' . ' GROUP BY `player_id`' . ' ORDER BY value DESC' . ' LIMIT 101 OFFSET '.$offset); } else { if($skill == POT::SKILL__MAGLEVEL) { $skills = $db->query('SELECT accounts.country, players.id,players.name' . $online . ',maglevel,level,vocation' . $promotion . $outfit . ' FROM accounts, players WHERE players.id NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND players.' . $deleted . ' = 0 '.$add_sql.' AND players.group_id < '.$config['highscores_groups_hidden'].' AND players.id > 6 AND accounts.id = players.account_id ORDER BY maglevel DESC, manaspent DESC LIMIT 101 OFFSET '.$offset); } else { // level $skills = $db->query('SELECT accounts.country, players.id,players.name' . $online . ',level,experience,vocation' . $promotion . $outfit . ' FROM accounts, players WHERE players.id NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND players.' . $deleted . ' = 0 '.$add_sql.' AND players.group_id < '.$config['highscores_groups_hidden'].' AND players.id > 6 AND accounts.id = players.account_id ORDER BY level DESC, experience DESC LIMIT 101 OFFSET '.$offset); $list = 'experience'; } } ?>

Ranking for on


query('SELECT `player_id` FROM `players_online` WHERE `player_id` = ' . $player['id']); $player['online'] = $query->rowCount() > 0; } if(++$i <= $config['highscores_length']) { if($skill == POT::SKILL__MAGIC) $player['value'] = $player['maglevel']; else if($skill == POT::SKILL__LEVEL) $player['value'] = $player['level']; echo ' '; if($config['account_country']) echo ''; echo ' '; if($config['highscores_outfit']) echo ''; echo ' '; if($skill == POT::SKILL__LEVEL) echo ''; echo ''; } else $show_link_to_next_page = true; } if(!$i) echo ''; ?>
# Rank Outfit Name Points
' . getFlagImage($player['country']) . '' . ($offset + $i) . '. ' . $player['name'] . ' '; if($config['highscores_vocation']) { if(isset($player['promotion'])) { if((int)$player['promotion'] > 0) $player['vocation'] += ($player['promotion'] * $config['vocations_amount']); } echo '
' . $config['vocations'][$player['vocation']] . ''; } echo '
'.$player['value'].'
' . number_format($player['experience']) . '
No records yet.
0) echo ''; //link to next page if any result will be on next page if($show_link_to_next_page) echo ''; //end of page echo '
Previous Page
Next Page
'; /* if($config['highscores_country_box']) { echo '
Choose a country
[ALL]
'; for($i = 1; $i < count($config_vocations); $i++) echo '' . $config_vocations[$i] . '
'; echo '
'; }*/ echo '
Choose a skill
'; $types = array( 'experience' => 'Experience', 'magic' => 'Magic', 'shield' => 'Shielding', 'distance' => 'Distance', 'club' => 'Club', 'sword' => 'Sword', 'axe' => 'Axe', 'fist' => 'Fist', 'fishing' => 'Fishing', ); foreach($types as $link => $name) { echo '' . $name . '
'; } if($config['highscores_frags']) echo 'Frags
'; echo '

'; if($config['highscores_vocation_box']) { echo '
Choose a vocation
[ALL]
'; for($i = 1; $i <= $config['vocations_amount']; $i++) { echo '' . $config_vocations[$i] . '
'; } echo '
'; } ?>