ModelAutocompleteType.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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. */
  11. namespace Sonata\AdminBundle\Form\Type;
  12. use Symfony\Component\Form\FormBuilderInterface;
  13. use Symfony\Component\Form\AbstractType;
  14. use Symfony\Component\OptionsResolver\OptionsResolverInterface;
  15. use Symfony\Component\Form\FormView;
  16. use Symfony\Component\Form\FormInterface;
  17. use Sonata\AdminBundle\Form\DataTransformer\ModelToIdPropertyTransformer;
  18. use Symfony\Component\OptionsResolver\Options;
  19. use Symfony\Component\Form\Extension\Core\EventListener\ResizeFormListener;
  20. /**
  21. * This type defines a standard text field with autocomplete feature.
  22. *
  23. * @author Andrej Hudec <pulzarraider@gmail.com>
  24. * @author Florent Denis <dflorent.pokap@gmail.com>
  25. */
  26. class ModelAutocompleteType extends AbstractType
  27. {
  28. /**
  29. * {@inheritDoc}
  30. */
  31. public function buildForm(FormBuilderInterface $builder, array $options)
  32. {
  33. $builder->addViewTransformer(new ModelToIdPropertyTransformer($options['model_manager'], $options['class'], $options['property'], $options['multiple'], $options['to_string_callback']), true);
  34. $builder->setAttribute('property', $options['property']);
  35. $builder->setAttribute('callback', $options['callback']);
  36. $builder->setAttribute('minimum_input_length', $options['minimum_input_length']);
  37. $builder->setAttribute('items_per_page', $options['items_per_page']);
  38. $builder->setAttribute('req_param_name_page_number', $options['req_param_name_page_number']);
  39. $builder->setAttribute('disabled', $options['disabled'] || $options['read_only']);
  40. $builder->setAttribute('to_string_callback', $options['to_string_callback']);
  41. if ($options['multiple']) {
  42. $resizeListener = new ResizeFormListener(
  43. 'hidden', array(), true, true, true
  44. );
  45. $builder->addEventSubscriber($resizeListener);
  46. }
  47. }
  48. /**
  49. * {@inheritdoc}
  50. */
  51. public function buildView(FormView $view, FormInterface $form, array $options)
  52. {
  53. $view->vars['admin_code'] = $options['admin_code'];
  54. $view->vars['placeholder'] = $options['placeholder'];
  55. $view->vars['multiple'] = $options['multiple'];
  56. $view->vars['minimum_input_length'] = $options['minimum_input_length'];
  57. $view->vars['items_per_page'] = $options['items_per_page'];
  58. $view->vars['width'] = $options['width'];
  59. // ajax parameters
  60. $view->vars['url'] = $options['url'];
  61. $view->vars['route'] = $options['route'];
  62. $view->vars['req_params'] = $options['req_params'];
  63. $view->vars['req_param_name_search'] = $options['req_param_name_search'];
  64. $view->vars['req_param_name_page_number'] = $options['req_param_name_page_number'];
  65. $view->vars['req_param_name_items_per_page'] = $options['req_param_name_items_per_page'];
  66. // CSS classes
  67. $view->vars['container_css_class'] = $options['container_css_class'];
  68. $view->vars['dropdown_css_class'] = $options['dropdown_css_class'];
  69. $view->vars['dropdown_item_css_class'] = $options['dropdown_item_css_class'];
  70. $view->vars['dropdown_auto_width'] = $options['dropdown_auto_width'];
  71. // template
  72. $view->vars['template'] = $options['template'];
  73. $view->vars['context'] = $options['context'];
  74. }
  75. /**
  76. * {@inheritDoc}
  77. */
  78. public function setDefaultOptions(OptionsResolverInterface $resolver)
  79. {
  80. $compound = function (Options $options) {
  81. return $options['multiple'];
  82. };
  83. $resolver->setDefaults(array(
  84. 'attr' => array(),
  85. 'compound' => $compound,
  86. 'model_manager' => null,
  87. 'class' => null,
  88. 'admin_code' => null,
  89. 'callback' => null,
  90. 'multiple' => false,
  91. 'width' => '',
  92. 'context' => '',
  93. 'placeholder' => '',
  94. 'minimum_input_length' => 3, //minimum 3 chars should be typed to load ajax data
  95. 'items_per_page' => 10, //number of items per page
  96. 'to_string_callback' => null,
  97. // ajax parameters
  98. 'url' => '',
  99. 'route' => array('name'=>'sonata_admin_retrieve_autocomplete_items', 'parameters'=>array()),
  100. 'req_params' => array(),
  101. 'req_param_name_search' => 'q',
  102. 'req_param_name_page_number' => '_page',
  103. 'req_param_name_items_per_page' => '_per_page',
  104. // CSS classes
  105. 'container_css_class' => '',
  106. 'dropdown_css_class' => '',
  107. 'dropdown_item_css_class' => '',
  108. 'dropdown_auto_width' => false,
  109. 'template' => 'SonataAdminBundle:Form/Type:sonata_type_model_autocomplete.html.twig'
  110. ));
  111. $resolver->setRequired(array('property'));
  112. }
  113. /**
  114. * {@inheritDoc}
  115. */
  116. public function getParent()
  117. {
  118. return 'form';
  119. }
  120. /**
  121. * {@inheritDoc}
  122. */
  123. public function getName()
  124. {
  125. return 'sonata_type_model_autocomplete';
  126. }
  127. }