Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Page size selectable by user #135

Merged
merged 1 commit into from
Oct 5, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
65 changes: 65 additions & 0 deletions docs/src/docs/features/pagination.md
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,71 @@ class ProductDataTableType extends AbstractDataTableType
}
```

## Configuring items per page

The per-page limit choices can be configured using the `per_page_choices` option.
Those choices will be rendered inside a select field, next to the pagination controls.

::: code-group
```yaml [Globally (YAML)]
kreyu_data_table:
defaults:
pagination:
per_page_choices: [10, 25, 50, 100]
```

```php [Globally (PHP)]
use Symfony\Config\KreyuDataTableConfig;

return static function (KreyuDataTableConfig $config) {
$defaults = $config->defaults();
$defaults->pagination()
->perPageChoices([10, 25, 50, 100)
;
};
```

```php [For data table type]
use Kreyu\Bundle\DataTableBundle\Type\AbstractDataTableType;
use Symfony\Component\OptionsResolver\OptionsResolver;

class ProductDataTableType extends AbstractDataTableType
{
public function configureOptions(OptionsResolver $resolver): void
{
$resolver->setDefaults([
'per_page_choices' => [10, 25, 50, 100],
]);
}
}
```

```php [For specific data table]
use App\DataTable\Type\ProductDataTableType;
use Kreyu\Bundle\DataTableBundle\DataTableFactoryAwareTrait;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;

class ProductController extends AbstractController
{
use DataTableFactoryAwareTrait;

public function index()
{
$dataTable = $this->createDataTable(
type: ProductDataTableType::class,
query: $query,
options: [
'per_page_choices' => [10, 25, 50, 100],
],
);
}
}
```
:::

Setting the `per_page_choices` to an empty array will hide the per-page select field.


## Events

The following events are dispatched when `paginate()` method of the [`DataTableInterface`](https://github.com/Kreyu/data-table-bundle/blob/main/src/DataTableInterface.php) is called:
Expand Down
2 changes: 2 additions & 0 deletions docs/src/reference/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ kreyu_data_table:
persistence_adapter: kreyu_data_table.pagination.persistence.adapter.cache
# if persistence is enabled and symfony/security-bundle is installed, null otherwise
persistence_subject_provider: kreyu_data_table.persistence.subject_provider.token_storage
per_page_choices: [10, 25, 50, 100]
filtration:
enabled: true
persistence_enabled: false
Expand Down Expand Up @@ -92,6 +93,7 @@ return static function (KreyuDataTableConfig $config) {
->persistenceAdapter('kreyu_data_table.pagination.persistence.adapter.cache')
// if persistence is enabled and symfony/security-bundle is installed, null otherwise
->persistenceSubjectProvider('kreyu_data_table.persistence.subject_provider.token_storage')
->perPageChoices([10, 25, 50, 100])
;

$defaults->filtration()
Expand Down
4 changes: 4 additions & 0 deletions src/DependencyInjection/Configuration.php
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,10 @@ public function getConfigTreeBuilder(): TreeBuilder
->scalarNode('persistence_subject_provider')
->defaultNull()
->end()
->arrayNode('per_page_choices')
->integerPrototype()->end()
->defaultValue([10, 25, 50, 100])
->end()
->end()
->end()
->arrayNode('filtration')
Expand Down
1 change: 1 addition & 0 deletions src/Resources/translations/KreyuDataTable.en.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ Hidden columns: Hidden columns

# Pagination
Showing %current_page_first_item_index% - %current_page_last_item_index% of %total_item_count%: Showing %current_page_first_item_index% - %current_page_last_item_index% of %total_item_count%
Items per page: Items per page

# Export
Export: Export
Expand Down
1 change: 1 addition & 0 deletions src/Resources/translations/KreyuDataTable.pl.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ Hidden columns: Ukryte kolumny

# Pagination
Showing %current_page_first_item_index% - %current_page_last_item_index% of %total_item_count%: Wyniki %current_page_first_item_index% - %current_page_last_item_index% z %total_item_count%
Items per page: Wyników na stronę

# Export
Export: Eksport
Expand Down
39 changes: 35 additions & 4 deletions src/Resources/views/themes/base.html.twig
Original file line number Diff line number Diff line change
Expand Up @@ -139,14 +139,17 @@
{# Pagination #}

{% block kreyu_data_table_pagination %}
{% if page_count > 1 %}
{{ block('pagination_widget', theme) }}
{% endif %}
{{ block('pagination_widget', theme) }}
{% endblock %}

{% block pagination_widget %}
{{ block('pagination_counters', theme) }}
{{ block('pagination_controls', theme) }}

{% if page_count > 1 %}
{{ block('pagination_controls', theme) }}
{% endif %}

{{ block('pagination_per_page', theme) }}
{% endblock %}

{% block pagination_controls %}
Expand Down Expand Up @@ -187,6 +190,34 @@
{%- endif -%}
{% endblock %}

{% block pagination_per_page %}
{% set choices = data_table.vars.per_page_choices %}

{% if choices is not empty %}
{{ block('pagination_per_page_message', theme) }}
{{ block('pagination_per_page_form', theme) }}
{% else %}
<div></div>
{% endif %}
{% endblock %}

{% block pagination_per_page_message 'Items per page'|trans %}

{% block pagination_per_page_form %}
<form>
{% set select_attr = {
name: data_table.vars.per_page_parameter_name,
onchange: 'this.form.submit()',
}|merge(select_attr|default({})) %}

<select {% with { attr: select_attr } %}{{ block('attributes') }}{% endwith %}>
{% for choice in choices %}
<option value="{{ choice }}"{{ item_number_per_page == choice ? ' selected' }}>{{ choice }}</option>
{% endfor %}
</select>
</form>
{% endblock %}

{% block pagination_counters %}
<span {{- block('attributes') -}}>
{{- block('pagination_counters_message', theme) -}}
Expand Down
23 changes: 19 additions & 4 deletions src/Resources/views/themes/bootstrap_5.html.twig
Original file line number Diff line number Diff line change
Expand Up @@ -439,19 +439,34 @@

{% block pagination_widget %}
<div class="card-footer">
<div class="pagination d-flex gap-3 flex-wrap justify-content-center align-items-center">
<div class="pagination d-flex flex-wrap justify-content-between align-items-center flex-lg-row flex-column gap-2">
{{ parent() }}
<div class="d-flex col"></div>
</div>
</div>
{% endblock %}

{% block pagination_counters %}
<div class="d-flex col">{{ parent() }}</div>
<div class="d-flex col justify-content-start">{{ parent() }}</div>
{% endblock %}

{% block pagination_controls %}
<div class="d-flex">{{ parent() }}</div>
<div class="d-flex col justify-content-center">{{ parent() }}</div>
{% endblock %}

{% block pagination_per_page %}
<div class="d-flex col justify-content-end">
{{ parent() }}
</div>
{% endblock %}

{% block pagination_per_page_message %}
<div class="me-2 d-flex align-items-center">{{ parent() }}</div>
{% endblock %}

{% block pagination_per_page_form %}
{% with { select_attr: { class: 'col form-select' } } %}
{{ parent() }}
{% endwith %}
{% endblock %}

{% block pagination_page %}
Expand Down
2 changes: 2 additions & 0 deletions src/Type/DataTableType.php
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@ public function buildView(DataTableView $view, DataTableInterface $dataTable, ar
'filtration_data' => $dataTable->getFiltrationData(),
'sorting_data' => $dataTable->getSortingData(),
'has_batch_actions' => !empty($dataTable->getBatchActions()),
'per_page_choices' => $options['per_page_choices'],
]);

$view->headerRow = $this->createHeaderRowView($view, $dataTable, $visibleColumns);
Expand Down Expand Up @@ -168,6 +169,7 @@ public function configureOptions(OptionsResolver $resolver): void
'pagination_persistence_enabled' => $this->defaults['pagination']['persistence_enabled'] ?? false,
'pagination_persistence_adapter' => $this->defaults['pagination']['persistence_adapter'] ?? null,
'pagination_persistence_subject_provider' => $this->defaults['pagination']['persistence_subject_provider'] ?? null,
'per_page_choices' => $this->defaults['pagination']['per_page_choices'] ?? [10, 25, 50, 100],
'filtration_enabled' => $this->defaults['filtration']['enabled'] ?? false,
'filtration_persistence_enabled' => $this->defaults['filtration']['persistence_enabled'] ?? false,
'filtration_persistence_adapter' => $this->defaults['filtration']['persistence_adapter'] ?? null,
Expand Down
Loading