Splitta kadavertabellen og minikadavertabellen
This commit is contained in:
parent
fdddbbb0ef
commit
b30996ceea
11
admin.php
11
admin.php
@ -37,6 +37,11 @@
|
|||||||
</menu>
|
</menu>
|
||||||
</nav>
|
</nav>
|
||||||
<button class="danger" onclick="log_out()">Logg ut</button>
|
<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>
|
<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">
|
<form action="/api/runner.php" method="GET" hx-boost="true" hx-target="#runner_info" hx-swap="show:none">
|
||||||
<label>
|
<label>
|
||||||
@ -54,9 +59,13 @@
|
|||||||
<output id="emails"></output>
|
<output id="emails"></output>
|
||||||
</div>
|
</div>
|
||||||
<h1>Løpende resultater</h1>
|
<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
|
<?php
|
||||||
include("api/table.php");
|
include("api/table.php");
|
||||||
liveresult_table($runners);
|
//liveresult_table($runners);
|
||||||
?>
|
?>
|
||||||
<script>
|
<script>
|
||||||
function update() {
|
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) {
|
function registration_table($runners) {
|
||||||
parse_str($_SERVER['QUERY_STRING'], $query);
|
parse_str($_SERVER['QUERY_STRING'], $query);
|
||||||
@ -127,6 +127,55 @@ function liveresult_table($runners) {
|
|||||||
<th>Sprekkindeks</th>
|
<th>Sprekkindeks</th>
|
||||||
</tr></thead>
|
</tr></thead>
|
||||||
<tbody>";
|
<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>
|
$minikadaver_table = "<table><thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>#</th>
|
<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";
|
$minikadaver_table .= "<tr><td>". "" .".</td><td>$runner->name</td><td>$tid_maal</td></tr>\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$kadaver_table .= "</tbody></table>\n";
|
|
||||||
$minikadaver_table .= "</tbody></table>";
|
$minikadaver_table .= "</tbody></table>";
|
||||||
echo($kadaver_table . $minikadaver_table);
|
echo($minikadaver_table);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,4 +250,7 @@ if (!isset($query)){
|
|||||||
elseif ($query["type"] == "liveresultater") {
|
elseif ($query["type"] == "liveresultater") {
|
||||||
liveresult_table($runners);
|
liveresult_table($runners);
|
||||||
}
|
}
|
||||||
|
elseif ($query["type"] == "minikadavern") {
|
||||||
|
minikadadvern_table($runners);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@ -24,9 +24,7 @@ class Runner
|
|||||||
$this->email = $email;
|
$this->email = $email;
|
||||||
$this->phone = $phone;
|
$this->phone = $phone;
|
||||||
$this->is_student = $is_student;
|
$this->is_student = $is_student;
|
||||||
for ($i = 0; $i < $GLOBALS['number_of_controls']; $i++) {
|
$this->splits = [false, false, false];
|
||||||
$this->splits[$i] = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function set_split($control, $timestamp)
|
function set_split($control, $timestamp)
|
||||||
@ -34,14 +32,14 @@ class Runner
|
|||||||
$this->splits[$control] = $timestamp;
|
$this->splits[$control] = $timestamp;
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_control()
|
function get_control(){
|
||||||
{ for ($i = 0; $i < count($this->splits); $i++) {
|
$control = -1;
|
||||||
|
for ($i = 0; $i < count($this->splits); $i++) {
|
||||||
if (!is_object($this->splits[$i])) {
|
if ($this->splits[$i] != false) {
|
||||||
return $i-1;
|
$control++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return count($this->splits)-1;
|
return $control;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user