Splitta kadavertabellen og minikadavertabellen
This commit is contained in:
parent
fdddbbb0ef
commit
b30996ceea
11
admin.php
11
admin.php
@ -37,6 +37,11 @@
|
||||
</menu>
|
||||
</nav>
|
||||
<button class="danger" onclick="log_out()">Logg ut</button>
|
||||
<div class='flex' hx-get="/api/statistics.php" hx-trigger="every 5s">
|
||||
<?php
|
||||
include("api/statistics.php");
|
||||
?>
|
||||
</div>
|
||||
<h1>Søk opp løper</h1>
|
||||
<form action="/api/runner.php" method="GET" hx-boost="true" hx-target="#runner_info" hx-swap="show:none">
|
||||
<label>
|
||||
@ -54,9 +59,13 @@
|
||||
<output id="emails"></output>
|
||||
</div>
|
||||
<h1>Løpende resultater</h1>
|
||||
<h2>Kadaverløpet</h2>
|
||||
<div class='flex' hx-get="api/table.php?type=liveresultater" hx-trigger="load, every 5s"></div>
|
||||
<h2>Minikadaver'n</h2>
|
||||
<div class='flex' hx-get="api/table.php?type=minikadavern" hx-trigger="load, every 15s"></div>
|
||||
<?php
|
||||
include("api/table.php");
|
||||
liveresult_table($runners);
|
||||
//liveresult_table($runners);
|
||||
?>
|
||||
<script>
|
||||
function update() {
|
||||
|
||||
41
api/statistics.php
Normal file
41
api/statistics.php
Normal file
@ -0,0 +1,41 @@
|
||||
<?php
|
||||
$documentRoot = $_SERVER['DOCUMENT_ROOT'];
|
||||
require_once("$documentRoot/import_runners.php");
|
||||
$method = $_SERVER['REQUEST_METHOD'];
|
||||
if ($method == "GET") {
|
||||
parse_str($_SERVER['QUERY_STRING'], $query);
|
||||
$runners = read_runners_from_csv();
|
||||
$minikadavern = 0;
|
||||
$minikadavern_total = 0;
|
||||
$mat1 = 0;
|
||||
$mat2 = 0;
|
||||
$maal = 0;
|
||||
$total = 0;
|
||||
for ($i = 0; $i < count($runners); $i++) {
|
||||
$runner = $runners[$i];
|
||||
if ($runner->course == "Minikadaver'n") {
|
||||
$minikadavern_total++;
|
||||
if ($runner->get_control() == 2) {
|
||||
$minikadavern++;
|
||||
}
|
||||
}
|
||||
else {
|
||||
$total++;
|
||||
if ($runner->get_control() >= 0) {
|
||||
$mat1++;
|
||||
}
|
||||
if ($runner->get_control() >= 1) {
|
||||
$mat2++;
|
||||
}
|
||||
if ($runner->get_control() == 2) {
|
||||
$maal++;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
echo("
|
||||
<div class='flash accent m-1'><b>$mat1 av $total</b> har passert 1. matpost</div>
|
||||
<div class='flash accent m-1'><b>$mat2 av $total</b> har passert 2. matpost</div>
|
||||
<div class='flash accent m-1'><b>$maal av $total</b> har fullført Kadaver'n</div>
|
||||
<div class='flash accent m-1'><b>$minikadavern av $minikadavern_total</b> har fullført Minikadaver'n</div>");
|
||||
}
|
||||
@ -21,7 +21,7 @@ if(isset($_SERVER['HTTP_IF_NONE_MATCH'])) {
|
||||
}
|
||||
*/
|
||||
|
||||
include("$documentRoot/import_runners.php");
|
||||
require_once("$documentRoot/import_runners.php");
|
||||
|
||||
function registration_table($runners) {
|
||||
parse_str($_SERVER['QUERY_STRING'], $query);
|
||||
@ -127,6 +127,55 @@ function liveresult_table($runners) {
|
||||
<th>Sprekkindeks</th>
|
||||
</tr></thead>
|
||||
<tbody>";
|
||||
$kadaver_num = 0;
|
||||
for ($i = 0; $i < count($runners); $i++) {
|
||||
$runner = $runners[$i];
|
||||
$tid_maal = "";
|
||||
$sprekk = "<td></td>";
|
||||
if ($runner->splits[2] != false) {
|
||||
$tid_maal = $GLOBALS['start_time']->diff($runner->splits[2])->format('%H:%I:%S');
|
||||
}
|
||||
if ($runner->course == "Kadaverløpet") {
|
||||
$kadaver_num++;
|
||||
$tid_1_mat = "";
|
||||
if ($runner->splits[0] != false) {
|
||||
// https://www.php.net/manual/en/class.dateinterval.php
|
||||
$tid_1_mat = $GLOBALS['start_time']->diff($runner->splits[0])->format('%H:%I:%S');
|
||||
}
|
||||
$tid_2_mat = "";
|
||||
|
||||
//tid etter vinner
|
||||
$tid_etter = "";
|
||||
if ($runner->splits[2] != false && $kadaver_num > 0) {
|
||||
$tid_etter = $runners[0]->splits[2]->diff($runner->splits[2])->format('%I:%S');
|
||||
}
|
||||
//sprekkindekss
|
||||
if ($runner->splits[1] != false) {
|
||||
$tid_2_mat = $GLOBALS['start_time']->diff($runner->splits[1])->format('%H:%I:%S');
|
||||
try {
|
||||
$sprekk = "<td>" . number_format(100*(time_diff($GLOBALS['start_time'],$runner->splits[2]) - time_diff($GLOBALS['start_time'],$runner->splits[1])) / time_diff($GLOBALS['start_time'],$runner->splits[2]), 0) . "%</td>";
|
||||
}
|
||||
catch (DivisionByZeroError $e){
|
||||
$sprekk = "<td></td>";
|
||||
}
|
||||
catch (TypeError $e) {
|
||||
$sprekk = "<td></td>";
|
||||
}
|
||||
}
|
||||
$matposter = "<td>$tid_1_mat</td><td>$tid_2_mat</td>";
|
||||
}
|
||||
if ($runner->course == "Kadaverløpet") {
|
||||
$kadaver_table .= "<tr><td>". $kadaver_num .".</td><td>$runner->name</td>$matposter<td>$tid_maal</td><td>$tid_etter</td>$sprekk</tr>\n";
|
||||
}
|
||||
}
|
||||
$kadaver_table .= "</tbody></table>\n";
|
||||
echo($kadaver_table);
|
||||
|
||||
}
|
||||
|
||||
function minikadadvern_table($runners) {
|
||||
usort($runners, "cmp");
|
||||
usort($runners, "cmp_course");
|
||||
$minikadaver_table = "<table><thead>
|
||||
<tr>
|
||||
<th>#</th>
|
||||
@ -183,9 +232,8 @@ function liveresult_table($runners) {
|
||||
$minikadaver_table .= "<tr><td>". "" .".</td><td>$runner->name</td><td>$tid_maal</td></tr>\n";
|
||||
}
|
||||
}
|
||||
$kadaver_table .= "</tbody></table>\n";
|
||||
$minikadaver_table .= "</tbody></table>";
|
||||
echo($kadaver_table . $minikadaver_table);
|
||||
echo($minikadaver_table);
|
||||
|
||||
}
|
||||
|
||||
@ -202,4 +250,7 @@ if (!isset($query)){
|
||||
elseif ($query["type"] == "liveresultater") {
|
||||
liveresult_table($runners);
|
||||
}
|
||||
elseif ($query["type"] == "minikadavern") {
|
||||
minikadadvern_table($runners);
|
||||
}
|
||||
}
|
||||
@ -24,9 +24,7 @@ class Runner
|
||||
$this->email = $email;
|
||||
$this->phone = $phone;
|
||||
$this->is_student = $is_student;
|
||||
for ($i = 0; $i < $GLOBALS['number_of_controls']; $i++) {
|
||||
$this->splits[$i] = false;
|
||||
}
|
||||
$this->splits = [false, false, false];
|
||||
}
|
||||
|
||||
function set_split($control, $timestamp)
|
||||
@ -34,14 +32,14 @@ class Runner
|
||||
$this->splits[$control] = $timestamp;
|
||||
}
|
||||
|
||||
function get_control()
|
||||
{ for ($i = 0; $i < count($this->splits); $i++) {
|
||||
|
||||
if (!is_object($this->splits[$i])) {
|
||||
return $i-1;
|
||||
function get_control(){
|
||||
$control = -1;
|
||||
for ($i = 0; $i < count($this->splits); $i++) {
|
||||
if ($this->splits[$i] != false) {
|
||||
$control++;
|
||||
}
|
||||
}
|
||||
return count($this->splits)-1;
|
||||
return $control;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user