1234567891011121314151617181920212223242526272829303132333435363738394041 |
- <?php
-
- use App\Enums\Setting\TaxComputation;
- use App\Enums\Setting\TaxType;
- use Illuminate\Database\Migrations\Migration;
- use Illuminate\Database\Schema\Blueprint;
- use Illuminate\Support\Facades\Schema;
-
- return new class extends Migration
- {
- /**
- * Run the migrations.
- */
- public function up(): void
- {
- Schema::create('taxes', function (Blueprint $table) {
- $table->id();
- $table->foreignId('company_id')->constrained()->cascadeOnDelete();
- $table->string('name')->index();
- $table->string('description')->nullable();
- $table->integer('rate')->default(0);
- $table->string('computation')->default(TaxComputation::DEFAULT);
- $table->string('type')->default(TaxType::DEFAULT);
- $table->string('scope')->nullable();
- $table->boolean('enabled')->default(true);
- $table->foreignId('created_by')->nullable()->constrained('users')->nullOnDelete();
- $table->foreignId('updated_by')->nullable()->constrained('users')->nullOnDelete();
- $table->timestamps();
-
- $table->unique(['company_id', 'name', 'type']);
- });
- }
-
- /**
- * Reverse the migrations.
- */
- public function down(): void
- {
- Schema::dropIfExists('taxes');
- }
- };
|