Feat: Обновление вопросов

 Удалён input тип (не имеет смысла без автопроверки)
 Добавлен ordering тип (сортировка элементов)
 Добавлено поле image для ответов
 Миграции применены
 QuestionOrderingItem модель

Co-authored-by: Qwen-Coder <qwen-coder@alibabacloud.com>
This commit is contained in:
mirivlad 2026-03-27 09:51:17 +08:00
parent e730cd4856
commit acf616fc08
6 changed files with 80 additions and 2 deletions

View File

@ -40,6 +40,11 @@ class Question extends Model
return $this->hasMany(QuestionMatchingPair::class);
}
public function orderingItems(): HasMany
{
return $this->hasMany(QuestionOrderingItem::class);
}
public function responses(): HasMany
{
return $this->hasMany(TestResponse::class);

View File

@ -0,0 +1,10 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class QuestionOrderingItem extends Model
{
//
}

View File

@ -11,7 +11,7 @@ return new class extends Migration
Schema::create('questions', function (Blueprint $table) {
$table->id();
$table->foreignId('test_id')->constrained()->onDelete('cascade');
$table->enum('type', ['single_choice', 'multiple_choice', 'input', 'matching'])->default('single_choice');
$table->enum('type', ['single_choice', 'multiple_choice', 'matching', 'ordering'])->default('multiple_choice');
$table->text('question_text');
$table->text('explanation')->nullable();
$table->integer('score')->default(1);

View File

@ -0,0 +1,33 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Facades\DB;
return new class extends Migration
{
public function up(): void
{
// Добавляем ordering и убираем input
DB::statement("ALTER TABLE questions MODIFY COLUMN type ENUM('single_choice', 'multiple_choice', 'matching', 'ordering') NOT NULL");
// Создаём таблицу для ordering элементов
Schema::create('question_ordering_items', function (Blueprint $table) {
$table->id();
$table->foreignId('question_id')->constrained()->onDelete('cascade');
$table->string('item_text');
$table->integer('correct_order');
$table->integer('sort_order')->default(0);
$table->timestamps();
$table->index('question_id');
});
}
public function down(): void
{
Schema::dropIfExists('question_ordering_items');
DB::statement("ALTER TABLE questions MODIFY COLUMN type ENUM('single_choice', 'multiple_choice', 'input', 'matching') NOT NULL");
}
};

View File

@ -0,0 +1,28 @@
<?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::table('answers', function (Blueprint $table) {
//
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('answers', function (Blueprint $table) {
//
});
}
};

View File

@ -64,13 +64,15 @@
</td>
<td>
@if($question->type === 'single_choice')
<span class="badge bg-info" title="Один ответ"><i class="bi bi-radio-button"></i></span>
<span class="badge bg-info" title="Один ответ"><i class="bi bi-circle"></i></span>
@elseif($question->type === 'multiple_choice')
<span class="badge bg-success" title="Несколько ответов"><i class="bi bi-check2-square"></i></span>
@elseif($question->type === 'input')
<span class="badge bg-warning" title="Ввод текста"><i class="bi bi-textarea-resize"></i></span>
@elseif($question->type === 'matching')
<span class="badge badge-purple" title="Соответствие"><i class="bi bi-arrow-left-right"></i></span>
@elseif($question->type === 'ordering')
<span class="badge bg-dark" title="Правильный порядок"><i class="bi bi-sort-numeric-down"></i></span>
@endif
{{ $question->type }}
</td>