Reactive Twig Templates
An Interactive UI
in PHP & Twig
Develop your interface.. from the comfort of Symfony.
No Javascript needed.
composer require symfony/ux-live-component
// ... use statements hidden - click to show
#[AsLiveComponent('SearchPackages', template: 'components/Package/SearchPackages.html.twig')]
class SearchPackages
{
use DefaultActionTrait;
#[LiveProp(writable: true, url: true)]
public ?string $query = null;
public function __construct(private UxPackageRepository $packageRepo)
{
}
public function getPackages(): array
{
return $this->packageRepo->findAll($this->query);
}
}
<div{{ attributes }}>
<input type="text" data-model="query" placeholder="Results update as you type..." class="form-control" />
<div class="PackageList pt-3" data-loading="addClass(opacity-50)">
{% for package in computed.packages %}
{{ include('components/Package/PackageListItem.html.twig', {package}) }}
{% else %}
No packages found "{{ query }}"
{% endfor %}
</div>
</div>
data:image/s3,"s3://crabby-images/67973/6797311cd0fe47fd2eeef781c1aac633bdab9034" alt="Symfony logo"
Live Components
Install It
$ composer require symfony/ux-live-component
Live Component Demos
Find out what else you can build
Read full Documentationdata:image/s3,"s3://crabby-images/d9d62/d9d62e47ac3a0802c0d14aeb0c8413118e9fe43f" alt="Infinite Scroll - 2/2 demo preview"
Infinite Scroll - 2/2
Loading on-scroll, flexible layout grid, colorfull loading animations and... more T-Shirts!
data:image/s3,"s3://crabby-images/da8ea/da8ea6e9330f46d89913064d25e479002ea4277c" alt="Infinite Scroll - 1/2 demo preview"
Infinite Scroll - 1/2
Load more items as you scroll down the page.
data:image/s3,"s3://crabby-images/6dd2a/6dd2a58b3aa5035608ad2d7da3b3e5543cc28e51" alt="Live Memory Card Game demo preview"
Live Memory Card Game
A Memorable Game UX with Live Components!
data:image/s3,"s3://crabby-images/08505/085055928820211c8a59640febae2e92bfa9f981" alt="Auto-Validating Form demo preview"
Auto-Validating Form
Create a form that validates each field in-real-time as the user enters data!
data:image/s3,"s3://crabby-images/9b405/9b40519d81bd385e406f0b2cfaaaee752213f6c0" alt="Embedded CollectionType Form demo preview"
Embedded CollectionType Form
Create embedded forms with functional "add" and "remove" buttons all in Twig.
data:image/s3,"s3://crabby-images/d4d57/d4d57b315c8624ae74eee5aca21134c2150f7bb0" alt="Dependent Form Fields demo preview"
Dependent Form Fields
After selecting the first field, automatically reload the options for a second field.
data:image/s3,"s3://crabby-images/73c66/73c6674d88f7c8127a1800417d2fc19f9727b15a" alt="Up & Down Voting demo preview"
Up & Down Voting
Save up & down votes live in pure Twig & PHP.
data:image/s3,"s3://crabby-images/4dbf0/4dbf00848f45d50b868d7697d76e66dde54ffbdc" alt="Inline Editing demo preview"
Inline Editing
Activate an inline editing form with real-time validation.
data:image/s3,"s3://crabby-images/7387b/7387b5e2cf892687c47619b79d9ecfff1a19b62e" alt="Auto-Updating Chart demo preview"
Auto-Updating Chart
Render & Update a Chart.js chart in real-time.
data:image/s3,"s3://crabby-images/9a657/9a6570d30761ca8fe461ec124395fbc094dc01a9" alt="Invoice Creator demo preview"
Invoice Creator
Create an invoice + line items that updates as you type.
data:image/s3,"s3://crabby-images/375f3/375f3c652198ca7ef80813c20e53e9ba7b9d64ff" alt="Product Form + Category Modal demo preview"
Product Form + Category Modal
Create a Category on the fly - from inside a product form - via a modal.
data:image/s3,"s3://crabby-images/1d4fb/1d4fb85c0fd86df34d7811d4976d458c6f75d951" alt="Uploading files demo preview"
Uploading files
Upload file from your live component through a LiveAction.