first commit
Some checks failed
Build / run (push) Has been cancelled

This commit is contained in:
maher
2025-10-29 11:42:25 +01:00
commit 703f50a09d
4595 changed files with 385164 additions and 0 deletions

View File

@@ -0,0 +1,25 @@
<?php
namespace Common\Votes;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Support\Facades\DB;
trait OrdersByWeightedScore
{
public function scopeOrderByWeightedScore(
Builder $query,
$direction = 'desc',
string $positiveCol = 'upvotes',
string $negativeCol = 'downvotes',
): Builder {
return $query
->select($query->getQuery()->columns ?? '*')
->addSelect([
DB::raw(
"(($positiveCol + 1.9208) / ($positiveCol + $negativeCol) -.96 * SQRT(($positiveCol * $negativeCol) / ($positiveCol + $negativeCol) + 0.9604) / ($positiveCol + $negativeCol)) / (1 + 3.8416 / ($positiveCol + $negativeCol)) AS weighted_score",
),
])
->orderBy('weighted_score', $direction);
}
}