Compare commits

...

8 Commits

Author SHA1 Message Date
Kilian f0a2ac15fb Create adjustments 2021-08-16 10:36:27 +02:00
Kilian 0bdba12a0e Exam create with 10 random questions 2021-08-15 23:05:46 +02:00
Kilian 3302d89057 Basic schooling GQL 2021-08-15 19:06:23 +02:00
Kilian fb1f54d8b9 Grading Function 2021-08-15 17:18:15 +02:00
Kilian 5f232a645c Controller Permission 2021-08-14 21:47:59 +02:00
Kilian ad6e4b2943 Member FK 2021-08-14 18:30:00 +02:00
Kilian 85ff347090 Deffered Class 2021-08-14 15:40:53 +02:00
Kilian ac87652534 Namespace Permission 2021-08-14 14:19:22 +02:00
20 changed files with 145 additions and 15 deletions
+4 -2
View File
@@ -4,10 +4,12 @@
- HasMany AircraftTypes (External DB) - HasMany AircraftTypes (External DB)
- HasMany ExamTyperatingQuestion - HasMany ExamTyperatingQuestion
- HasMany ExamTyperating
## MemberRank ## MemberRank
- HasMany ExamMemberRankQuestion - HasMany ExamMemberRankQuestion
- HasMany ExamMemberRank
## ExamMemberRankQuestion ## ExamMemberRankQuestion
@@ -34,13 +36,13 @@
## ExamMemberRank ## ExamMemberRank
- BelongsTo MemberRank - BelongsTo MemberRank
- **TODO** BelongsTo Member (External DB) - BelongsTo Member (External DB, creation in Social Plugin)
- BelongsToMany ExamMemberRankQuestion - BelongsToMany ExamMemberRankQuestion
- BelongsToMany ExamMemberRankAnswers - BelongsToMany ExamMemberRankAnswers
## ExamTyperating ## ExamTyperating
- BelongsTo Typerating - BelongsTo Typerating
- **TODO** BelongsTo Member (External DB) - BelongsTo Member (External DB, creation in Social Plugin)
- BelongsToMany ExamTyperatingQuestion - BelongsToMany ExamTyperatingQuestion
- BelongsToMany ExamTyperatingAnswers - BelongsToMany ExamTyperatingAnswers
+2
View File
@@ -8,6 +8,8 @@ class ExamMemberRank extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class ExamMemberRankAnswer extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class ExamMemberRankQuestion extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -8,6 +8,8 @@ class ExamTyperating extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class ExamTyperatingAnswer extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class ExamTyperatingQuestion extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class MemberRank extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+2
View File
@@ -9,6 +9,8 @@ class Typerating extends Controller
public $listConfig = 'config_list.yaml'; public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml'; public $formConfig = 'config_form.yaml';
public $requiredPermissions = ['germanairlinesva.schooling.master'];
public function __construct() public function __construct()
{ {
parent::__construct(); parent::__construct();
+52
View File
@@ -33,6 +33,7 @@ class ExamMemberRank extends Model
public $belongsTo = [ public $belongsTo = [
'member_rank' => 'GermanAirlinesVa\Schooling\Models\MemberRank', 'member_rank' => 'GermanAirlinesVa\Schooling\Models\MemberRank',
'member' => 'GermanAirlinesVa\Social\Models\Member',
]; ];
public $belongsToMany = [ public $belongsToMany = [
@@ -63,4 +64,55 @@ class ExamMemberRank extends Model
$builder->where('member_rank_id', '<>', null); $builder->where('member_rank_id', '<>', null);
}); });
} }
public static function createNew($member_id, $member_rank_id)
{
$exam = new ExamMemberRank();
$exam->member_id = $member_id;
$exam->member_rank_id = $member_rank_id;
$entry = [];
$questions = ExamMemberRankQuestion::where('member_rank_id', $member_rank_id)
->get()
->random(10);
foreach ($questions as $question) {
array_push($entry, ['exam_question_id' => $question->id]);
}
$exam->exam_questions = $entry;
$exam->save();
return $exam;
}
public function grade()
{
$this->load([
'exam_questions' => function ($query) {
$query->groupBy('id');
},
]);
$returnVal = [];
$returnGrade = 0;
foreach ($this->exam_questions as $question) {
$answers = $question->exam_answers;
$returnAnswers = [];
$returnAnswerGrade = true;
foreach ($answers as $answer) {
$given = $this->exam_answers->contains($answer->id);
array_push($returnAnswers, [
'answer' => $answer,
'status' => $given,
'grade' => $given == $answer->is_correct,
]);
$returnAnswerGrade = $returnAnswerGrade && $given == $answer->is_correct;
}
array_push($returnVal, [
'question' => $question,
'answers' => $returnAnswers,
'grade' => $returnAnswerGrade,
]);
$returnGrade = $returnAnswerGrade ? $returnGrade + 1 : $returnGrade;
}
return ['exam' => $returnVal, 'grade' => $returnGrade];
}
} }
+52 -2
View File
@@ -27,12 +27,11 @@ class ExamTyperating extends Model
public $rules = [ public $rules = [
'member_id' => 'required', 'member_id' => 'required',
'typerating_id' => 'required', 'typerating_id' => 'required',
'start' => 'required',
'status' => 'required',
]; ];
public $belongsTo = [ public $belongsTo = [
'typerating' => 'GermanAirlinesVa\Schooling\Models\Typerating', 'typerating' => 'GermanAirlinesVa\Schooling\Models\Typerating',
'member' => 'GermanAirlinesVa\Social\Models\Member',
]; ];
public $belongsToMany = [ public $belongsToMany = [
@@ -63,4 +62,55 @@ class ExamTyperating extends Model
$builder->where('typerating_id', '<>', null); $builder->where('typerating_id', '<>', null);
}); });
} }
public static function createNew($member_id, $typerating_id)
{
$exam = new ExamTyperating();
$exam->member_id = $member_id;
$exam->typerating_id = $typerating_id;
$entry = [];
$questions = ExamTyperatingQuestion::where('typerating_id', $typerating_id)
->get()
->random(10);
foreach ($questions as $question) {
array_push($entry, ['exam_question_id' => $question->id]);
}
$exam->exam_questions = $entry;
$exam->save();
return $exam;
}
public function grade()
{
$this->load([
'exam_questions' => function ($query) {
$query->groupBy('id');
},
]);
$returnVal = [];
$returnGrade = 0;
foreach ($this->exam_questions as $question) {
$answers = $question->exam_answers;
$returnAnswers = [];
$returnAnswerGrade = true;
foreach ($answers as $answer) {
$given = $this->exam_answers->contains($answer->id);
array_push($returnAnswers, [
'answer' => $answer,
'status' => $given,
'grade' => $given == $answer->is_correct,
]);
$returnAnswerGrade = $returnAnswerGrade && $given == $answer->is_correct;
}
array_push($returnVal, [
'question' => $question,
'answers' => $returnAnswers,
'grade' => $returnAnswerGrade,
]);
$returnGrade = $returnAnswerGrade ? $returnGrade + 1 : $returnGrade;
}
return ['exam' => $returnVal, 'grade' => $returnGrade];
}
} }
+1
View File
@@ -35,5 +35,6 @@ class MemberRank extends Model
public $hasMany = [ public $hasMany = [
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRankQuestion', 'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRankQuestion',
'exams' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRank',
]; ];
} }
+1
View File
@@ -29,5 +29,6 @@ class Typerating extends Model
public $hasMany = [ public $hasMany = [
'aircraft_types' => 'GermanAirlinesVa\Fleet\Models\AircraftType', 'aircraft_types' => 'GermanAirlinesVa\Fleet\Models\AircraftType',
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamTyperatingQuestion', 'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamTyperatingQuestion',
'exams' => 'GermanAirlinesVa\Schooling\Models\ExamTyperating',
]; ];
} }
+5 -3
View File
@@ -2,9 +2,11 @@ columns:
id: id:
label: id label: id
type: number type: number
member_id: member:
label: member_id label: member
type: number type: text
relation: member
valueFrom: name
member_rank: member_rank:
label: member_rank label: member_rank
type: text type: text
+5 -3
View File
@@ -2,9 +2,11 @@ columns:
id: id:
label: id label: id
type: number type: number
member_id: member:
label: member_id label: member
type: number type: text
relation: member
valueFrom: name
typerating: typerating:
label: typerating label: typerating
type: text type: text
+2 -2
View File
@@ -10,7 +10,7 @@ navigation:
url: / url: /
icon: icon-university icon: icon-university
permissions: permissions:
- schooling - germanairlinesva.schooling.master
sideMenu: sideMenu:
side-menu-item: side-menu-item:
label: 'germanairlinesva.schooling::lang.menu.typeratings' label: 'germanairlinesva.schooling::lang.menu.typeratings'
@@ -45,6 +45,6 @@ navigation:
url: germanairlinesva/schooling/examtyperating url: germanairlinesva/schooling/examtyperating
icon: icon-file-text icon: icon-file-text
permissions: permissions:
schooling: germanairlinesva.schooling.master:
tab: 'germanairlinesva.schooling::lang.permissions.tab' tab: 'germanairlinesva.schooling::lang.permissions.tab'
label: 'germanairlinesva.schooling::lang.permissions.label' label: 'germanairlinesva.schooling::lang.permissions.label'
@@ -1,4 +1,4 @@
<?php namespace GermanAirlinesVa\Fleet\Updates; <?php namespace GermanAirlinesVa\Schooling\Updates;
use Schema; use Schema;
use October\Rain\Database\Updates\Migration; use October\Rain\Database\Updates\Migration;
@@ -22,6 +22,8 @@ class BuilderTableCreateExamAnswers extends Migration
public function down() public function down()
{ {
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints();
Schema::connection('germanairlinesva_schooling')->dropIfExists('exam_answers'); Schema::connection('germanairlinesva_schooling')->dropIfExists('exam_answers');
Schema::connection('germanairlinesva_schooling')->enableForeignKeyConstraints();
} }
} }
@@ -31,7 +31,7 @@ class BuilderTableCreateExamExamAnswerExamQuestion extends Migration
public function down() public function down()
{ {
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints(); Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints();
Schema::dropIfExists('germanairlinesva_schooling_exam_exam_answer_exam_question'); Schema::connection('germanairlinesva_schooling')->dropIfExists('exam_exam_answer_exam_question');
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints(); Schema::connection('germanairlinesva_schooling')->enableForeignKeyConstraints();
} }
} }
+2
View File
@@ -35,6 +35,8 @@ class BuilderTableCreateExams extends Migration
public function down() public function down()
{ {
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints();
Schema::connection('germanairlinesva_schooling')->dropIfExists('exams'); Schema::connection('germanairlinesva_schooling')->dropIfExists('exams');
Schema::connection('germanairlinesva_schooling')->enableForeignKeyConstraints();
} }
} }