Compare commits
2 Commits
839f50a836
...
dfe1530d27
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
dfe1530d27 | ||
|
|
1f448b1ec4 |
17
controllers/MemberRank.php
Normal file
17
controllers/MemberRank.php
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?php namespace GermanAirlinesVa\Schooling\Controllers;
|
||||||
|
|
||||||
|
use Backend\Classes\Controller;
|
||||||
|
use BackendMenu;
|
||||||
|
|
||||||
|
class MemberRank 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();
|
||||||
|
}
|
||||||
|
}
|
||||||
18
controllers/memberrank/_list_toolbar.htm
Normal file
18
controllers/memberrank/_list_toolbar.htm
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<div data-control="toolbar">
|
||||||
|
<a href="<?= Backend::url('germanairlinesva/schooling/memberrank/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/memberrank/config_form.yaml
Normal file
10
controllers/memberrank/config_form.yaml
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
name: MemberRank
|
||||||
|
form: $/germanairlinesva/schooling/models/memberrank/fields.yaml
|
||||||
|
modelClass: GermanAirlinesVa\Schooling\Models\MemberRank
|
||||||
|
defaultRedirect: germanairlinesva/schooling/memberrank
|
||||||
|
create:
|
||||||
|
redirect: 'germanairlinesva/schooling/memberrank/update/:id'
|
||||||
|
redirectClose: germanairlinesva/schooling/memberrank
|
||||||
|
update:
|
||||||
|
redirect: germanairlinesva/schooling/memberrank
|
||||||
|
redirectClose: germanairlinesva/schooling/memberrank
|
||||||
12
controllers/memberrank/config_list.yaml
Normal file
12
controllers/memberrank/config_list.yaml
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
list: $/germanairlinesva/schooling/models/memberrank/columns.yaml
|
||||||
|
modelClass: GermanAirlinesVa\Schooling\Models\MemberRank
|
||||||
|
title: MemberRank
|
||||||
|
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/memberrank/update/:id'
|
||||||
46
controllers/memberrank/create.htm
Normal file
46
controllers/memberrank/create.htm
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
<?php Block::put('breadcrumb') ?>
|
||||||
|
<ul>
|
||||||
|
<li><a href="<?= Backend::url('germanairlinesva/schooling/memberrank') ?>">MemberRank</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/memberrank') ?>"><?= 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/memberrank') ?>" class="btn btn-default"><?= e(trans('backend::lang.form.return_to_list')) ?></a></p>
|
||||||
|
<?php endif ?>
|
||||||
1
controllers/memberrank/index.htm
Normal file
1
controllers/memberrank/index.htm
Normal file
@ -0,0 +1 @@
|
|||||||
|
<?= $this->listRender() ?>
|
||||||
22
controllers/memberrank/preview.htm
Normal file
22
controllers/memberrank/preview.htm
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php Block::put('breadcrumb') ?>
|
||||||
|
<ul>
|
||||||
|
<li><a href="<?= Backend::url('germanairlinesva/schooling/memberrank') ?>">MemberRank</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/memberrank') ?>" class="btn btn-default oc-icon-chevron-left">
|
||||||
|
<?= e(trans('backend::lang.form.return_to_list')) ?>
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
54
controllers/memberrank/update.htm
Normal file
54
controllers/memberrank/update.htm
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
<?php Block::put('breadcrumb') ?>
|
||||||
|
<ul>
|
||||||
|
<li><a href="<?= Backend::url('germanairlinesva/schooling/memberrank') ?>">MemberRank</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/memberrank') ?>"><?= 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/memberrank') ?>" class="btn btn-default"><?= e(trans('backend::lang.form.return_to_list')) ?></a></p>
|
||||||
|
<?php endif ?>
|
||||||
@ -10,5 +10,18 @@
|
|||||||
'menu' => [
|
'menu' => [
|
||||||
'main' => 'GA Schooling',
|
'main' => 'GA Schooling',
|
||||||
'typeratings' => 'Typeratings',
|
'typeratings' => 'Typeratings',
|
||||||
|
'rank' => 'Member Ranks',
|
||||||
|
],
|
||||||
|
'permissions' => [
|
||||||
|
'tab' => 'German Airlines VA - Schooling',
|
||||||
|
'label' => 'Manage Schooling',
|
||||||
|
],
|
||||||
|
'member_rank' => [
|
||||||
|
'name' => 'Name',
|
||||||
|
'description' => 'Description',
|
||||||
|
'points' => 'Required Points',
|
||||||
|
'price' => 'Price of Exam',
|
||||||
|
'badge' => 'Badge',
|
||||||
|
'region' => 'REGEX to Filter Allowed Regions of Flight',
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|||||||
35
models/MemberRank.php
Normal file
35
models/MemberRank.php
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
<?php namespace GermanAirlinesVa\Schooling\Models;
|
||||||
|
|
||||||
|
use Model;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Model
|
||||||
|
*/
|
||||||
|
class MemberRank 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 = 'member_ranks';
|
||||||
|
protected $connection = 'germanairlinesva_schooling';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array Validation rules
|
||||||
|
*/
|
||||||
|
public $rules = [
|
||||||
|
'name' => 'required',
|
||||||
|
'description' => 'required',
|
||||||
|
'points' => 'required',
|
||||||
|
'price' => 'required',
|
||||||
|
'badge' => 'required',
|
||||||
|
'region' => 'required',
|
||||||
|
];
|
||||||
|
}
|
||||||
22
models/memberrank/columns.yaml
Normal file
22
models/memberrank/columns.yaml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
columns:
|
||||||
|
id:
|
||||||
|
label: id
|
||||||
|
type: text
|
||||||
|
name:
|
||||||
|
label: name
|
||||||
|
type: text
|
||||||
|
description:
|
||||||
|
label: description
|
||||||
|
type: text
|
||||||
|
points:
|
||||||
|
label: points
|
||||||
|
type: number
|
||||||
|
price:
|
||||||
|
label: price
|
||||||
|
type: number
|
||||||
|
badge:
|
||||||
|
label: badge
|
||||||
|
type: text
|
||||||
|
region:
|
||||||
|
label: region
|
||||||
|
type: text
|
||||||
32
models/memberrank/fields.yaml
Normal file
32
models/memberrank/fields.yaml
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
fields:
|
||||||
|
name:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.name'
|
||||||
|
span: auto
|
||||||
|
required: 1
|
||||||
|
type: text
|
||||||
|
description:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.description'
|
||||||
|
size: small
|
||||||
|
span: auto
|
||||||
|
required: 1
|
||||||
|
type: richeditor
|
||||||
|
points:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.points'
|
||||||
|
span: auto
|
||||||
|
required: 1
|
||||||
|
type: number
|
||||||
|
price:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.price'
|
||||||
|
span: auto
|
||||||
|
type: number
|
||||||
|
badge:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.badge'
|
||||||
|
mode: file
|
||||||
|
span: auto
|
||||||
|
required: 1
|
||||||
|
type: mediafinder
|
||||||
|
region:
|
||||||
|
label: 'germanairlinesva.schooling::lang.member_rank.region'
|
||||||
|
span: auto
|
||||||
|
required: 1
|
||||||
|
type: text
|
||||||
38
plugin.yaml
38
plugin.yaml
@ -1,16 +1,26 @@
|
|||||||
plugin:
|
plugin:
|
||||||
name: 'germanairlinesva.schooling::lang.plugin.name'
|
name: 'germanairlinesva.schooling::lang.plugin.name'
|
||||||
description: 'germanairlinesva.schooling::lang.plugin.description'
|
description: 'germanairlinesva.schooling::lang.plugin.description'
|
||||||
author: 'German Airlines Va'
|
author: 'German Airlines Va'
|
||||||
icon: oc-icon-university
|
icon: oc-icon-university
|
||||||
homepage: ''
|
homepage: ''
|
||||||
navigation:
|
navigation:
|
||||||
main-menu-item:
|
main-menu-item:
|
||||||
label: 'germanairlinesva.schooling::lang.menu.main'
|
label: 'germanairlinesva.schooling::lang.menu.main'
|
||||||
url: /
|
url: /
|
||||||
icon: icon-university
|
icon: icon-university
|
||||||
sideMenu:
|
permissions:
|
||||||
side-menu-item:
|
- schooling
|
||||||
label: 'germanairlinesva.schooling::lang.menu.typeratings'
|
sideMenu:
|
||||||
url: germanairlinesva/schooling/typerating
|
side-menu-item:
|
||||||
icon: icon-plane
|
label: 'germanairlinesva.schooling::lang.menu.typeratings'
|
||||||
|
url: germanairlinesva/schooling/typerating
|
||||||
|
icon: icon-plane
|
||||||
|
side-menu-item2:
|
||||||
|
label: 'germanairlinesva.schooling::lang.menu.rank'
|
||||||
|
url: germanairlinesva/schooling/memberRank
|
||||||
|
icon: icon-signal
|
||||||
|
permissions:
|
||||||
|
schooling:
|
||||||
|
tab: 'germanairlinesva.schooling::lang.permissions.tab'
|
||||||
|
label: 'germanairlinesva.schooling::lang.permissions.label'
|
||||||
|
|||||||
31
updates/builder_table_create_deferred_bindings.php
Normal file
31
updates/builder_table_create_deferred_bindings.php
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?php namespace GermanAirlinesVa\Fleet\Updates;
|
||||||
|
|
||||||
|
use Config;
|
||||||
|
use Schema;
|
||||||
|
use October\Rain\Database\Updates\Migration;
|
||||||
|
|
||||||
|
class BuilderTableCreateGermanAirlinesVaSchoolingDeferredBindings extends Migration
|
||||||
|
{
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
Schema::connection('germanairlinesva_schooling')->create('deferred_bindings', function ($table) {
|
||||||
|
$table->engine = 'InnoDB';
|
||||||
|
$table->increments('id')->unsigned();
|
||||||
|
$table->string('master_type');
|
||||||
|
$table->string('master_field');
|
||||||
|
$table->string('slave_type');
|
||||||
|
$table->integer('slave_id');
|
||||||
|
$table->mediumText('pivot_data')->nullable();
|
||||||
|
$table->string('session_key');
|
||||||
|
$table->boolean('is_bind')->default(true);
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints();
|
||||||
|
Schema::connection('germanairlinesva_schooling')->dropIfExists('deferred_bindings');
|
||||||
|
Schema::connection('germanairlinesva_schooling')->enableForeignKeyConstraints();
|
||||||
|
}
|
||||||
|
}
|
||||||
28
updates/builder_table_create_member_ranks.php
Normal file
28
updates/builder_table_create_member_ranks.php
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
<?php namespace GermanAirlinesVa\Schooling\Updates;
|
||||||
|
|
||||||
|
use Schema;
|
||||||
|
use October\Rain\Database\Updates\Migration;
|
||||||
|
|
||||||
|
class BuilderTableCreateMemberRanks extends Migration
|
||||||
|
{
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
Schema::connection('germanairlinesva_schooling')->create('member_ranks', function ($table) {
|
||||||
|
$table->engine = 'InnoDB';
|
||||||
|
$table->bigIncrements('id')->unsigned();
|
||||||
|
$table->string('name');
|
||||||
|
$table->text('description');
|
||||||
|
$table->integer('points')->unsigned();
|
||||||
|
$table->integer('price')->unsigned();
|
||||||
|
$table->string('badge');
|
||||||
|
$table->string('region');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::connection('germanairlinesva_schooling')->disableForeignKeyConstraints();
|
||||||
|
Schema::connection('germanairlinesva_schooling')->dropIfExists('member_ranks');
|
||||||
|
Schema::connection('germanairlinesva_schooling')->enableForeignKeyConstraints();
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,5 +1,9 @@
|
|||||||
1.0.1:
|
1.0.1:
|
||||||
- 'Initialize plugin.'
|
- 'Initialize plugin.'
|
||||||
|
- 'Create table deferred_bindings'
|
||||||
|
- builder_table_create_deferred_bindings.php
|
||||||
1.0.2:
|
1.0.2:
|
||||||
- 'Created table typeratings'
|
- 'Created table typeratings'
|
||||||
- builder_table_create_typeratings.php
|
- builder_table_create_typeratings.php
|
||||||
|
- 'Created table member_ranks'
|
||||||
|
- builder_table_create_member_ranks.php
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user