DatagridBuilderInterface.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <?php
  2. /*
  3. * This file is part of the Sonata package.
  4. *
  5. * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Sonata\AdminBundle\Builder;
  11. use Sonata\AdminBundle\Admin\FieldDescriptionInterface;
  12. use Sonata\AdminBundle\Model\ModelManagerInterface;
  13. use Sonata\AdminBundle\Admin\AdminInterface;
  14. use Sonata\AdminBundle\Datagrid\DatagridInterface;
  15. interface DatagridBuilderInterface
  16. {
  17. /**
  18. *
  19. * @param \Sonata\AdminBundle\Admin\AdminInterface $admin
  20. * @param \Sonata\AdminBundle\Admin\FieldDescriptionInterface $fieldDescription
  21. *
  22. * @return void
  23. */
  24. function fixFieldDescription(AdminInterface $admin, FieldDescriptionInterface $fieldDescription);
  25. /**
  26. * @abstract
  27. *
  28. * @param \Sonata\AdminBundle\Datagrid\DatagridInterface $datagrid
  29. * @param string $type
  30. * @param \Sonata\AdminBundle\Admin\FieldDescriptionInterface $fieldDescription
  31. * @param \Sonata\AdminBundle\Admin\AdminInterface $admin
  32. *
  33. * @return void
  34. */
  35. function addFilter(DatagridInterface $datagrid, $type = null, FieldDescriptionInterface $fieldDescription, AdminInterface $admin);
  36. /**
  37. * @param \Sonata\AdminBundle\Admin\AdminInterface $admin
  38. * @param array $values
  39. *
  40. * @return \Sonata\AdminBundle\Datagrid\DatagridInterface
  41. */
  42. function getBaseDatagrid(AdminInterface $admin, array $values = array());
  43. }