ModelAutocompleteType.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <?php
  2. /*
  3. * This file is part of the Sonata Project 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\Form\Type;
  11. use Sonata\AdminBundle\Form\DataTransformer\ModelToIdPropertyTransformer;
  12. use Symfony\Component\Form\AbstractType;
  13. use Symfony\Component\Form\Extension\Core\EventListener\ResizeFormListener;
  14. use Symfony\Component\Form\FormBuilderInterface;
  15. use Symfony\Component\Form\FormInterface;
  16. use Symfony\Component\Form\FormView;
  17. use Symfony\Component\OptionsResolver\Options;
  18. use Symfony\Component\OptionsResolver\OptionsResolver;
  19. use Symfony\Component\OptionsResolver\OptionsResolverInterface;
  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. $view->vars['read_only'] = $options['read_only'];
  60. // ajax parameters
  61. $view->vars['url'] = $options['url'];
  62. $view->vars['route'] = $options['route'];
  63. $view->vars['req_params'] = $options['req_params'];
  64. $view->vars['req_param_name_search'] = $options['req_param_name_search'];
  65. $view->vars['req_param_name_page_number'] = $options['req_param_name_page_number'];
  66. $view->vars['req_param_name_items_per_page'] = $options['req_param_name_items_per_page'];
  67. $view->vars['quiet_millis'] = $options['quiet_millis'];
  68. $view->vars['cache'] = $options['cache'];
  69. // CSS classes
  70. $view->vars['container_css_class'] = $options['container_css_class'];
  71. $view->vars['dropdown_css_class'] = $options['dropdown_css_class'];
  72. $view->vars['dropdown_item_css_class'] = $options['dropdown_item_css_class'];
  73. $view->vars['dropdown_auto_width'] = $options['dropdown_auto_width'];
  74. // template
  75. $view->vars['template'] = $options['template'];
  76. $view->vars['context'] = $options['context'];
  77. }
  78. /**
  79. * {@inheritdoc}
  80. *
  81. * @todo Remove it when bumping requirements to SF 2.7+
  82. */
  83. public function setDefaultOptions(OptionsResolverInterface $resolver)
  84. {
  85. $this->configureOptions($resolver);
  86. }
  87. /**
  88. * {@inheritdoc}
  89. */
  90. public function configureOptions(OptionsResolver $resolver)
  91. {
  92. $compound = function (Options $options) {
  93. return $options['multiple'];
  94. };
  95. $resolver->setDefaults(array(
  96. 'attr' => array(),
  97. 'compound' => $compound,
  98. 'model_manager' => null,
  99. 'class' => null,
  100. 'admin_code' => null,
  101. 'callback' => null,
  102. 'multiple' => false,
  103. 'width' => '',
  104. 'context' => '',
  105. 'read_only' => false,
  106. 'placeholder' => '',
  107. 'minimum_input_length' => 3, //minimum 3 chars should be typed to load ajax data
  108. 'items_per_page' => 10, //number of items per page
  109. 'quiet_millis' => 100,
  110. 'cache' => false,
  111. 'to_string_callback' => null,
  112. // ajax parameters
  113. 'url' => '',
  114. 'route' => array('name' => 'sonata_admin_retrieve_autocomplete_items', 'parameters' => array()),
  115. 'req_params' => array(),
  116. 'req_param_name_search' => 'q',
  117. 'req_param_name_page_number' => '_page',
  118. 'req_param_name_items_per_page' => '_per_page',
  119. // CSS classes
  120. 'container_css_class' => '',
  121. 'dropdown_css_class' => '',
  122. 'dropdown_item_css_class' => '',
  123. 'dropdown_auto_width' => false,
  124. 'template' => 'SonataAdminBundle:Form/Type:sonata_type_model_autocomplete.html.twig',
  125. ));
  126. $resolver->setRequired(array('property'));
  127. }
  128. /**
  129. * {@inheritdoc}
  130. */
  131. public function getParent()
  132. {
  133. return 'form';
  134. }
  135. /**
  136. * {@inheritdoc}
  137. */
  138. public function getBlockPrefix()
  139. {
  140. return 'sonata_type_model_autocomplete';
  141. }
  142. /**
  143. * {@inheritdoc}
  144. */
  145. public function getName()
  146. {
  147. return $this->getBlockPrefix();
  148. }
  149. }