Files
InvoiceShelf/database/migrations/2021_09_28_130822_add_sequence_column.php
mchev 3259173066 Laravel 11 (#84)
* Convert string references to `::class`

PHP 5.5.9 adds the new static `class` property which provides the fully qualified class name. This is preferred over using strings for class names since the `class` property references are checked by PHP.

* Use Faker methods

Accessing Faker properties was deprecated in Faker 1.14.

* Convert route options to fluent methods

Laravel 8 adopts the tuple syntax for controller actions. Since the old options array is incompatible with this syntax, Shift converted them to use modern, fluent methods.

* Adopt class based routes

* Remove default `app` files

* Shift core files

* Streamline config files

* Set new `ENV` variables

* Default new `bootstrap/app.php`

* Re-register HTTP middleware

* Consolidate service providers

* Re-register service providers

* Re-register routes

* Re-register scheduled commands

* Bump Composer dependencies

* Use `<env>` tags for configuration

`<env>` tags have a lower precedence than system environment variables making it easier to overwrite PHPUnit configuration values in additional environments, such a CI.

Review this blog post for more details on configuration precedence when testing Laravel: https://jasonmccreary.me/articles/laravel-testing-configuration-precedence/

* Adopt anonymous migrations

* Rename `password_resets` table

* Convert `$casts` property to method

* Adopt Laravel type hints

* Mark base controller as `abstract`

* Remove `CreatesApplication` testing trait

* Shift cleanup

* Fix shift first issues

* Updating Rules for laravel 11, sanctum config and pint

* Fix Carbon issue on dashboard

* Temporary fix for tests while migration is issue fixed on laravel side

* Carbon needs numerical values, not strings

* Minimum php version

* Fix domain installation step not fetching the correct company_id

* Fix Role Policy wasn't properly registered

---------
2024-06-05 11:33:52 +02:00

98 lines
3.8 KiB
PHP

<?php
use App\Models\Customer;
use App\Models\User;
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::table('customers', function (Blueprint $table) {
$table->string('prefix')->nullable()->after('id');
});
Schema::table('invoices', function (Blueprint $table) {
$table->mediumInteger('sequence_number')->unsigned()->nullable()->after('id');
$table->mediumInteger('customer_sequence_number')->unsigned()->nullable()->after('sequence_number');
});
Schema::table('estimates', function (Blueprint $table) {
$table->mediumInteger('sequence_number')->unsigned()->nullable()->after('id');
$table->mediumInteger('customer_sequence_number')->unsigned()->nullable()->after('sequence_number');
});
Schema::table('payments', function (Blueprint $table) {
$table->mediumInteger('sequence_number')->unsigned()->nullable()->after('id');
$table->mediumInteger('customer_sequence_number')->unsigned()->nullable()->after('sequence_number');
});
$user = User::where('role', 'super admin')->first();
if ($user && $user->role == 'super admin') {
$customers = Customer::all();
foreach ($customers as $customer) {
$invoices = $customer->invoices;
if ($invoices) {
$customerSequence = 1;
$invoices->map(function ($invoice) use ($customerSequence) {
$invoiceNumber = explode('-', $invoice->invoice_number);
$invoice->sequence_number = intval(end($invoiceNumber));
$invoice->customer_sequence_number = $customerSequence;
$invoice->save();
$customerSequence += 1;
});
}
$estimates = $customer->estimates;
if ($estimates) {
$customerSequence = 1;
$estimates->map(function ($estimate) use ($customerSequence) {
$estimateNumber = explode('-', $estimate->estimate_number);
$estimate->sequence_number = intval(end($estimateNumber));
$estimate->customer_sequence_number = $customerSequence;
$estimate->save();
$customerSequence += 1;
});
}
$payments = $customer->payments;
if ($estimates) {
$customerSequence = 1;
$payments->map(function ($payment) use ($customerSequence) {
$paymentNumber = explode('-', $payment->payment_number);
$payment->sequence_number = intval(end($paymentNumber));
$payment->customer_sequence_number = $customerSequence;
$payment->save();
$customerSequence += 1;
});
}
}
}
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('invoices', function (Blueprint $table) {
$table->dropColumn('sequence_number');
$table->dropColumn('customer_sequence_number');
});
Schema::table('estimates', function (Blueprint $table) {
$table->dropColumn('sequence_number');
$table->dropColumn('customer_sequence_number');
});
Schema::table('payments', function (Blueprint $table) {
$table->dropColumn('sequence_number');
$table->dropColumn('customer_sequence_number');
});
}
};