This commit is contained in:
Gogs 2021-06-18 16:32:17 +02:00
parent b5a3a2a547
commit d0df0f6a44
33 changed files with 622 additions and 3 deletions

View File

@ -0,0 +1,23 @@
<?php namespace GermanAirlinesVa\Schooling\Controllers;
use Backend\Classes\Controller;
use BackendMenu;
class ExamMemberRankAnswer extends Controller
{
public $implement = ['Backend\Behaviors\ListController', 'Backend\Behaviors\FormController'];
public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml';
public function __construct()
{
parent::__construct();
}
public function listExtendQuery($query)
{
$query->leftJoin('exam_questions', 'exam_questions.id', 'exam_answers.exam_question_id');
$query->where('exam_questions.member_rank_id', '<>', null);
}
}

View File

@ -0,0 +1,23 @@
<?php namespace GermanAirlinesVa\Schooling\Controllers;
use Backend\Classes\Controller;
use BackendMenu;
class ExamTyperatingAnswer extends Controller
{
public $implement = ['Backend\Behaviors\ListController', 'Backend\Behaviors\FormController'];
public $listConfig = 'config_list.yaml';
public $formConfig = 'config_form.yaml';
public function __construct()
{
parent::__construct();
}
public function listExtendQuery($query)
{
$query->leftJoin('exam_questions', 'exam_questions.id', 'exam_answers.exam_question_id');
$query->where('exam_questions.typerating_id', '<>', null);
}
}

View File

@ -0,0 +1,23 @@
<div data-control="toolbar">
<a
href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer/create') ?>"
class="btn btn-primary oc-icon-plus"
><?= e(trans('backend::lang.form.create')) ?></a
>
<button
class="btn btn-default oc-icon-trash-o"
disabled="disabled"
onclick="$(this).data('request-data', {
checked: $('.control-list').listWidget('getChecked')
})"
data-request="onDelete"
data-request-confirm="<?= e(trans('backend::lang.list.delete_selected_confirm')) ?>"
data-trigger-action="enable"
data-trigger=".control-list input[type=checkbox]"
data-trigger-condition="checked"
data-request-success="$(this).prop('disabled', true)"
data-stripe-load-indicator
>
<?= e(trans('backend::lang.list.delete_selected')) ?>
</button>
</div>

View File

@ -0,0 +1,10 @@
name: Exam Member Rank Answers
form: $/germanairlinesva/schooling/models/exammemberrankanswer/fields.yaml
modelClass: GermanAirlinesVa\Schooling\Models\ExamMemberRankAnswer
defaultRedirect: germanairlinesva/schooling/exammemberrankanswer
create:
redirect: 'germanairlinesva/schooling/exammemberrankanswer/update/:id'
redirectClose: germanairlinesva/schooling/exammemberrankanswer
update:
redirect: germanairlinesva/schooling/exammemberrankanswer
redirectClose: germanairlinesva/schooling/exammemberrankanswer

View File

@ -0,0 +1,12 @@
list: $/germanairlinesva/schooling/models/exammemberrankanswer/columns.yaml
modelClass: GermanAirlinesVa\Schooling\Models\ExamMemberRankAnswer
title: Exam Member Rank Answers
noRecordsMessage: 'backend::lang.list.no_records'
showSetup: true
showCheckboxes: true
recordsPerPage: 20
toolbar:
buttons: list_toolbar
search:
prompt: 'backend::lang.list.search_prompt'
recordUrl: 'germanairlinesva/schooling/exammemberrankanswer/update/:id'

View File

@ -0,0 +1,54 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>">Exam Member Rank Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<?= Form::open(['class' =>
'layout']) ?>
<div class="layout-row"><?= $this->formRender() ?></div>
<div class="form-buttons">
<div class="loading-indicator-container">
<button
type="submit"
data-request="onSave"
data-hotkey="ctrl+s, cmd+s"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-primary"
>
<?= e(trans('backend::lang.form.create')) ?>
</button>
<button
type="button"
data-request="onSave"
data-request-data="close:1"
data-hotkey="ctrl+enter, cmd+enter"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-default"
>
<?= e(trans('backend::lang.form.create_and_close')) ?>
</button>
<span class="btn-text">
<?= e(trans('backend::lang.form.or')) ?>
<a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>"
><?= e(trans('backend::lang.form.cancel')) ?></a
>
</span>
</div>
</div>
<?= Form::close() ?>
<?php else: ?>
<p class="flash-message static error"><?= e(trans($this->fatalError)) ?></p>
<p>
<a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>" class="btn btn-default"
><?= e(trans('backend::lang.form.return_to_list')) ?></a
>
</p>
<?php endif ?>

View File

@ -0,0 +1 @@
<?= $this->listRender() ?>

View File

@ -0,0 +1,23 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>">Exam Member Rank Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<div class="form-preview"><?= $this->formRenderPreview() ?></div>
<?php else: ?>
<p class="flash-message static error"><?= e($this->fatalError) ?></p>
<?php endif ?>
<p>
<a
href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>"
class="btn btn-default oc-icon-chevron-left"
>
<?= e(trans('backend::lang.form.return_to_list')) ?>
</a>
</p>

View File

@ -0,0 +1,62 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>">Exam Member Rank Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<?= Form::open(['class' =>
'layout']) ?>
<div class="layout-row"><?= $this->formRender() ?></div>
<div class="form-buttons">
<div class="loading-indicator-container">
<button
type="submit"
data-request="onSave"
data-request-data="redirect:0"
data-hotkey="ctrl+s, cmd+s"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-primary"
>
<?= e(trans('backend::lang.form.save')) ?>
</button>
<button
type="button"
data-request="onSave"
data-request-data="close:1"
data-hotkey="ctrl+enter, cmd+enter"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-default"
>
<?= e(trans('backend::lang.form.save_and_close')) ?>
</button>
<button
type="button"
class="oc-icon-trash-o btn-icon danger pull-right"
data-request="onDelete"
data-load-indicator="<?= e(trans('backend::lang.form.deleting')) ?>"
data-request-confirm="<?= e(trans('backend::lang.form.confirm_delete')) ?>"
></button>
<span class="btn-text">
<?= e(trans('backend::lang.form.or')) ?>
<a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>"
><?= e(trans('backend::lang.form.cancel')) ?></a
>
</span>
</div>
</div>
<?= Form::close() ?>
<?php else: ?>
<p class="flash-message static error"><?= e(trans($this->fatalError)) ?></p>
<p>
<a href="<?= Backend::url('germanairlinesva/schooling/exammemberrankanswer') ?>" class="btn btn-default"
><?= e(trans('backend::lang.form.return_to_list')) ?></a
>
</p>
<?php endif ?>

View File

@ -0,0 +1,23 @@
<div data-control="toolbar">
<a
href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer/create') ?>"
class="btn btn-primary oc-icon-plus"
><?= e(trans('backend::lang.form.create')) ?></a
>
<button
class="btn btn-default oc-icon-trash-o"
disabled="disabled"
onclick="$(this).data('request-data', {
checked: $('.control-list').listWidget('getChecked')
})"
data-request="onDelete"
data-request-confirm="<?= e(trans('backend::lang.list.delete_selected_confirm')) ?>"
data-trigger-action="enable"
data-trigger=".control-list input[type=checkbox]"
data-trigger-condition="checked"
data-request-success="$(this).prop('disabled', true)"
data-stripe-load-indicator
>
<?= e(trans('backend::lang.list.delete_selected')) ?>
</button>
</div>

View File

@ -0,0 +1,10 @@
name: Exam Typerating Answer
form: $/germanairlinesva/schooling/models/examtyperatinganswer/fields.yaml
modelClass: GermanAirlinesVa\Schooling\Models\ExamMemberRankAnswer
defaultRedirect: germanairlinesva/schooling/examtyperatinganswer
create:
redirect: 'germanairlinesva/schooling/examtyperatinganswer/update/:id'
redirectClose: germanairlinesva/schooling/examtyperatinganswer
update:
redirect: germanairlinesva/schooling/examtyperatinganswer
redirectClose: germanairlinesva/schooling/examtyperatinganswer

View File

@ -0,0 +1,12 @@
list: $/germanairlinesva/schooling/models/examtyperatinganswer/columns.yaml
modelClass: GermanAirlinesVa\Schooling\Models\ExamMemberRankAnswer
title: Exam Typerating Answers
noRecordsMessage: 'backend::lang.list.no_records'
showSetup: true
showCheckboxes: true
recordsPerPage: 20
toolbar:
buttons: list_toolbar
search:
prompt: 'backend::lang.list.search_prompt'
recordUrl: 'germanairlinesva/schooling/examtyperatinganswer/update/:id'

View File

@ -0,0 +1,54 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>">Exam Typerating Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<?= Form::open(['class' =>
'layout']) ?>
<div class="layout-row"><?= $this->formRender() ?></div>
<div class="form-buttons">
<div class="loading-indicator-container">
<button
type="submit"
data-request="onSave"
data-hotkey="ctrl+s, cmd+s"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-primary"
>
<?= e(trans('backend::lang.form.create')) ?>
</button>
<button
type="button"
data-request="onSave"
data-request-data="close:1"
data-hotkey="ctrl+enter, cmd+enter"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-default"
>
<?= e(trans('backend::lang.form.create_and_close')) ?>
</button>
<span class="btn-text">
<?= e(trans('backend::lang.form.or')) ?>
<a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>"
><?= e(trans('backend::lang.form.cancel')) ?></a
>
</span>
</div>
</div>
<?= Form::close() ?>
<?php else: ?>
<p class="flash-message static error"><?= e(trans($this->fatalError)) ?></p>
<p>
<a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>" class="btn btn-default"
><?= e(trans('backend::lang.form.return_to_list')) ?></a
>
</p>
<?php endif ?>

View File

@ -0,0 +1 @@
<?= $this->listRender() ?>

View File

@ -0,0 +1,23 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>">Exam Typerating Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<div class="form-preview"><?= $this->formRenderPreview() ?></div>
<?php else: ?>
<p class="flash-message static error"><?= e($this->fatalError) ?></p>
<?php endif ?>
<p>
<a
href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>"
class="btn btn-default oc-icon-chevron-left"
>
<?= e(trans('backend::lang.form.return_to_list')) ?>
</a>
</p>

View File

@ -0,0 +1,62 @@
<?php Block::put('breadcrumb') ?>
<ul>
<li><a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>">Exam Typerating Answers</a></li>
<li><?= e($this->pageTitle) ?></li>
</ul>
<?php Block::endPut() ?>
<?php if (!$this->fatalError): ?>
<?= Form::open(['class' =>
'layout']) ?>
<div class="layout-row"><?= $this->formRender() ?></div>
<div class="form-buttons">
<div class="loading-indicator-container">
<button
type="submit"
data-request="onSave"
data-request-data="redirect:0"
data-hotkey="ctrl+s, cmd+s"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-primary"
>
<?= e(trans('backend::lang.form.save')) ?>
</button>
<button
type="button"
data-request="onSave"
data-request-data="close:1"
data-hotkey="ctrl+enter, cmd+enter"
data-load-indicator="<?= e(trans('backend::lang.form.saving')) ?>"
class="btn btn-default"
>
<?= e(trans('backend::lang.form.save_and_close')) ?>
</button>
<button
type="button"
class="oc-icon-trash-o btn-icon danger pull-right"
data-request="onDelete"
data-load-indicator="<?= e(trans('backend::lang.form.deleting')) ?>"
data-request-confirm="<?= e(trans('backend::lang.form.confirm_delete')) ?>"
></button>
<span class="btn-text">
<?= e(trans('backend::lang.form.or')) ?>
<a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>"
><?= e(trans('backend::lang.form.cancel')) ?></a
>
</span>
</div>
</div>
<?= Form::close() ?>
<?php else: ?>
<p class="flash-message static error"><?= e(trans($this->fatalError)) ?></p>
<p>
<a href="<?= Backend::url('germanairlinesva/schooling/examtyperatinganswer') ?>" class="btn btn-default"
><?= e(trans('backend::lang.form.return_to_list')) ?></a
>
</p>
<?php endif ?>

View File

@ -13,6 +13,8 @@
'rank' => 'Member Ranks',
'exam_question_rank' => 'Exam Member Rank Questions',
'exam_question_typerating' => 'Exam Typerating Questions',
'exam_answer_rank' => 'Exam Member Rank Answers',
'exam_answer_typerating' => 'Exam Typerating Answers',
],
'permissions' => [
'tab' => 'German Airlines VA - Schooling',
@ -34,4 +36,9 @@
'text' => 'Question text',
'picture' => 'Question Picture',
],
'exam_answer' => [
'question' => 'Exam Question',
'text' => 'Answer Text',
'is_correct' => 'True if Answer is Correct',
],
];

View File

@ -0,0 +1,36 @@
<?php namespace GermanAirlinesVa\Schooling\Models;
use Model;
/**
* Model
*/
class ExamMemberRankAnswer extends Model
{
use \October\Rain\Database\Traits\Validation;
/*
* Disable timestamps by default.
* Remove this line if timestamps are defined in the database table.
*/
public $timestamps = false;
/**
* @var string The database table used by the model.
*/
public $table = 'exam_answers';
protected $connection = 'germanairlinesva_schooling';
/**
* @var array Validation rules
*/
public $rules = [
'exam_question' => 'required',
'text' => 'required',
'is_correct' => 'required',
];
public $belongsTo = [
'exam_question' => ['GermanAirlinesVa\Schooling\Models\ExamMemberRankQuestion', 'key' => 'exam_question_id'],
];
}

View File

@ -31,6 +31,10 @@ class ExamMemberRankQuestion extends Model
'text' => 'required',
];
public $hasMany = [
'exam_answers' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRankAnswer',
];
public $belongsTo = [
'member_rank' => 'GermanAirlinesVa\Schooling\Models\MemberRank',
];

View File

@ -0,0 +1,36 @@
<?php namespace GermanAirlinesVa\Schooling\Models;
use Model;
/**
* Model
*/
class ExamTyperatingAnswer extends Model
{
use \October\Rain\Database\Traits\Validation;
/*
* Disable timestamps by default.
* Remove this line if timestamps are defined in the database table.
*/
public $timestamps = false;
/**
* @var string The database table used by the model.
*/
public $table = 'exam_answers';
protected $connection = 'germanairlinesva_schooling';
/**
* @var array Validation rules
*/
public $rules = [
'exam_question' => 'required',
'text' => 'required',
'is_correct' => 'required',
];
public $belongsTo = [
'exam_question' => ['GermanAirlinesVa\Schooling\Models\ExamTyperatingQuestion', 'key' => 'exam_question_id'],
];
}

View File

@ -32,4 +32,8 @@ class MemberRank extends Model
'badge' => 'required',
'region' => 'required',
];
public $hasMany = [
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRankQuestion',
];
}

View File

@ -28,5 +28,6 @@ class Typerating extends Model
public $hasMany = [
'aircraft_types' => 'GermanAirlinesVa\Fleet\Models\AircraftType',
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamTyperatingQuestion',
];
}

View File

@ -0,0 +1,17 @@
columns:
id:
label: id
type: text
exam_question_id:
label: exam_question_id
type: text
searchable: true
relation: exam_question
valueFrom: text
text:
label: text
type: text
searchable: true
is_correct:
label: is_correct
type: switch

View File

@ -0,0 +1,19 @@
fields:
exam_question:
label: 'germanairlinesva.schooling::lang.exam_answer.question'
nameFrom: text
descriptionFrom: description
span: auto
required: 1
type: relation
text:
label: 'germanairlinesva.schooling::lang.exam_answer.text'
size: small
span: auto
required: 1
type: richeditor
is_correct:
label: 'germanairlinesva.schooling::lang.exam_answer.is_correct'
span: auto
required: 1
type: switch

View File

@ -0,0 +1,17 @@
columns:
id:
label: id
type: text
exam_question_id:
label: exam_question_id
type: text
searchable: true
relation: exam_question
valueFrom: text
text:
label: text
type: text
searchable: true
is_correct:
label: is_correct
type: switch

View File

@ -0,0 +1,19 @@
fields:
exam_question:
label: 'germanairlinesva.schooling::lang.exam_answer.question'
nameFrom: text
descriptionFrom: description
span: auto
required: 1
type: relation
text:
label: 'germanairlinesva.schooling::lang.exam_answer.text'
size: small
span: auto
required: 1
type: richeditor
is_correct:
label: 'germanairlinesva.schooling::lang.exam_answer.is_correct'
span: auto
required: 1
type: switch

View File

@ -4,8 +4,9 @@ columns:
type: text
member_rank:
label: member_rank
relation: member_rank
type: text
searchable: true
relation: member_rank
valueFrom: name
in_use:
label: in_use
@ -13,9 +14,11 @@ columns:
mandatory:
label: mandatory
type: text
searchable: false
text:
label: text
type: text
searchable: true
picture:
label: picture
type: text

View File

@ -19,7 +19,7 @@ fields:
type: switch
text:
label: 'germanairlinesva.schooling::lang.exam_question.text'
size: large
size: small
span: auto
required: 1
type: richeditor

View File

@ -5,17 +5,20 @@ columns:
typerating:
label: typerating
type: text
searchable: true
relation: typerating
valueFrom: name
in_use:
label: in_use
type: text
searchable: false
mandatory:
label: mandatory
type: text
text:
label: text
type: text
searchable: true
picture:
label: picture
type: text

View File

@ -20,7 +20,7 @@ fields:
type: switch
text:
label: 'germanairlinesva.schooling::lang.exam_question.text'
size: large
size: small
span: auto
required: 1
type: richeditor

View File

@ -28,6 +28,14 @@ navigation:
label: 'germanairlinesva.schooling::lang.menu.exam_question_typerating'
url: germanairlinesva/schooling/examtyperatingquestion
icon: icon-question
side-menu-item5:
label: 'germanairlinesva.schooling::lang.menu.exam_answer_rank'
url: germanairlinesva/schooling/exammemberrankanswer
icon: icon-check
side-menu-item6:
label: 'germanairlinesva.schooling::lang.menu.exam_answer_typerating'
url: germanairlinesva/schooling/examtyperatinganswer
icon: icon-check
permissions:
schooling:
tab: 'germanairlinesva.schooling::lang.permissions.tab'

View File

@ -0,0 +1,27 @@
<?php namespace GermanAirlinesVa\Schooling\Updates;
use Schema;
use October\Rain\Database\Updates\Migration;
class BuilderTableCreateExamAnswers extends Migration
{
public function up()
{
Schema::connection('germanairlinesva_schooling')->create('exam_answers', function ($table) {
$table->engine = 'InnoDB';
$table->bigIncrements('id')->unsigned();
$table->bigInteger('exam_question_id')->unsigned();
$table
->foreign('exam_question_id')
->references('id')
->on('exam_questions');
$table->text('text');
$table->boolean('is_correct');
});
}
public function down()
{
Schema::connection('germanairlinesva_schooling')->dropIfExists('exam_answers');
}
}

View File

@ -9,3 +9,5 @@
- builder_table_create_member_ranks.php
- 'Created table exam_questions'
- builder_table_create_exam_questions.php
- 'Created table exam_answers'
- builder_table_create_exam_answers.php