Skip to content
This repository has been archived by the owner on Sep 30, 2021. It is now read-only.

Commit

Permalink
Deprecate the form mapping feature (#462)
Browse files Browse the repository at this point in the history
  • Loading branch information
greg0ire authored and OskarStark committed Nov 13, 2017
1 parent 2946a0b commit 7c72ed8
Show file tree
Hide file tree
Showing 9 changed files with 79 additions and 105 deletions.
12 changes: 12 additions & 0 deletions UPGRADE-3.x.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,18 @@
UPGRADE 3.x
===========

Using the form mapping feature is now deprecated. You should use FQCNs
everywhere form names are used, and disable this feature with the following
piece of configuration:

```yaml
# config.yml
sonata_core:
form:
mapping:
enabled: false
```
UPGRADE FROM 3.4 to 3.5
=======================
Expand Down
4 changes: 3 additions & 1 deletion docs/reference/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,11 @@ client only sent partial data to update an entity.
<?php
use Sonata\ClassificationBundle\Form\Type\ApiCategoryType;
$category = $id ? $this->getCategory($id) : null;
$form = $this->formFactory->createNamed(null, 'sonata_classification_api_form_category', $category, array(
$form = $this->formFactory->createNamed(null, ApiCategoryType::class, $category, array(
'csrf_protection' => false
));
Expand Down
143 changes: 42 additions & 101 deletions docs/reference/form_types.rst
Original file line number Diff line number Diff line change
Expand Up @@ -6,78 +6,6 @@ Form Types

The bundle comes with some handy form types.


Symfony3 Supports
-----------------

In order to help the migration path toward Symfony3, the bundle restores the Symfony2.X behavior of string code usage for the form type declaration.
Each bundles can register a mapping with Symfony3 boot.

.. code-block:: php
<?php
namespace Sonata\AdminBundle;
use Sonata\CoreBundle\Form\FormHelper;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\HttpKernel\Bundle\Bundle;
class SonataAdminBundle extends Bundle
{
/**
* {@inheritdoc}
*/
public function build(ContainerBuilder $container)
{
$this->registerFormMapping();
}
/**
* {@inheritdoc}
*/
public function boot()
{
$this->registerFormMapping();
}
/**
* Register form mapping information
*/
public function registerFormMapping()
{
FormHelper::registerFormTypeMapping(array(
'sonata_type_admin' => 'Sonata\AdminBundle\Form\Type\AdminType', // the form mapping
));
FormHelper::registerFormExtensionMapping('choice', array( // the extended mapping for the choice type
'sonata.admin.form.extension.choice',
));
}
}
You can either alter your bundle to configure these mappings or you can add the mapping as configuration settings. Values provided in configuration will overwrite default values:

.. code-block: yaml
sonata_core:
form:
mapping:
enabled: true # (default value)
type:
sonata_type_admin: Sonata\AdminBundle\Form\Type\AdminType
extension:
choice:
- sonata.admin.form.extension.choice
If you are lazy, you can get the mapping with the command:

.. code-block: yaml
app/console sonata:core:form-mapping -f yaml|php
DoctrineORMSerializationType
----------------------------

Expand Down Expand Up @@ -115,8 +43,8 @@ The service definition should contain the following arguments:



sonata_type_immutable_array
---------------------------
ImmutableArrayType
------------------

The ``Immutable Array`` allows you to edit an array property by defining a type per key.

Expand Down Expand Up @@ -159,13 +87,14 @@ Now, the property can be edited by setting a type for each type:
<?php
// src/AppBundle/Admin/PageAdmin.php
use Sonata\CoreBundle\Form\Type\ImmutableArrayType;
class PageAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('options', 'sonata_type_immutable_array', array(
->add('options', ImmutableArrayType::class, array(
'keys' => array(
array('ttl', 'text', array('required' => false)),
array('redirect', 'url', array('required' => true)),
Expand All @@ -178,16 +107,16 @@ Now, the property can be edited by setting a type for each type:
// ...
}
sonata_type_boolean
-------------------
BooleanType
-----------

The ``boolean`` type is a specialized ``ChoiceType``, where the list of choices is locked to *yes* and *no*.

Note that for backward compatibility reasons, it will set your value to *1* for *yes* and to *2* for *no*.
If you want to map to a boolean value, just set the option ``transform`` to true. For instance, you need to do so when mapping to a doctrine boolean.

sonata_type_translatable_choice
-------------------------------
TranslatableChoiceType
----------------------

The translatable type is a specialized ``ChoiceType`` where the choices values are translated with the Symfony Translator component.

Expand Down Expand Up @@ -222,13 +151,14 @@ The type has one extra parameter:
<?php
// src/AppBundle/Admin/DeliveryAdmin.php
use Sonata\CoreBundle\Form\Type\TranslatableChoiceType;
class DeliveryAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('deliveryStatus', 'sonata_type_translatable_choice', array(
->add('deliveryStatus', TranslatableChoiceType::class, array(
'choices' => Delivery::getStatusList(),
'catalogue' => 'SonataOrderBundle'
))
Expand All @@ -243,8 +173,8 @@ The type has one extra parameter:

For more information, you can check the official `ChoiceType documentation`_ .

sonata_type_collection
----------------------
CollectionType
--------------

The ``Collection Type`` is meant to handle creation and editing of model
collections. Rows can be added and deleted, and your model abstraction layer may
Expand All @@ -255,13 +185,14 @@ to the underlying forms.
<?php
// src/AppBundle/Entity/ProductAdmin.php
use Sonata\CoreBundle\Form\Type\CollectionType;
class ProductAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('sales', 'sonata_type_collection', array(
->add('sales', CollectionType::class, array(
// Prevents the "Delete" option from being displayed
'type_options' => array('delete' => false)
Expand Down Expand Up @@ -330,7 +261,7 @@ This can be done by declaring a new service:
.. code-block:: xml
<service id="sonata.order.form.status_type" class="Sonata\CoreBundle\Form\Type\StatusType">
<tag name="form.type" alias="sonata_order_status" />
<tag name="form.type" />
<argument>%sonata.order.order.class%</argument>
<argument>getStatusList</argument>
Expand All @@ -343,13 +274,14 @@ And the type can now be used:
<?php
// src/AppBundle/Admin/DeliveryAdmin.php
use App\Type\OrderStatusType;
class DeliveryAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('deliveryStatus', 'sonata_order_status')
->add('deliveryStatus', OrderStatusType::class)
// ...
;
}
Expand All @@ -358,12 +290,12 @@ And the type can now be used:
.. warning::

``StatusType`` cannot be used directly with Symfony3.0, you need to extends the class ``BaseStatusType``
with an empty class to have an unique FQCN.
with an empty class to have a unique FQCN.



sonata_type_date_picker and sonata_type_datetime_picker
-------------------------------------------------------
DatePickerType and DateTimePickerType
-------------------------------------

Those types integrate `Eonasdan's Bootstrap datetimepicker`_ into a Symfony form.
They both are available as services, and inherit from ``date`` and ``datetime`` default form types.
Expand Down Expand Up @@ -408,16 +340,18 @@ Finally, in your form, you may use the form type as follows:
<?php
// src/AppBundle/Admin/PageAdmin.php
use Sonata\CoreBundle\Form\Type\DatePickerType;
use Sonata\CoreBundle\Form\Type\DateTimePickerType;
class PageAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('publicationDateStart', 'sonata_type_datetime_picker')
->add('publicationDateStart', DateTimePickerType::class)
// or sonata_type_date_picker if you don't need the time
->add('publicationDateStart', 'sonata_type_date_picker')
->add('publicationDateStart', DatePickerType::class)
// ...
;
Expand All @@ -430,13 +364,15 @@ Many of the `standard date picker options`_ are available by adding options with
<?php
// src/AppBundle/Admin/PageAdmin.php
use Sonata\CoreBundle\Form\Type\DatePickerType;
use Sonata\CoreBundle\Form\Type\DateTimePickerType;
class PageAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('publicationDateStart', 'sonata_type_datetime_picker', array(
->add('publicationDateStart', DateTimePickerType::class, array(
'dp_side_by_side' => true,
'dp_use_current' => false,
'dp_use_seconds' => false,
Expand All @@ -447,7 +383,7 @@ Many of the `standard date picker options`_ are available by adding options with
))
// or sonata_type_date_picker if you don't need the time
->add('publicationDateStart', 'sonata_type_date_picker', array(
->add('publicationDateStart', DatePickerType::class, array(
'dp_use_current' => false,
))
;
Expand All @@ -458,27 +394,31 @@ If you look in the classes ``DateTimePickerType.php`` and ``BasePickerType.php``

In addition to these standard options, there is also the option ``datepicker_use_button`` which, when used, will change the widget so that the datepicker icon is not shown and the pop-up datepicker is invoked simply by clicking on the date input.

sonata_type_date_range_picker and sonata_type_datetime_range_picker
-------------------------------------------------------------------
DateRangePickerType and DateTimeRangePickerType
-----------------------------------------------

``sonata_type_date_range_picker`` and ``sonata_type_datetime_range_picker`` extends the basic range form field types (``sonata_type_date_range`` and ``sonata_type_datetime_range``).
Those types extend the basic range form field types
(``Sonata\CoreBundle\Form\Type\DateRangeType`` and
``Sonata\CoreBundle\Form\Type\DateTimeRangeType``).
You can use them if you need datetime picker in datetime range filters.

Example with ``doctrine_orm_date_range`` filter:
Example with ``Sonata\DoctrineORMAdminBundle\Filter\DateRangeFilter`` filter:

.. code-block:: php
<?php
// src/AppBundle/Admin/PostAdmin.php
use Sonata\CoreBundle\Form\Type\DateRangeType;
use Sonata\DoctrineORMAdminBundle\Filter\DateRangeFilter;
class PostAdmin extends Admin
{
protected function configureDatagridFilters(DatagridMapper $datagridMapper)
{
$datagridMapper
->add('createdAt', 'doctrine_orm_date_range', array(
'field_type' => 'sonata_type_date_range_picker',
->add('createdAt', DateRangeFilter::class, array(
'field_type' => DateRangeType::class,
))
// ...
;
Expand All @@ -487,8 +427,8 @@ Example with ``doctrine_orm_date_range`` filter:
// ...
}
sonata_type_color
------------------------
ColorType
---------

This is HTML5 input type color.

Expand All @@ -511,13 +451,14 @@ Finally, in your form, you may use the form type as follows:
<?php
// src/AppBundle/Admin/PageAdmin.php
use Sonata\CoreBundle\Form\Type\ColorType;
class PageAdmin extends Admin
{
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('color', 'sonata_type_color')
->add('color', ColorType::class)
// ...
;
}
Expand Down
5 changes: 4 additions & 1 deletion docs/reference/installation.rst
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,10 @@ Configuration
# app/config/config.yml
sonata_core: ~
sonata_core:
form:
mapping:
enabled: false
When using bootstrap, some widgets need to be wrapped in a special ``div`` element
depending on whether you are using the standard style for your forms or the
Expand Down
3 changes: 3 additions & 0 deletions src/Command/SonataListFormMappingCommand.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\HttpKernel\Kernel;

/**
* @deprecated since 3.x, to be removed in 4.0, the form mapping feature should be disabled.
*/
class SonataListFormMappingCommand extends ContainerAwareCommand
{
/**
Expand Down
3 changes: 3 additions & 0 deletions src/DependencyInjection/Compiler/FormFactoryCompilerPass.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
use Symfony\Bundle\FrameworkBundle\DependencyInjection\Compiler\FormPass;
use Symfony\Component\DependencyInjection\ContainerBuilder;

/**
* @deprecated since 3.x, to be removed in 4.0, the form mapping feature should be disabled.
*/
class FormFactoryCompilerPass extends FormPass
{
/**
Expand Down
5 changes: 5 additions & 0 deletions src/DependencyInjection/SonataCoreExtension.php
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,11 @@ public function configureFormFactory(ContainerBuilder $container, array $config)
return;
}

@trigger_error(
'Relying on the form mapping feature is deprecated since 3.x and will be removed in 4.0. Please set the "sonata_core.form.mapping.enabled" configuration node to false to avoid this message.',
E_USER_DEPRECATED
);

$container->setParameter('sonata.core.form.mapping.type', $config['form']['mapping']['type']);
$container->setParameter('sonata.core.form.mapping.extension', $config['form']['mapping']['extension']);

Expand Down
Loading

0 comments on commit 7c72ed8

Please sign in to comment.