X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=app%2FModels%2FResult.php;h=229ac4b9c8e418c5d52cf9de99c33e07122eaf26;hb=60b20c057188f8965d02c170099aaf1d8ff4e3c6;hp=cdb86c77798fb2bccb204c740ee0ced94473bf71;hpb=d32516335ea2534e15256c948e9c38d3de40794b;p=alttp.git diff --git a/app/Models/Result.php b/app/Models/Result.php index cdb86c7..229ac4b 100644 --- a/app/Models/Result.php +++ b/app/Models/Result.php @@ -11,6 +11,44 @@ class Result extends Model use HasFactory; + public static function compareResult(Result $a, Result $b) { + $a_time = !$a->forfeit ? $a->time : 0; + $b_time = !$b->forfeit ? $b->time : 0; + if ($a_time) { + if ($b_time) { + if ($a_time < $b_time) return -1; + if ($b_time < $a_time) return 1; + return static::compareUsername($a, $b); + } + return -1; + } + if ($b_time) { + return 1; + } + if ($a->forfeit) { + if ($b->forfeit) { + return static::compareUsername($a, $b); + } + return -1; + } + if ($b->forfeit) { + return 1; + } + return static::compareUsername($a, $b); + } + + public static function compareUsername(Result $a, Result $b) { + return strcasecmp($a->user->username, $b->user->username); + } + + + public function formatTime() { + $hours = floor($this->time / 60 / 60); + $minutes = floor(($this->time / 60) % 60); + $seconds = floor($this->time % 60); + return sprintf('%d:%02d:%02d', $hours, $minutes, $seconds); + } + public function updateResult($time, $forfeit) { $this->time = $time; $this->forfeit = $forfeit; @@ -38,11 +76,21 @@ class Result extends Model return $this->belongsTo(Participant::class); } + public function user() { + return $this->belongsTo(User::class); + } + public function getHasFinishedAttribute() { return $this->time > 0 || $this->forfeit; } + protected $casts = [ + 'forfeit' => 'boolean', + 'time' => 'double', + 'user_id' => 'string', + ]; + protected $appends = [ 'has_finished', ];