Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tomschlick/laravel-linkable
URL binding for Laravel models
https://github.com/tomschlick/laravel-linkable
http laravel links php url
Last synced: 3 months ago
JSON representation
URL binding for Laravel models
- Host: GitHub
- URL: https://github.com/tomschlick/laravel-linkable
- Owner: tomschlick
- License: mit
- Created: 2016-09-18T03:15:43.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2021-07-18T01:39:18.000Z (over 3 years ago)
- Last Synced: 2024-09-18T04:17:30.034Z (4 months ago)
- Topics: http, laravel, links, php, url
- Language: PHP
- Size: 27.3 KB
- Stars: 25
- Watchers: 3
- Forks: 1
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Laravel Linkable
[![StyleCI](https://styleci.io/repos/68492905/shield)](https://styleci.io/repos/68492905) [![Build Status](https://travis-ci.org/tomschlick/laravel-linkable.svg)](https://travis-ci.org/tomschlick/laravel-linkable) [![Latest Stable Version](https://poser.pugx.org/tomschlick/laravel-linkable/v/stable)](https://packagist.org/packages/tomschlick/laravel-linkable) [![Total Downloads](https://poser.pugx.org/tomschlick/laravel-linkable/downloads)](https://packagist.org/packages/tomschlick/laravel-linkable) [![License](https://poser.pugx.org/tomschlick/laravel-linkable/license)](https://packagist.org/packages/tomschlick/laravel-linkable)
--------
Linkable allows you to bind named routes directly to your Eloquent models. It has been tested with Laravel 5.0 and above (although it may work on older versions as well).Making calls to `route()` each time you need to generate a url can be cumbersome and makes your Blade files unreadable. Instead with Linkable, you can use this syntax to generate a url:
```php
$model->link()
```That's it! Check out the full usage below.
## Install via Composer
```bash
composer require tomschlick/laravel-linkable
```## Add to your model(s) and implement the interface
```php
class User extends Model
{
use TomSchlick\Linkable\Linkable;
public function sublink(string $key, array $attr = []) : string
{
return route("users.$key", [
'user_id' => $this->id, // 'user_id' is the name of the parameter in the users.* route group
] + $attr);
}
}
```## Usage
```php
$model->link(); // Link for the resource (example: https://your-site.com/user/7)$model->sublink('edit'); // SubLink for the resource (example: https://your-site.com/user/7/edit)
$model->sublink('photos.show', ['photo_id' => 1234]); // SubLink for the resource (example: https://your-site.com/user/7/photos/1234)
$model->redirect(); // Generates a redirect response to the resource to use in a controller return statement.
$model->sublinkRedirect('edit'); // Generates a redirect response to the resource's edit page to use in a controller return statement.
```