Original migrations and models

#20 Implement bonus scores
This commit is contained in:
Matt Young 2024-07-14 23:36:46 -05:00
parent bb3ea6fe5e
commit 2ee0cf23cc
5 changed files with 118 additions and 0 deletions

11
app/Models/BonusScore.php Normal file
View File

@ -0,0 +1,11 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BonusScore extends Model
{
use HasFactory;
}

View File

@ -0,0 +1,11 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BonusScoreDefinition extends Model
{
use HasFactory;
}

View File

@ -0,0 +1,32 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('bonus_score_definitions', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->integer('max_score');
$table->float('weight');
$table->boolean('for_seating')->default(true);
$table->boolean('for_attendance')->default(false);
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('bonus_score_definitions');
}
};

View File

@ -0,0 +1,31 @@
<?php
use App\Models\Audition;
use App\Models\BonusScoreDefinition;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('bonus_score_audition_assignment', function (Blueprint $table) {
$table->id();
$table->foreignIdFor(BonusScoreDefinition::class)->constrained()->onDelete('cascade')->onUpdate('cascade');
$table->foreignIdFor(Audition::class)->constrained()->onDelete('cascade')->onUpdate('cascade');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('bonus_score_audition_assignment');
}
};

View File

@ -0,0 +1,33 @@
<?php
use App\Models\Entry;
use App\Models\User;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('bonus_scores', function (Blueprint $table) {
$table->id();
$table->foreignIdFor(Entry::class);
$table->foreignIdFor(User::class);
$table->foreignId('originally_scored_entry')->nullable()->constrained('entries')->nullOnDelete();
$table->integer('score');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('bonus_scores');
}
};