|
Server : Apache/2.4.41 (Ubuntu) System : Linux vmi1525618.contaboserver.net 5.4.0-105-generic #119-Ubuntu SMP Mon Mar 7 18:49:24 UTC 2022 x86_64 User : www-data ( 33) PHP Version : 8.2.12 Disable Function : NONE Directory : /var/www/lecturebazaar.com/database/migrations/ |
Upload File : |
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
class CreateInstallmentsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('installments', function (Blueprint $table) {
$table->increments('id');
$table->enum('target_type', \App\Models\Installment::$targetTypes);
$table->string('target')->nullable();
$table->integer('capacity')->unsigned()->nullable();
$table->bigInteger('start_date')->unsigned()->nullable();
$table->bigInteger('end_date')->unsigned()->nullable();
$table->boolean('verification')->default(false);
$table->boolean('request_uploads')->default(false);
$table->boolean('bypass_verification_for_verified_users')->default(false);
$table->float('upfront', 15, 2)->nullable();
$table->enum('upfront_type', ['fixed_amount', 'percent'])->nullable();
$table->boolean('enable')->default(false);
$table->bigInteger('created_at')->unsigned();
});
Schema::create('installment_translations', function (Blueprint $table) {
$table->increments('id');
$table->integer('installment_id')->unsigned();
$table->string('locale', 191)->index();
$table->string('title');
$table->string('main_title');
$table->text('description');
$table->string('banner')->nullable();
$table->text('options')->nullable();
$table->text('verification_description')->nullable();
$table->string('verification_banner')->nullable();
$table->string('verification_video')->nullable();
$table->foreign('installment_id')->on('installments')->references('id')->cascadeOnDelete();
});
Schema::create('installment_specification_items', function (Blueprint $table) {
$table->increments('id');
$table->integer('installment_id')->unsigned();
$table->integer('category_id')->unsigned()->nullable();
$table->integer('instructor_id')->unsigned()->nullable();
$table->integer('seller_id')->unsigned()->nullable();
$table->integer('webinar_id')->unsigned()->nullable();
$table->integer('product_id')->unsigned()->nullable();
$table->integer('bundle_id')->unsigned()->nullable();
$table->integer('subscribe_id')->unsigned()->nullable();
$table->integer('registration_package_id')->unsigned()->nullable();
$table->foreign('installment_id')->on('installments')->references('id')->cascadeOnDelete();
$table->foreign('category_id')->on('categories')->references('id')->cascadeOnDelete();
$table->foreign('instructor_id')->on('users')->references('id')->cascadeOnDelete();
$table->foreign('seller_id')->on('users')->references('id')->cascadeOnDelete();
$table->foreign('webinar_id')->on('webinars')->references('id')->cascadeOnDelete();
$table->foreign('product_id')->on('products')->references('id')->cascadeOnDelete();
$table->foreign('bundle_id')->on('bundles')->references('id')->cascadeOnDelete();
$table->foreign('subscribe_id')->on('subscribes')->references('id')->cascadeOnDelete();
$table->foreign('registration_package_id')->on('registration_packages')->references('id')->cascadeOnDelete();
});
Schema::create('installment_steps', function (Blueprint $table) {
$table->increments('id');
$table->integer('installment_id')->unsigned();
$table->integer('deadline')->unsigned()->nullable();
$table->float('amount', 15, 2)->nullable();
$table->enum('amount_type', ['fixed_amount', 'percent'])->nullable();
$table->integer('order')->unsigned()->nullable();
$table->foreign('installment_id')->on('installments')->references('id')->cascadeOnDelete();
});
Schema::create('installment_step_translations', function (Blueprint $table) {
$table->increments('id');
$table->integer('installment_step_id')->unsigned();
$table->string('locale', 191)->index();
$table->string('title');
$table->foreign('installment_step_id')->on('installment_steps')->references('id')->cascadeOnDelete();
});
Schema::create('installment_user_groups', function (Blueprint $table) {
$table->increments('id');
$table->integer('installment_id')->unsigned();
$table->integer('group_id')->unsigned()->nullable();
$table->foreign('installment_id')->on('installments')->references('id')->cascadeOnDelete();
$table->foreign('group_id')->on('groups')->references('id')->cascadeOnDelete();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('installments');
Schema::dropIfExists('installment_translations');
Schema::dropIfExists('installment_specification_items');
Schema::dropIfExists('installment_steps');
Schema::dropIfExists('installment_step_translations');
Schema::dropIfExists('installment_user_groups');
}
}