uff
This commit is contained in:
116
pages/doppelklinge.php
Normal file
116
pages/doppelklinge.php
Normal file
@ -0,0 +1,116 @@
|
||||
<?php
|
||||
require_once __DIR__ . '/../inc/db.inc.php';
|
||||
|
||||
$tpl['file'] = 'doppelklinge.twig';
|
||||
$tpl['data'] = [];
|
||||
|
||||
$tasks = [
|
||||
'auftrag' => [ 'name' => 'Aufträge / Vermessungen', 'max' => 15000 ],
|
||||
'blut' => [ 'name' => 'Blutproben abgegeben', 'max' => 500 ],
|
||||
'gewebe' => [ 'name' => 'Gewebeproben abgegeben', 'max' => 750 ],
|
||||
'gnpc' => [ 'name' => 'Gruppen-NPCs getötet', 'max' => 5000 ],
|
||||
'npc' => [ 'name' => 'NPCs getötet', 'max' => 100000 ],
|
||||
'pflanzen' => [ 'name' => 'Pflanzen geerntet', 'max' => 1500 ],
|
||||
'unique' => [ 'name' => 'Unique-NPCs getötet', 'max' => 2500 ]
|
||||
];
|
||||
|
||||
if(isset($_GET['c'])) {
|
||||
$res = $db->prepare('select * from ft_doppelklinge where uuid = :uuid limit 1');
|
||||
$res->execute([ ':uuid' => $_GET['c'] ]);
|
||||
$arr = $res->fetch($db::FETCH_ASSOC);
|
||||
|
||||
$i = 0;
|
||||
foreach($tasks as $type => $data) {
|
||||
$list[$i] = (object)[
|
||||
'task' => $data['name'],
|
||||
'act' => $arr[$type],
|
||||
'max' => $data['max']
|
||||
];
|
||||
$list[$i]->percent = round($list[$i]->act / $list[$i]->max * 100, 2);
|
||||
$list[$i]->left = $list[$i]->max - $list[$i]->act;
|
||||
$i++;
|
||||
}
|
||||
|
||||
usort($list, function($a, $b) { return $b->percent <=> $a->percent; });
|
||||
|
||||
$act = $max = $avg = 0;
|
||||
for($i = 0; $i < 5; $i++) {
|
||||
$act += $list[$i]->act;
|
||||
$max += $list[$i]->max;
|
||||
$avg += $list[$i]->percent;
|
||||
}
|
||||
$percent = round($act / $max * 100, 2);
|
||||
|
||||
$tpl['data'] = [
|
||||
'progress' => $progress,
|
||||
'list' => $list,
|
||||
'percent' => $percent,
|
||||
'avg' => round($avg / 5, 2),
|
||||
'dt' => date('d.m.Y - H:i:s', strtotime($arr['created_at']))
|
||||
];
|
||||
return;
|
||||
}
|
||||
|
||||
$progress = !empty($_POST['progress']) ? $_POST['progress'] : '';
|
||||
|
||||
if(!empty($progress)) {
|
||||
$list = [];
|
||||
preg_match_all("/(?<task>.*): (?<act>.*) \/ (?<max>.*)/m", $progress, $tmp);
|
||||
|
||||
for($i = 0; $i < count($tmp[0]); $i++) {
|
||||
if(preg_match('/XP\:/', $tmp['task'][$i]))
|
||||
continue;
|
||||
|
||||
$list[$i] = (object)[
|
||||
'task' => trim($tmp['task'][$i]),
|
||||
'act' => (int)str_replace('.', '', $tmp['act'][$i]),
|
||||
'max' => (int)str_replace('.', '', $tmp['max'][$i])
|
||||
];
|
||||
$list[$i]->percent = round($list[$i]->act / $list[$i]->max * 100, 2);
|
||||
$list[$i]->left = $list[$i]->max - $list[$i]->act;
|
||||
}
|
||||
|
||||
$query = <<<SQL
|
||||
replace into ft_doppelklinge
|
||||
(`uuid`, `sessid`, `auftrag`, `blut`, `gewebe`, `gnpc`, `npc`, `pflanzen`, `unique`)
|
||||
values
|
||||
(substr(uuid(), 1, 8), :sessid, :auftrag, :blut, :gewebe, :gnpc, :npc, :pflanzen, :unique)
|
||||
returning uuid;
|
||||
SQL;
|
||||
$insert = $db->prepare($query);
|
||||
$insert->execute([
|
||||
':sessid' => session_id(),
|
||||
':auftrag' => $list[0]->act,
|
||||
':blut' => $list[1]->act,
|
||||
':gewebe' => $list[2]->act,
|
||||
':gnpc' => $list[3]->act,
|
||||
':npc' => $list[4]->act,
|
||||
':pflanzen' => $list[5]->act,
|
||||
':unique' =>$list[6]->act
|
||||
]);
|
||||
|
||||
$uuid = $insert->fetch()->uuid;
|
||||
|
||||
usort($list, function($a, $b) { return $b->percent <=> $a->percent; });
|
||||
|
||||
$act = $max = $avg = 0;
|
||||
for($i = 0; $i < 5; $i++) {
|
||||
$act += $list[$i]->act;
|
||||
$max += $list[$i]->max;
|
||||
$avg += $list[$i]->percent;
|
||||
}
|
||||
$percent = round($act / $max * 100, 2);
|
||||
|
||||
$tpl['data'] = [
|
||||
'progress' => $progress,
|
||||
'list' => $list,
|
||||
'percent' => $percent,
|
||||
'avg' => round($avg / 5, 2),
|
||||
'share' => $uuid
|
||||
];
|
||||
}
|
||||
else {
|
||||
$tpl['data'] = [
|
||||
'progress' => ''
|
||||
];
|
||||
}
|
Reference in New Issue
Block a user