reedware / laravel-blueprints
Adds useful methods to the blueprint schema builder.
Requires
- php: >=7.1.0
- illuminate/database: ^5.1|^6.0|^7.0|^8.0
- illuminate/support: ^5.1|^6.0|^7.0|^8.0
Requires (Dev)
- ext-fileinfo: *
- mockery/mockery: 0.9.*
- phpunit/phpunit: ~5.7
This package is auto-updated.
Last update: 2024-10-12 23:00:40 UTC
README
Adds useful methods to the blueprint schema builder.
Installation
Step 1: Require this Package
Require this package with composer.
composer require reedware/laravel-blueprints
This package uses auto-discovery, so it doesn't require you to manually add the service provider for Laravel 5.5+. Should you choose to register the service provider manually, or you're using a framework older than Laravel 5.5, you can include the following class in your list of service providers:
\Reedware\LaravelBlueprints\BlueprintsServiceProvider::class
Step 2: Publish Configuration
This package comes with a configuration file. You can either publish the configuration file (using php artisan vendor:publish
), or by copying the configuration file from the source code directly (see ~/config/blueprints.php
).
Step 3: Replace the Schema Facade
This package leverages the Schema
facade to override the default blueprint resolver for the schema builder. While this is minimally invasive on Laravel's source code, it requires a small workaround to become functional in a project. The first quirk is that you'll have to replace Laravel's default Schema
facade with the one provided by this package.
// 'Schema' => Illuminate\Support\Facades\Schema::class, 'Schema' => Reedware\LaravelBlueprints\Schema::class,
Step 4: Change your Migrations before running
Since Laravel 5.3, the absolute path to Laravel's Schema
facade was included in all of the migrations that were automatically generated. This bypasses the facade configuration that you did in Step 3. You can either uncomment this line (which will then defer to the correct facade), or you change the namespace to match the one from this package.
// use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration;
or
use Reedware\LaravelBlueprints\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration;