1. Go to this page and download the library: Download takemo101/laravel-simple-vm library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
takemo101 / laravel-simple-vm example snippets
namespace App\Http\ViewModel;
use Takemo101\LaravelSimpleVM\ViewModel;
use Takemo101\SimpleVM\Attribute\{
Ignore,
ChangeName,
};
use App\Models\User;
use Illuminate\Support\Collection;
/**
* You need to extend and create the ViewModel class.
* Only the public properties and methods defined in the ViewModel class will be the output target values.
*/
class TestViewModel extends ViewModel
{
/**
* ignores property or method names
*
* @var string[]
*/
protected array $__ignores = [
//
];
/**
* The data to be output to View is passed to the ViewModel class in the constructor.
*/
public function __construct(
public string $description,
private User $user,
) {
//
}
/**
* Method injection is available for each published method
*/
public function users(User $user): Collection
{
return $user->all();
}
/**
* You can also process the model object and output it like the JsonResponse class.
*/
public function user(): array
{
return [
'name' => $this->user->name,
'email' => $this->user->email,
];
}
/**
* You can ignore the output to the View by setting the Ignore Attribute class
*/
#[Ignore]
public function other(): string
{
return 'other';
}
/**
* You can change the output name to the View by setting the ChangeName Attribute class.
*/
#[ChangeName('modification')]
public function change(): string
{
return 'change';
}
}
namespace App\Http\Controllers;
use App\Http\ViewModel\TestViewModel;
use App\Models\User;
class HomeController
{
/**
* Output Json by making the return value of the controller method an object of ViewModel
*/
public function json()
{
$user = new User();
$user->name = 'name';
$user->email = '[email protected]';
return new TestViewModel(
'description',
$user,
);
}
/**
* You can use the output data on the template by passing a ViewModel object as the template data
*/
public function view()
{
$user = new User();
$user->name = 'name';
$user->email = '[email protected]';
// By using the toAccessArray method, you can treat the output data like an object on the template.
return view('home.view', (new TestViewModel(
'description',
$user,
))->toAccessArray());
// You can create an object from the of method of the ViewModel class
}
}
# php artisan make:svm TestViewModel
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.