PHPackages                             jgm/tablebundle - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Search &amp; Filtering](/categories/search)
4. /
5. jgm/tablebundle

AbandonedArchivedSymfony-bundle[Search &amp; Filtering](/categories/search)

jgm/tablebundle
===============

Bundle for creating data tables for symfony application.

v1.3.3(9y ago)83.5k7[6 issues](https://github.com/jangemue/TableBundle/issues)[1 PRs](https://github.com/jangemue/TableBundle/pulls)MITPHPPHP &gt;=5.3.9

Since Aug 29Pushed 9y ago1 watchersCompare

[ Source](https://github.com/jangemue/TableBundle)[ Packagist](https://packagist.org/packages/jgm/tablebundle)[ RSS](/packages/jgm-tablebundle/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (10)Dependencies (9)Versions (18)Used By (0)

TableBundle
===========

[](#tablebundle)

The [JGM TableBundle](http://tablebundle.org) is a bundle for the Symfony Framework (Symfony2 or higher), which is used to build data tables in PHP and render them easily with twig.

Why should I use this Bundle?
-----------------------------

[](#why-should-i-use-this-bundle)

Creating tables for data is a boring and cumbersome work. You have to care about rendering, paginating, order and filter the given data. Sometimes, you want to reuse your tables, too.

Using the TableBundle will be the answer to your problems. It provides building tables including dynamic columns for displaying data from different sources (like entities from database or arrays). Additional the TableBundle supports mechanisms for dynamic filters, pagination and order. You don't have to care about the implementation, it's all automatic.

A unique feature is the automatic join, which allows you to access and also filter for joined columns of the given data (and their joined columns, and their...).

Installation
------------

[](#installation)

### Using composer

[](#using-composer)

1. Add the bundle to your `composer.json` by executing the command `composer require jgm/tablebundle` or adding the line `"jgm/tablebundle": "1.3.*"` to the `required`-section.
2. Add the Bundle to your Kernel (`app/AppKernel.php`):

```
// app/AppKernel.php
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...,
            new JGM\TableBundle\JGMTableBundle()
        );
        // ...
    }
    // ...
}

```

### Dependencies

[](#dependencies)

- php: &gt;=5.3.9
- symfony/symfony: &gt;=2.5
- symfony/config: &gt;=2.5
- symfony/yaml: &gt;=2.5
- symfony/security: &gt;=2.5
- symfony/templating: &gt;=2.5
- symfony/http-foundation: &gt;=2.5
- symfony/http-kernel: &gt;=2.5
- symfony/dependency-injection: &gt;=2.5
- doctrine/common: &gt;=2.3

Basic usage
-----------

[](#basic-usage)

### Step 1: Create a table type

[](#step-1-create-a-table-type)

```
// src/YourBundle/Table/Type/StudentTableType.php
class StudentTableType extends JGM\TableBundle\Table\Type\AbstractTableType
{
    public function buildTable(TableBuilder $builder)
    {
		$builder
			->add('text', 'name', ['label' => 'Name'])
			->add('number', 'term', ['label' => 'Term'])
			->add('date', 'birthday', ['label' => 'Day of birth']);
    }

    public function getDataSource(ContainerInterface $container)
    {
      return new EntityDataSource('YourBundle:Student');
    }

    public function getName()
    {
        return 'student_table';
    }

    public function configureOptions(OptionsResolver $resolver)
    {
		$optionsResolver->setDefaults(array(
			'attr' => array('width' => '600px', 'class' => 'table-css'),
			'empty_value' => 'There is no student...'
		));
    }
}

```

### Step 2: Instantiate the table

[](#step-2-instantiate-the-table)

```
// src/YourBundle/Controller/StudentController.php
