12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- <?php
-
- 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('budgets', function (Blueprint $table) {
- $table->id();
- $table->foreignId('company_id')->constrained()->cascadeOnDelete();
- $table->foreignId('source_budget_id')->nullable()->constrained('budgets')->nullOnDelete();
- // Source fiscal year
- $table->year('source_fiscal_year')->nullable();
- $table->string('source_type')->nullable(); // budget, actuals
- $table->string('name');
- $table->date('start_date');
- $table->date('end_date');
- $table->string('status')->default('draft'); // draft, active, closed
- $table->string('interval_type')->default('month'); // day, week, month, quarter, year
- $table->text('notes')->nullable();
- $table->timestamp('approved_at')->nullable();
- $table->foreignId('approved_by_id')->nullable()->constrained('users')->nullOnDelete();
- $table->timestamp('closed_at')->nullable();
- $table->foreignId('created_by')->nullable()->constrained('users')->nullOnDelete();
- $table->foreignId('updated_by')->nullable()->constrained('users')->nullOnDelete();
- $table->timestamps();
- });
- }
-
- /**
- * Reverse the migrations.
- */
- public function down(): void
- {
- Schema::dropIfExists('budgets');
- }
- };
|