Download the PHP package hihaho/laravel-js-store without Composer
On this page you can find all versions of the php package hihaho/laravel-js-store. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download hihaho/laravel-js-store
More information about hihaho/laravel-js-store
Files in hihaho/laravel-js-store
Package laravel-js-store
Short Description Laravel JS Store - Easily render data to your blade templates to use in your frontend, like Vue
License MIT
Homepage https://github.com/hihaho/laravel-js-store
Informations about the package laravel-js-store
Laravel JS Store
Easily pass data to your view to create an initial state for your frontend. This package lets you easily create and register global data providers (for each page), which for example is useful for user data. You can also manually push data on the fly, for example in a controller.
Installation
You can install the package via composer:
Next you should render the js data on your page, there are a few different ways to do this:
Blade directive
Add the @frontend_store
directive to your view:
Overwrite the default view
Publish the current one using php artisan vendor:publish --tag=laravel-js-store-views
or create a new view: resources/views/vendor/js-store/script.blade.php
Output the data the way you want and then include it using the blade directive (@frontend_store
).
Usage
There are two methods of pushing data to the store, through data-providers or pushing manually.
Pushing manually
At any point in your application you can push data to the store using the helper, facade or through the laravel container.
You can push pretty much any type of data, as long as it can be cast to a string.
Data-providers
Data-providers are classes that can be used to globally define data that should be send to your frontend. It's also a convenient way to store more logic related to the data, or define a rule if the data needs to be rendered.
The data-providers are defined in your config, so first you'll have to publish the config file.
This should create config/js-store.php
.
Create a data provider using the artisan make command:
This creates a data-provider which extends HiHaHo\LaravelJsStore\AbstractFrontendDataProvider
.
An example of a data-provider might look like this:
Next, register you data-provider in config/js-store.php
:
Your data will now automatically be rendered in blade views (in this case only when the user is signed in).
Usage with Laravel Octane
This package registers a singleton to manage all data that's sent to the JS Store. Laravel Octane will register one instance per request, but only when the singleton is not accessed inside a service provider. For this reason it's not possible to push data to the store within a service provider.
Generally it won't be necessary to flush all data between requests, but if you need this behaviour you can flush the data between requests.
Any data that is pushed within a service provider won't be available in requests.
To flush the data between requests you should add the PrepareStoreForNextOperation::class
listener to the following Octane events in config/octane.php
:
RequestReceived::class
TaskReceived::clas
TickReceived::class
Testing
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Credits
- Robert Boes
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
Laravel Package Boilerplate
This package was generated using the Laravel Package Boilerplate.
All versions of laravel-js-store with dependencies
ext-json Version *
illuminate/support Version ^11.31|^12.0
spatie/laravel-package-tools Version ^1.14