Adds History API support to nette.ajax.js addon for Nette Framework!
- Link
client-side/history.ajax.js
afternette.ajax.js
. - Load PHP files with Composer:
vojtech-dobes/nette-ajax-history
- Register config extension in your configuration:
extensions:
ajaxHistory: VojtechDobes\NetteAjax\HistoryExtension
Write your application as normal. All redirects and forwards will be properly handled.
To correctly update UI, use snippets. If you plan to ajaxify whole application, consider adding this snippet to your beforeRender()
method in BasePresenter
.
if ($this->isAjax()) {
$this->invalidateControl('title');
$this->invalidateControl('content');
}
And app/@layout.latte
might be upgraded accordingly:
<title n:inner-snippet="title">...
{snippet content}
{include content}
{/snippet}
If you want specific links or forms exclude from scope of this addon (not make them update the URL), you can use data-ajax-off
feature of nette.ajax.js.
<a class="ajax" data-ajax-off="history">
Extension will automatically cache your UI and restore it on Back and Forward buttons without communication with server. If you wish to call server on every Back and Forward, turn caching off.
$.nette.ext('history').cache = false;