123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Form;
- use Symfony\Component\EventDispatcher\EventSubscriberInterface;
- use Symfony\Component\PropertyAccess\PropertyPathInterface;
- /**
- * @author Bernhard Schussek <bschussek@gmail.com>
- *
- * @method $this setIsEmptyCallback(callable|null $isEmptyCallback) Sets the callback that will be called to determine if the model data of the form is empty or not - not implementing it is deprecated since Symfony 5.1
- */
- interface FormConfigBuilderInterface extends FormConfigInterface
- {
- /**
- * Adds an event listener to an event on this form.
- *
- * @param int $priority The priority of the listener. Listeners
- * with a higher priority are called before
- * listeners with a lower priority.
- *
- * @return $this The configuration object
- */
- public function addEventListener(string $eventName, callable $listener, int $priority = 0);
- /**
- * Adds an event subscriber for events on this form.
- *
- * @return $this The configuration object
- */
- public function addEventSubscriber(EventSubscriberInterface $subscriber);
- /**
- * Appends / prepends a transformer to the view transformer chain.
- *
- * The transform method of the transformer is used to convert data from the
- * normalized to the view format.
- * The reverseTransform method of the transformer is used to convert from the
- * view to the normalized format.
- *
- * @param bool $forcePrepend If set to true, prepend instead of appending
- *
- * @return $this The configuration object
- */
- public function addViewTransformer(DataTransformerInterface $viewTransformer, bool $forcePrepend = false);
- /**
- * Clears the view transformers.
- *
- * @return $this The configuration object
- */
- public function resetViewTransformers();
- /**
- * Prepends / appends a transformer to the normalization transformer chain.
- *
- * The transform method of the transformer is used to convert data from the
- * model to the normalized format.
- * The reverseTransform method of the transformer is used to convert from the
- * normalized to the model format.
- *
- * @param bool $forceAppend If set to true, append instead of prepending
- *
- * @return $this The configuration object
- */
- public function addModelTransformer(DataTransformerInterface $modelTransformer, bool $forceAppend = false);
- /**
- * Clears the normalization transformers.
- *
- * @return $this The configuration object
- */
- public function resetModelTransformers();
- /**
- * Sets the value for an attribute.
- *
- * @param mixed $value The value of the attribute
- *
- * @return $this The configuration object
- */
- public function setAttribute(string $name, $value);
- /**
- * Sets the attributes.
- *
- * @return $this The configuration object
- */
- public function setAttributes(array $attributes);
- /**
- * Sets the data mapper used by the form.
- *
- * @return $this The configuration object
- */
- public function setDataMapper(DataMapperInterface $dataMapper = null);
- /**
- * Sets whether the form is disabled.
- *
- * @return $this The configuration object
- */
- public function setDisabled(bool $disabled);
- /**
- * Sets the data used for the client data when no value is submitted.
- *
- * @param mixed $emptyData The empty data
- *
- * @return $this The configuration object
- */
- public function setEmptyData($emptyData);
- /**
- * Sets whether errors bubble up to the parent.
- *
- * @return $this The configuration object
- */
- public function setErrorBubbling(bool $errorBubbling);
- /**
- * Sets whether this field is required to be filled out when submitted.
- *
- * @return $this The configuration object
- */
- public function setRequired(bool $required);
- /**
- * Sets the property path that the form should be mapped to.
- *
- * @param string|PropertyPathInterface|null $propertyPath The property path or null if the path should be set
- * automatically based on the form's name
- *
- * @return $this The configuration object
- */
- public function setPropertyPath($propertyPath);
- /**
- * Sets whether the form should be mapped to an element of its
- * parent's data.
- *
- * @return $this The configuration object
- */
- public function setMapped(bool $mapped);
- /**
- * Sets whether the form's data should be modified by reference.
- *
- * @return $this The configuration object
- */
- public function setByReference(bool $byReference);
- /**
- * Sets whether the form should read and write the data of its parent.
- *
- * @return $this The configuration object
- */
- public function setInheritData(bool $inheritData);
- /**
- * Sets whether the form should be compound.
- *
- * @return $this The configuration object
- *
- * @see FormConfigInterface::getCompound()
- */
- public function setCompound(bool $compound);
- /**
- * Sets the resolved type.
- *
- * @return $this The configuration object
- */
- public function setType(ResolvedFormTypeInterface $type);
- /**
- * Sets the initial data of the form.
- *
- * @param mixed $data The data of the form in model format
- *
- * @return $this The configuration object
- */
- public function setData($data);
- /**
- * Locks the form's data to the data passed in the configuration.
- *
- * A form with locked data is restricted to the data passed in
- * this configuration. The data can only be modified then by
- * submitting the form or using PRE_SET_DATA event.
- *
- * It means data passed to a factory method or mapped from the
- * parent will be ignored.
- *
- * @return $this The configuration object
- */
- public function setDataLocked(bool $locked);
- /**
- * Sets the form factory used for creating new forms.
- */
- public function setFormFactory(FormFactoryInterface $formFactory);
- /**
- * Sets the target URL of the form.
- *
- * @return $this The configuration object
- */
- public function setAction(string $action);
- /**
- * Sets the HTTP method used by the form.
- *
- * @return $this The configuration object
- */
- public function setMethod(string $method);
- /**
- * Sets the request handler used by the form.
- *
- * @return $this The configuration object
- */
- public function setRequestHandler(RequestHandlerInterface $requestHandler);
- /**
- * Sets whether the form should be initialized automatically.
- *
- * Should be set to true only for root forms.
- *
- * @param bool $initialize True to initialize the form automatically,
- * false to suppress automatic initialization.
- * In the second case, you need to call
- * {@link FormInterface::initialize()} manually.
- *
- * @return $this The configuration object
- */
- public function setAutoInitialize(bool $initialize);
- /**
- * Builds and returns the form configuration.
- *
- * @return FormConfigInterface
- */
- public function getFormConfig();
- }
|