ekyna/table-bundle
最新稳定版本:v0.1
Composer 安装命令:
composer require ekyna/table-bundle
包简介
Table component integration
关键字:
README 文档
README
Table component integration.
Instation
- Through Composer
composer require ekyna/table-bundle:0.1.*@dev
- Register the bundle in your AppKernel
// app/AppKernel.php public function registerBundles() { $bundles = array( // other bundles ... new Ekyna\Bundle\TableBundle\EkynaTableBundle(), ); return $bundles; }
Usage
- Create the table type
// 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'; } }
- (optional) Register the table type as a service
<!-- 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>
- Create the controller
// 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(), )); } }
- Create the twig template
# 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>
Customization
The default template used to render the table is vendor/ekyna/table-bundle/Ekyna/Bundle/TableBundle/Resources/views/ekyna_table.html.twig.
It requires jQuery and Bootstrap 3.
You can create your own rendering template (where you will define all blocks of the default template) and use it this way
{{ ekyna_table_render(brands, {'template': 'AcmeDemoBundle:Table:render.html.twig'}) }}
TODO
- Tests
- Type inheritance
- AJAX
- Adapters (ORM, ODM, PHPCR)
- Render engines
- More documentation (columns, filter, internals, ...)
统计信息
- 总下载量: 1.41k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2014-03-25