X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=app%2FModels%2FResult.php;h=c672a6a780856b1222b5e4e5ac6f7cb7ef93aa6b;hb=4f4b2fd64141cbbff953881e2705602a00b85df5;hp=cdb86c77798fb2bccb204c740ee0ced94473bf71;hpb=d32516335ea2534e15256c948e9c38d3de40794b;p=alttp.git diff --git a/app/Models/Result.php b/app/Models/Result.php index cdb86c7..c672a6a 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(Participant $a, Participant $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,20 @@ 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', + ]; + protected $appends = [ 'has_finished', ];