ModelAutocompleteType.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  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. // 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. $view->vars['quiet_millis'] = $options['quiet_millis'];
  67. // CSS classes
  68. $view->vars['container_css_class'] = $options['container_css_class'];
  69. $view->vars['dropdown_css_class'] = $options['dropdown_css_class'];
  70. $view->vars['dropdown_item_css_class'] = $options['dropdown_item_css_class'];
  71. $view->vars['dropdown_auto_width'] = $options['dropdown_auto_width'];
  72. // template
  73. $view->vars['template'] = $options['template'];
  74. $view->vars['context'] = $options['context'];
  75. }
  76. /**
  77. * {@inheritdoc}
  78. *
  79. * @todo Remove it when bumping requirements to SF 2.7+
  80. */
  81. public function setDefaultOptions(OptionsResolverInterface $resolver)
  82. {
  83. $this->configureOptions($resolver);
  84. }
  85. /**
  86. * {@inheritdoc}
  87. */
  88. public function configureOptions(OptionsResolver $resolver)
  89. {
  90. $compound = function (Options $options) {
  91. return $options['multiple'];
  92. };
  93. $resolver->setDefaults(array(
  94. 'attr' => array(),
  95. 'compound' => $compound,
  96. 'model_manager' => null,
  97. 'class' => null,
  98. 'admin_code' => null,
  99. 'callback' => null,
  100. 'multiple' => false,
  101. 'width' => '',
  102. 'context' => '',
  103. 'placeholder' => '',
  104. 'minimum_input_length' => 3, //minimum 3 chars should be typed to load ajax data
  105. 'items_per_page' => 10, //number of items per page
  106. 'quiet_millis' => 100,
  107. 'to_string_callback' => null,
  108. // ajax parameters
  109. 'url' => '',
  110. 'route' => array('name' => 'sonata_admin_retrieve_autocomplete_items', 'parameters' => array()),
  111. 'req_params' => array(),
  112. 'req_param_name_search' => 'q',
  113. 'req_param_name_page_number' => '_page',
  114. 'req_param_name_items_per_page' => '_per_page',
  115. // CSS classes
  116. 'container_css_class' => '',
  117. 'dropdown_css_class' => '',
  118. 'dropdown_item_css_class' => '',
  119. 'dropdown_auto_width' => false,
  120. 'template' => 'SonataAdminBundle:Form/Type:sonata_type_model_autocomplete.html.twig',
  121. ));
  122. $resolver->setRequired(array('property'));
  123. }
  124. /**
  125. * {@inheritdoc}
  126. */
  127. public function getParent()
  128. {
  129. return 'form';
  130. }
  131. /**
  132. * {@inheritdoc}
  133. */
  134. public function getName()
  135. {
  136. return 'sonata_type_model_autocomplete';
  137. }
  138. }