Compare commits

...

2 Commits

Author SHA1 Message Date
Gogs
dfe1530d27 MemberRanks 2021-06-15 00:36:47 +02:00
Gogs
1f448b1ec4 Deferred Bindings 2021-06-14 16:08:55 +02:00
16 changed files with 369 additions and 14 deletions

View 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();
}
}

View 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>

View 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

View 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'

View 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 ?>

View File

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

View 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>

View 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 ?>

View File

@ -10,5 +10,18 @@
'menu' => [
'main' => 'GA Schooling',
'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
View 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',
];
}

View 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

View 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

View File

@ -1,16 +1,26 @@
plugin:
name: 'germanairlinesva.schooling::lang.plugin.name'
description: 'germanairlinesva.schooling::lang.plugin.description'
author: 'German Airlines Va'
icon: oc-icon-university
homepage: ''
name: 'germanairlinesva.schooling::lang.plugin.name'
description: 'germanairlinesva.schooling::lang.plugin.description'
author: 'German Airlines Va'
icon: oc-icon-university
homepage: ''
navigation:
main-menu-item:
label: 'germanairlinesva.schooling::lang.menu.main'
url: /
icon: icon-university
sideMenu:
side-menu-item:
label: 'germanairlinesva.schooling::lang.menu.typeratings'
url: germanairlinesva/schooling/typerating
icon: icon-plane
main-menu-item:
label: 'germanairlinesva.schooling::lang.menu.main'
url: /
icon: icon-university
permissions:
- schooling
sideMenu:
side-menu-item:
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'

View 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();
}
}

View 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();
}
}

View File

@ -1,5 +1,9 @@
1.0.1:
- 'Initialize plugin.'
- 'Create table deferred_bindings'
- builder_table_create_deferred_bindings.php
1.0.2:
- 'Created table typeratings'
- builder_table_create_typeratings.php
- 'Created table member_ranks'
- builder_table_create_member_ranks.php