sidus/eav-filter-bundle
最新稳定版本:v3.0.0
Composer 安装命令:
composer require sidus/eav-filter-bundle
包简介
Extension for sidus/eav-model-bundle and sidus/filter-bundle to handle the EAV model
README 文档
README
This bundle works on top of the Sidus/FilterBundle and enables the compatibility for the Sidus/EAVModelBundle.
Installation
Bundle setup
Require this bundle with composer:
$ composer require sidus/eav-filter-bundle "^1.3.5"
Add the bundle to AppKernel.php
<?php /** * app/AppKernel.php */ class AppKernel { public function registerBundles() { $bundles = [ // ... // If not already enabled: new Sidus\EAVModelBundle\SidusEAVModelBundle(), new Sidus\FilterBundle\SidusFilterBundle(), // This bundle: new Sidus\EAVFilterBundle\SidusEAVFilterBundle(), // ... ]; } }
Configuration
Check the Sidus/FilterBundle for the base configuration documentation.
Simply setup your filter configuration with the sidus.eav provider and setup the family option like
this:
sidus_filter: configurations: my_configuration: provider: sidus.eav # Tells the system to use the EAV filter engine options: family: News # Required to select the proper data source sortable: - id - label - publicationDate - publicationStatus - updatedAt default_sort: publicationDate: DESC filters: label: ~ publicationDate: type: date_range publicationStatus: type: choice category: type: autocomplete_data # Will display an autocomplete to the related EAV family
Specific features
The choice filter type will automatically load the choices from your attribute configuration.
The autocomplete_data filter type doesn't supports attributes related to multiple families for the moment.
This bundle provides a specific adapter for PagerFanta, the EAVAdapter that supports the OptimizedDataLoader from the EAVModelBundle. Check this documentation for more information: EAV Query Optimization
The depth of the loader is configurable through the loader_depth option:
Configuration quick reference
sidus_filter: configurations: <configuration_code>: provider: sidus.eav # Required options: family: <FamilyCode> # Required # Optional options loader_depth: <int> # Default 2 query_context: <array> # If you want to inject a custom context (or part of it) statically for the query use_global_context: <bool> # Merge the query_context with the global context for the query # (the results always use the global context by default) result_context: <array> # Same as before but for the results (will inject this in Data::setCurrentContext)
统计信息
- 总下载量: 20.62k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2016-01-21