jaxon-php / jaxon-laravel
Jaxon library integration for the Laravel framework
Installs: 1 389
Dependents: 1
Suggesters: 0
Security: 0
Stars: 9
Watchers: 2
Forks: 2
Open Issues: 0
Requires
- illuminate/support: 7.*|8.*|9.*|10.*|11.*|12.*
- jaxon-php/jaxon-core: ^5.0
Provides
- dev-main
- v5.0.2
- v5.0.1
- v5.0.0
- v5.0.0-beta.1
- v4.x-dev
- v4.1.0
- v4.0.2
- v4.0.1
- v4.0.0
- v4.0-rc.1
- v4.0-beta.1
- v3.2.x-dev
- v3.2.1
- v3.2.0
- v3.1.0
- v3.0.4
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0.0
- v3.0-beta.2
- v3.0-beta.1
- v2.0.2
- v2.0.1
- v2.0.0
- v2.0-beta.9
- v2.0-beta.8
- v2.0-beta.7
- v2.0-beta.6
- v2.0-beta.5
- v2.0-beta.4
- v2.0-beta.3
- v2.0-beta.2
- v2.0-beta.1
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
This package is auto-updated.
Last update: 2025-06-29 02:02:00 UTC
README
This package is an extension to integrate the Jaxon library into the Laravel framework. It works with Laravel version 7 or newer.
Installation
Add the following lines in the composer.json
file, and run the composer update jaxon-php/*
command.
"require": { "jaxon-php/jaxon-laravel": "^5.0" }
Publish the package configuration.
php artisan vendor:publish --tag=config
Configuration
The library configuration is located in the config/jaxon.php
file.
It must contain both the app
and lib
sections defined in the documentation (https://www.jaxon-php.org/docs/v5x/about/configuration.html).
An example is presented in the config/config.php
file of this repo.
Routing and middlewares
The extension automatically registers two middlewares, jaxon.config
and, jaxon.ajax
.
The jaxon.config
middleware calls the Jaxon library setup function. It must be added to the routes to pages that need to show Jaxon related content.
Route::get('/', [DemoController::class, 'index']) ->middleware(['web', 'jaxon.config']) ->name('demo');
The extension also registers the Jaxon requests route and the associated middlewares.
The route url is the value of the lib.core.request.uri
option, the app.request.route
gives an optional name to the route, and the app.request.middlewares
option defines additional middlewares.
'app' => [ 'request' => [ 'route' => 'jaxon', // The route name 'middlewares' => ['web'], ], ], 'lib' => [ 'core' => [ 'request' => [ 'uri' => '/jaxon', // The route url ], ], ],
Usage
This extension registers the following Blade directives to insert Jaxon js and css codes in the pages that need to show Jaxon related content.
// resources/views/demo/index.blade.php <!-- In page header --> @jxnCss() </head> <body> <!-- Page content here --> </body> <!-- In page footer --> @jxnJs() @jxnScript()
Call factories
This extension registers the following Blade directives for Jaxon call factories functions.
Note
In the following examples, the $rqAppTest
template variable is set to the value rq(Demo\Ajax\App\AppTest::class)
.
The jxnBind
directive attaches a UI component to a DOM element, while the jxnHtml
directive displays a component HTML code in a view.
<div class="col-md-12" @jxnBind($rqAppTest)> @jxnHtml($rqAppTest) </div>
The jxnPagination
directive displays pagination links in a view.
<div class="col-md-12" @jxnPagination($rqAppTest)> </div>
The jxnOn
directive binds an event on a DOM element to a Javascript call defined with a call factory
.
<select class="form-select" @jxnOn('change', $rqAppTest->setColor(jq()->val()))> <option value="black" selected="selected">Black</option> <option value="red">Red</option> <option value="green">Green</option> <option value="blue">Blue</option> </select>
The jxnClick
directive is a shortcut to define a handler for the click
event.
<button type="button" class="btn btn-primary" @jxnClick($rqAppTest->sayHello(true))>Click me</button>
The jxnEvent
directive defines a set of events handlers on the children of a DOM element, using jQuery
selectors.
<div class="row" @jxnEvent([ ['.app-color-choice', 'change', $rqAppTest->setColor(jq()->val())] ['.ext-color-choice', 'change', $rqExtTest->setColor(jq()->val())] ])> <div class="col-md-12"> <select class="form-control app-color-choice"> <option value="black" selected="selected">Black</option> <option value="red">Red</option> <option value="green">Green</option> <option value="blue">Blue</option> </select> </div> <div class="col-md-12"> <select class="form-control ext-color-choice"> <option value="black" selected="selected">Black</option> <option value="red">Red</option> <option value="green">Green</option> <option value="blue">Blue</option> </select> </div> </div>
The jxnEvent
directive takes as parameter an array in which each entry is an array with a jQuery
selector, an event and a call factory
.
Contribute
- Issue Tracker: github.com/jaxon-php/jaxon-laravel/issues
- Source Code: github.com/jaxon-php/jaxon-laravel
License
The package is licensed under the BSD license.