jaxon-php / jaxon-symfony
Jaxon library integration for the Symfony Framework
Installs: 1 281
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 3
Open Issues: 0
Requires
- jaxon-php/jaxon-core: ^5.0
- symfony/expression-language: *
- symfony/framework-bundle: 5.*|6.*|7.*
Requires (Dev)
- twig/twig: ^3.10
Provides
- dev-main
- v5.0.2
- v5.0.1
- v5.0.0
- v5.0.0-beta.1
- v4.x-dev
- v4.0.0
- v4.0-rc.1
- v4.0-beta.1
- v3.4.x-dev
- v3.4.0
- v3.3.0
- v3.2.3
- v3.2.2
- v3.2.1
- v3.2.0
- v3.1.0
- v3.0.2
- v3.0.1
- v3.0.0
- v2.2.0
- v2.1.0
- v2.0.4
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- 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.x-dev
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- dev-analysis-8bR4x4
This package is auto-updated.
Last update: 2025-06-29 03:02:13 UTC
README
This package is an extension to integrate the Jaxon library into the Symfony framework. It works with Symfony version 5 or newer.
Installation
Add the following lines in the composer.json
file, and run the composer update jaxon-php/
command.
"require": { "jaxon-php/jaxon-symfony": "^5.0" }
Add the Jaxon bundle in the config/bundle.php
file.
return [ ... Jaxon\Symfony\JaxonBundle::class => ['all' => true], ];
Configuration
The library configuration is located in the packages/config/jaxon.yaml
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/jaxon.yaml
file of this repo.
Add the following settings in the config/services.yaml
file, to configure the Jaxon library.
imports: ... - { resource: packages/jaxon.yaml }
Add the following settings in the config/routes.yaml
file, to configure the Jaxon route.
jaxon_ajax: resource: 'Jaxon\Symfony\App\Jaxon::route' type: service
Routing and listener
The extension provides a route and a controller to process Jaxon Ajax requests, as well as a listener on the kernel.controller
event to bootstrap the Jaxon library.
Dependency injection
Services in Symfony can be declared as public or private, and injected in Jaxon classes.
Since Jaxon uses a container to fetch to the Symfony services that are injected in his classes, by default it will be able to get access only to services declared as public.
A service locator can be defined for Jaxon in the config/services.yaml
file, in order to provide access to private services.
services: ... jaxon.service_locator: public: true class: Symfony\Component\DependencyInjection\ServiceLocator tags: ['container.service_locator'] arguments: - Twig\Environment: '@twig'
The service locator must be declared as public, and take all the services that can be passed to Jaxon classes as arguments. See the Symfony service locators documentation.
Twig functions
This extension provides the following Twig functions to insert Jaxon js and css codes in the pages that need to show Jaxon related content.
// templates/demo/index.html.twig <!-- In page header --> {{ jxnCss() }} </head> <body> <!-- Page content here --> </body> <!-- In page footer --> {{ jxnJs() }} {{ jxnScript() }}
Call factories
This extension registers the following Twig functions 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
function attaches a UI component to a DOM element, while the jxnHtml
function displays a component HTML code in a view.
<div class="col-md-12" {{ jxnBind(rqAppTest) }}> {{ jxnHtml(rqAppTest) }} </div>
The jxnPagination
function displays pagination links in a view.
<div class="col-md-12" {{ jxnPagination(rqAppTest) }}> </div>
The jxnOn
function 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
function 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
function 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
function 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-symfony/issues
- Source Code: github.com/jaxon-php/jaxon-symfony
License
The package is licensed under the BSD license.