Provider to use Pagerfanta with Silex, (*1)
This Provider is based on WhiteOctoberPagerfantaBundle and includes:
* Twig function to render pagerfantas with views and options.
* Way to use easily views., (*2)
Install
You have to add to your composer.json file:, (*3)
"franmomu/silex-pagerfanta-provider": "1.0.*@dev"
or if you use Symfony2.2 components:, (*4)
"franmomu/silex-pagerfanta-provider": "dev-master"
Registering
$app->register(new FranMoreno\Silex\Provider\PagerfantaServiceProvider());
Parameters
This are the default parameters:, (*5)
$app['pagerfanta.view.options'] = array(
'routeName' => null,
'routeParams' => array(),
'pageParameter' => '[page]',
'proximity' => 3,
'next_message' => '»',
'previous_message' => '«',
'default_view' => 'default'
);
The Twig Extension provides this function:, (*6)
{{ pagerfanta(my_pager, view_name, view_options) }}
The routes are generated automatically for the current route using the variable
"page" to propagate the page number. By default, the bundle uses the
DefaultView with the default name., (*7)
{{ pagerfanta(my_pager) }}
If you want to use a custom template, add another argument, (*8)
<div class="pagerfanta">
{{ pagerfanta(my_pager, 'my_template') }}
</div>
With Options, (*9)
{{ pagerfanta(my_pager, 'default', { 'proximity': 2}) }}
See the Pagerfanta documentation for the list of the parameters., (*10)
Adding a custom template
You can use the CSS classes provided with DefaultView, but if you want to create a Custom View, you have to implement Pagerfanta\View\ViewInterface
, then add the View to the Factory:, (*11)
$app['pagerfanta.view_factory'] = $app->share($app->extend('pagerfanta.view_factory', function($viewFactory, $app) {
$customView = new \Foo\Bar\View\CustomView();
$viewFactory->add(array(
'my_view' => $customView
));
return $viewFactory;
}));
And if you want set as default view:, (*12)
$app['pagerfanta.view.options'] = array(
'default_view' => 'my_view'
);
Use in controllers
use Pagerfanta\Pagerfanta;
use Pagerfanta\Adapter\ArrayAdapter;
$app->get('/index', function (Request $request) use ($app) {
$results = $app['some.service']->getResults();
$adapter = new ArrayAdapter($results);
$pagerfanta = new Pagerfanta($adapter);
$pagerfanta->setMaxPerPage(10);
$pagerfanta->setCurrentPage($request->query->get('page', 1));
return $app['twig']->render('index.html', array(
'my_pager' => $pagerfanta
));
})