ListBuilder.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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\FieldDescription;
  12. use Sonata\AdminBundle\Admin\Admin;
  13. use Sonata\AdminBundle\Datagrid\ListCollection;
  14. use Doctrine\ORM\Mapping\ClassMetadataInfo;
  15. class ListBuilder implements ListBuilderInterface
  16. {
  17. public function getBaseList(array $options = array())
  18. {
  19. return new ListCollection;
  20. }
  21. public function addField(ListCollection $list, FieldDescription $fieldDescription)
  22. {
  23. return $list->add($fieldDescription);
  24. }
  25. /**
  26. * The method define the correct default settings for the provided FieldDescription
  27. *
  28. * @param FieldDescription $fieldDescription
  29. * @return void
  30. */
  31. public function fixFieldDescription(Admin $admin, FieldDescription $fieldDescription, array $options = array())
  32. {
  33. $fieldDescription->mergeOptions($options);
  34. $fieldDescription->setAdmin($admin);
  35. // set the default field mapping
  36. if (isset($admin->getClassMetaData()->fieldMappings[$fieldDescription->getName()])) {
  37. $fieldDescription->setFieldMapping($admin->getClassMetaData()->fieldMappings[$fieldDescription->getName()]);
  38. }
  39. // set the default association mapping
  40. if (isset($admin->getClassMetaData()->associationMappings[$fieldDescription->getName()])) {
  41. $fieldDescription->setAssociationMapping($admin->getClassMetaData()->associationMappings[$fieldDescription->getName()]);
  42. }
  43. if (!$fieldDescription->getType()) {
  44. throw new \RuntimeException(sprintf('Please define a type for field `%s` in `%s`', $fieldDescription->getName(), get_class($admin)));
  45. }
  46. $fieldDescription->setOption('code', $fieldDescription->getOption('code', $fieldDescription->getName()));
  47. $fieldDescription->setOption('label', $fieldDescription->getOption('label', $fieldDescription->getName()));
  48. if (!$fieldDescription->getTemplate()) {
  49. $fieldDescription->setTemplate(sprintf('SonataAdminBundle:CRUD:list_%s.html.twig', $fieldDescription->getType()));
  50. if ($fieldDescription->getType() == ClassMetadataInfo::MANY_TO_ONE) {
  51. $fieldDescription->setTemplate('SonataAdminBundle:CRUD:list_many_to_one.html.twig');
  52. }
  53. if ($fieldDescription->getType() == ClassMetadataInfo::ONE_TO_ONE) {
  54. $fieldDescription->setTemplate('SonataAdminBundle:CRUD:list_one_to_one.html.twig');
  55. }
  56. if ($fieldDescription->getType() == ClassMetadataInfo::ONE_TO_MANY) {
  57. $fieldDescription->setTemplate('SonataAdminBundle:CRUD:list_one_to_many.html.twig');
  58. }
  59. if ($fieldDescription->getType() == ClassMetadataInfo::MANY_TO_MANY) {
  60. $fieldDescription->setTemplate('SonataAdminBundle:CRUD:list_many_to_many.html.twig');
  61. }
  62. }
  63. if ($fieldDescription->getType() == ClassMetadataInfo::MANY_TO_ONE) {
  64. $admin->attachAdminClass($fieldDescription);
  65. }
  66. if ($fieldDescription->getType() == ClassMetadataInfo::ONE_TO_ONE) {
  67. $admin->attachAdminClass($fieldDescription);
  68. }
  69. if ($fieldDescription->getType() == ClassMetadataInfo::ONE_TO_MANY) {
  70. $admin->attachAdminClass($fieldDescription);
  71. }
  72. if ($fieldDescription->getType() == ClassMetadataInfo::MANY_TO_MANY) {
  73. $admin->attachAdminClass($fieldDescription);
  74. }
  75. }
  76. }