Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tbreuss/yii2-inertia
The Yii 2 server-side adapter for Inertia.js.
https://github.com/tbreuss/yii2-inertia
adapter hacktoberfest inertiajs yii2
Last synced: about 1 month ago
JSON representation
The Yii 2 server-side adapter for Inertia.js.
- Host: GitHub
- URL: https://github.com/tbreuss/yii2-inertia
- Owner: tbreuss
- License: mit
- Created: 2020-02-12T21:09:08.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-07-24T11:39:33.000Z (5 months ago)
- Last Synced: 2024-11-08T08:27:34.771Z (about 1 month ago)
- Topics: adapter, hacktoberfest, inertiajs, yii2
- Language: PHP
- Homepage:
- Size: 42 KB
- Stars: 63
- Watchers: 5
- Forks: 9
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-inertiajs - Yii2
README
# Inertia.js Yii 2 Adapter
This is the Yii 2 server-side adapter for [Inertia](https://inertiajs.com).
With Inertia you are able to build single-page apps using classic server-side routing and controllers, without building an API.
To use Inertia you need both a server-side adapter as well as a client-side adapter.
Be sure to follow the installation instructions for the [client-side framework](https://inertiajs.com/client-side-setup) you use.## Demo
## Installation
Composer require dependency:
```sh
composer require tebe/yii2-inertia
```Edit `config/web.php`:
```php
['inertia']
...
'components' => [
'inertia' => [
'class' => 'tebe\inertia\Inertia'
'rootElementId' => 'app' // optional per https://inertiajs.com/client-side-setup#defining-a-root-element
],
'request' => [
'cookieValidationKey' => '',
'enableCsrfValidation' => false,
'enableCsrfCookie' => false,
'parsers' => [
'application/json' => 'yii\web\JsonParser',
]
]
]
...
];
```Note that CSRF protection is disabled.
## Controllers
Your backend controllers should extend from `tebe\inertia\web\Controller`.
Instead of the render method within your actions you should use the `inertia` method.```php
[],
'links' => []
];
return $this->inertia('demo/index', $params);
}
}
```## Routing
Use your Yii server-side routes as usual.
There is nothing special.## CSRF protection
Axios is the HTTP library that Inertia uses under the hood.
Yii's CSRF protection is not optimized for Axios.The easiest way to implement CSRF protection is using the customized `tebe\inertia\web\Request` component.
Simply edit `config/web.php` file:
```php
[
'request' => [
'class' => 'tebe\inertia\web\Request',
'cookieValidationKey' => ''
]
]
];
```Please see the [security page](https://inertiajs.com/security) for more details.
### Shared data
The Yii 2 adapter provides a way to preassign shared data for each request.
This is typically done outside of your controllers.
Shared data will be automatically merged with the page props provided in your controller.Massive assignment of shared data:
```php
[
'id' => $this->getUser()->id,
'first_name' => $this->getUser()->firstName,
'last_name' => $this->getUser()->lastName,
],
'flash' => $this->getFlashMessages(),
'errors' => $this->getFormErrors(),
'filters' => $this->getGridFilters()
];
Yii::$app->get('inertia')->share($shared);
```Shared data for one key:
```php
$this->getUser()->id,
'first_name' => $this->getUser()->firstName,
'last_name' => $this->getUser()->lastName
];
Yii::$app->get('inertia')->share('user', $user);
```A good strategy when using shared data outside of your controllers is to implement an action filter.
```php
$this->getUser(),
'flash' => $this->getFlashMessages(),
'errors' => $this->getFormErrors()
];
Yii::$app->get('inertia')->share($shared);
return parent::beforeAction($action);
}
}
```And then use this action filter as a behaviour in your controller.
```php
SharedDataFilter::class
]
];
}
public function actionIndex()
{
// your action code
}
}
```Please see the [shared data page](https://inertiajs.com/shared-data) for more details.
## Client-side setup
To use Inertia you need to setup your client-side framework.
This primarily includes updating your main JavaScript file to boot the Inertia app.
Please see the [client-side setup page](https://inertiajs.com/client-side-setup) for more details.## More about Inertia
Visit [inertiajs.com](https://inertiajs.com/) to learn more.