novius/laravel-linkable
最新稳定版本:1.1.1
Composer 安装命令:
composer require novius/laravel-linkable
包简介
A Laravel Eloquent model trait for linkable resource
README 文档
README
Introduction
A package to manage Laravel Eloquent models linkable.
Provide a Linkable Nova Field.
Requirements
- PHP >= 8.2
- Laravel 10.0
Installation
You can install the package via composer:
composer require novius/laravel-linkable
Optionally, you can also:
php artisan vendor:publish --provider="Novius\LaravelLinkable\LaravelLinkableServiceProvider" --tag=config php artisan vendor:publish --provider="Novius\LaravelLinkable\LaravelLinkableServiceProvider" --tag=lang
Usage
Eloquent Model Trait
namespace App\Models; use \Illuminate\Database\Eloquent\Model; use Novius\LaravelLinkable\Traits\Linkable; class Post extends Model { use Linkable; ... public function getLinkableConfig(): LinkableModelConfig { if (! isset($this->linkableConfig)) { $this->linkableConfig = new LinkableModelConfig( // To retrieve a instance url, you can define the getUrlCallback getUrlCallback: function (Model $model, array $extraParameters = []) { return route('post_route', [ ...$extraParameters, 'post' => $model, ], true, $model->locale) }, // Or your can juste define the route name and the route name parameter routeName: 'post_route', routeParameterName: 'post', optionLabel: 'title', // Required. A field of your model or a closure (taking the model instance as parameter) returning a label. Use to display a model instance in the Linkable Nova field optionGroup: 'My model', // Required. The name of the group of the model in the Linkable Nova field optionsQuery: function (Builder|Page $query) { // Optional. To modify the default query to populate the Linkable Nova field $query->published(); }, resolveQuery: function (Builder|Page $query) { // Optional. The base query to resolve the model binding $query->where('locale', app()->currentLocale()); }, resolveNotPreviewQuery: function (Builder|Page $query) { // Optional. The query to resolve the model binding when not in preview mode $query->published(); }, previewTokenField: 'preview_token' // Optional. The field that contains the preview token of the model ); } return $this->linkableConfig; }
Now you can do that:
// In your route file, if you choose to work with `routeName` and `routeParameterName` Route::get('post/{post}', function (Post $post) { // ... })->name('post_route'); $post = Post::first(); $post->url(); $post->previewUrl();
Nova
If you use Laravel Nova, you can now use the Linkable field :
<?php use Novius\LaravelLinkable\Nova\Fields\Linkable; class MyResource extends Resource { public static $model = \App\Models\MyResource::class; public function fields(NovaRequest $request) { return [ // ... Linkable::make('Link', 'link') ->linkableClasses([ // Optional: if you want to restrict link types 'route', OtherModel::class, ]), ]; } }
Filament
If you use Laravel Filament, you can now use the Linkable field :
<?php use Novius\LaravelLinkable\Filament\Forms\Components\Linkable; class MyResource extends Resource { public static $model = \App\Models\MyResource::class; public static function form(Form $form): Form { return $form ->schema([ // ... Linkable::make('link') ->label('Link') ->setLinkableClasses([ // Optional: if you want to restrict link types 'route', OtherModel::class, ]) ->setLocale('fr'), // Optional: if you want to predefine locale ]); } }
Retrieving link
Now you can do that:
use Novius\LaravelLinkable\Facades\Linkable; $model = MyResource::first(); echo Linkable::getLink($model->link);
Configuration
return [ // Laravel Linkable will autoload all Model using Linkable trait in this directory 'autoload_models_in' => app_path('Models'), // The guard name to preview a model without using the preview token 'guard_preview' => null, /* * Sometimes you need to link items that are not objects. * * This config allows you to link routes. * For instance: 'contact' => 'page.contact' * * "contact" will be the parameter of the laravel function route(). * "page.contact" will be the parameter of the laravel function trans(). */ 'linkable_routes' => [ 'my_route' => 'My route', ], /* * If you want to add specific models that use the linkable trait and that do not appear in your `autoload_models_in` directory */ 'linkable_models' => [ \Provider\Package\Models\Model::class, ], // Set to `true` if you don't want to use localization 'disable_localization' => false, ];
If you want to customize the way Linkable generates URLs (by default the native route() method of Laravel), you can define your own method.
Indispensable if you use a localization package for the routes.
Add this in your ServiceProvider:
namespace App\Providers; use Illuminate\Support\ServiceProvider; use Novius\LaravelLinkable\Facades\Linkable; class AppServiceProvider extends ServiceProvider { public function boot(): void { $this->app->booted(function () { Linkable::setRouteCallback(static function (string $name, array $parameters = [], ?string $locale = null) { // This is an example of a package adding a `locale` to the route method return route($name, $parameters, true, $locale); }); Linkable::setHasRouteCallback(static function (string $name, ?string $locale = null) { // This is an example of a package adding a `hasLocalized` method on Route facade return Route::hasLocalized($name, $locale); }); }); } }
Testing
composer run test
CS Fixer
Lint your code with Laravel Pint using:
composer run cs-fix
Licence
This package is under GNU Affero General Public License v3 or (at your option) any later version.
统计信息
- 总下载量: 4.27k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 3
- 推荐数: 0
其他信息
- 授权协议: AGPL-3.0-or-later
- 更新时间: 2024-08-06