ekyna / table-bundle
表格组件集成
v0.1
2015-04-22 06:07 UTC
Requires
- php: >=5.3.3
- ekyna/table: 0.1.*@dev
- symfony/framework-bundle: ~2.3
README
表格组件集成。
安装
- 通过 Composer
composer require ekyna/table-bundle:0.1.*@dev
- 在 AppKernel 中注册该包
// app/AppKernel.php public function registerBundles() { $bundles = array( // other bundles ... new Ekyna\Bundle\TableBundle\EkynaTableBundle(), ); return $bundles; }
使用方法
- 创建表格类型
// src/Acme/DemoBundle/Table/Type/BrandType.php namespace Acme\DemoBundle\Table\Type; use Ekyna\Component\Table\AbstractTableType; use Ekyna\Component\Table\TableBuilderInterface; use Symfony\Component\OptionsResolver\OptionsResolverInterface; class BrandType extends AbstractTableType { public function buildTable(TableBuilderInterface $tableBuilder) { $tableBuilder ->addColumn('id', 'number', array( 'sortable' => true, )) ->addColumn('title', 'text', array( 'label' => 'Title', 'sortable' => true, )) ->addFilter('id', 'number') ->addFilter('title', 'text', array( 'label' => 'Title' )) ; } public function setDefaultOptions(OptionsResolverInterface $resolver) { parent::setDefaultOptions($resolver); $resolver->setDefaults(array( 'data_class' => 'Acme\DemoBundle\Entity\Brand', )); } public function getName() { return 'acme_demo_brand'; } }
- (可选) 将表格类型注册为一个服务
<!-- src/Acme/DemoBundle/Resources/config/services.xml --> <service id="acme_demo.table_type.brand" class="Acme\DemoBundle\Table\Type\BrandType"> <tag name="table.type" alias="acme_demo_brand" /> </service>
- 创建控制器
// src/Acme/DemoBundle/Controller/BrandController.php namespace Acme\Demo\Controller; use Symfony\Bundle\FrameworkBundle\Controller\Controller; use Symfony\Component\HttpFoundation\Request; // use Acme\DemoBundle\Table\Type\BrandType; class ResourceController extends Controller { public function indexAction(Request $request) { $table = $this->get('table.factory') /*->createBuilder(new BrandType(), array( // instance 'name' => 'my_brand_list, ))*/ ->createBuilder('acme_demo_brand', array( // service 'name' => 'my_brand_list', )) ->getTable($request) ; return $this->render('AcmeDemoBundle:Brand:index.html.twig', array( 'brands' => $table->createView(), )); } }
- 创建 twig 模板
# src/Acme/DemoBundle/Resources/views/Brand/index.html.twig <!DOCTYPE html> <html> <head> {% stylesheets output='css/main.css' 'css/bootstrap.css' '@EkynaTableBundle/Resources/asset/css/table.css' -%} <link href="{{ asset_url }}" rel="stylesheet" type="text/css" /> {% endstylesheets %} </head> <body> {{ ekyna_table_render(brands) }} {% javascripts output='js/main.js' 'js/jquery.js' 'js/bootstrap.js' '@EkynaTableBundle/Resources/asset/js/table.js' -%} <script type="text/javascript" src="{{ asset_url }}"></script> {%- endjavascripts %} </body> </html>
自定义
默认用于渲染表格的模板是 vendor/ekyna/table-bundle/Ekyna/Bundle/TableBundle/Resources/views/ekyna_table.html.twig
。它需要 jQuery 和 Bootstrap 3。
您可以创建自己的渲染模板(在其中定义默认模板的所有块)并按此方式使用它
{{ ekyna_table_render(brands, {'template': 'AcmeDemoBundle:Table:render.html.twig'}) }}
待办事项
- 测试
- 类型继承
- AJAX
- 适配器(ORM,ODM,PHPCR)
- 渲染引擎
- 更多文档(列,过滤器,内部结构,...)