Answers
This commit is contained in:
parent
b5a3a2a547
commit
d0df0f6a44
23
controllers/ExamMemberRankAnswer.php
Normal file
23
controllers/ExamMemberRankAnswer.php
Normal 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);
|
||||
}
|
||||
}
|
||||
23
controllers/ExamTyperatingAnswer.php
Normal file
23
controllers/ExamTyperatingAnswer.php
Normal 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);
|
||||
}
|
||||
}
|
||||
23
controllers/exammemberrankanswer/_list_toolbar.htm
Normal file
23
controllers/exammemberrankanswer/_list_toolbar.htm
Normal 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>
|
||||
10
controllers/exammemberrankanswer/config_form.yaml
Normal file
10
controllers/exammemberrankanswer/config_form.yaml
Normal 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
|
||||
12
controllers/exammemberrankanswer/config_list.yaml
Normal file
12
controllers/exammemberrankanswer/config_list.yaml
Normal 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'
|
||||
54
controllers/exammemberrankanswer/create.htm
Normal file
54
controllers/exammemberrankanswer/create.htm
Normal 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 ?>
|
||||
1
controllers/exammemberrankanswer/index.htm
Normal file
1
controllers/exammemberrankanswer/index.htm
Normal file
@ -0,0 +1 @@
|
||||
<?= $this->listRender() ?>
|
||||
23
controllers/exammemberrankanswer/preview.htm
Normal file
23
controllers/exammemberrankanswer/preview.htm
Normal 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>
|
||||
62
controllers/exammemberrankanswer/update.htm
Normal file
62
controllers/exammemberrankanswer/update.htm
Normal 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 ?>
|
||||
23
controllers/examtyperatinganswer/_list_toolbar.htm
Normal file
23
controllers/examtyperatinganswer/_list_toolbar.htm
Normal 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>
|
||||
10
controllers/examtyperatinganswer/config_form.yaml
Normal file
10
controllers/examtyperatinganswer/config_form.yaml
Normal 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
|
||||
12
controllers/examtyperatinganswer/config_list.yaml
Normal file
12
controllers/examtyperatinganswer/config_list.yaml
Normal 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'
|
||||
54
controllers/examtyperatinganswer/create.htm
Normal file
54
controllers/examtyperatinganswer/create.htm
Normal 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 ?>
|
||||
1
controllers/examtyperatinganswer/index.htm
Normal file
1
controllers/examtyperatinganswer/index.htm
Normal file
@ -0,0 +1 @@
|
||||
<?= $this->listRender() ?>
|
||||
23
controllers/examtyperatinganswer/preview.htm
Normal file
23
controllers/examtyperatinganswer/preview.htm
Normal 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>
|
||||
62
controllers/examtyperatinganswer/update.htm
Normal file
62
controllers/examtyperatinganswer/update.htm
Normal 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 ?>
|
||||
@ -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',
|
||||
],
|
||||
];
|
||||
|
||||
36
models/ExamMemberRankAnswer.php
Normal file
36
models/ExamMemberRankAnswer.php
Normal 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'],
|
||||
];
|
||||
}
|
||||
@ -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',
|
||||
];
|
||||
|
||||
36
models/ExamTyperatingAnswer.php
Normal file
36
models/ExamTyperatingAnswer.php
Normal 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'],
|
||||
];
|
||||
}
|
||||
@ -32,4 +32,8 @@ class MemberRank extends Model
|
||||
'badge' => 'required',
|
||||
'region' => 'required',
|
||||
];
|
||||
|
||||
public $hasMany = [
|
||||
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamMemberRankQuestion',
|
||||
];
|
||||
}
|
||||
|
||||
@ -28,5 +28,6 @@ class Typerating extends Model
|
||||
|
||||
public $hasMany = [
|
||||
'aircraft_types' => 'GermanAirlinesVa\Fleet\Models\AircraftType',
|
||||
'exam_questions' => 'GermanAirlinesVa\Schooling\Models\ExamTyperatingQuestion',
|
||||
];
|
||||
}
|
||||
|
||||
17
models/examMemberRankAnswer/columns.yaml
Normal file
17
models/examMemberRankAnswer/columns.yaml
Normal 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
|
||||
19
models/examMemberRankAnswer/fields.yaml
Normal file
19
models/examMemberRankAnswer/fields.yaml
Normal 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
|
||||
17
models/examTyperatingAnswer/columns.yaml
Normal file
17
models/examTyperatingAnswer/columns.yaml
Normal 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
|
||||
19
models/examTyperatingAnswer/fields.yaml
Normal file
19
models/examTyperatingAnswer/fields.yaml
Normal 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
|
||||
@ -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
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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
|
||||
|
||||
@ -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'
|
||||
|
||||
27
updates/builder_table_create_exam_answers.php
Normal file
27
updates/builder_table_create_exam_answers.php
Normal 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');
|
||||
}
|
||||
}
|
||||
@ -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
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user