Use:
new \Doctrine\Common\Collections\ArrayCollection()
instead ofgetModelCollectionInstance($class)
$collection->removeElement($element)
instead ofcollectionRemoveElement($collection, $element)
$collection->add($element)
instead ofcollectionAddElement($collection, $element)
$collection->contains($element)
instead ofcollectionHasElement($collection, $element)
$collection->clear()
instead ofcollectionClear($collection)
Use Sonata\AdminBundle\Datagrid\ProxyQueryInterface::execute
instead.
src/Resources/views/CRUD/base_filter_field.html.twig
src/Resources/views/CRUD/base_inline_edit_field.html.twig
src/Resources/views/CRUD/base_standard_edit_field.html.twig
src/Resources/views/CRUD/edit_array.html.twig
src/Resources/views/CRUD/edit_boolean.html.twig
src/Resources/views/CRUD/edit_file.html.twig
src/Resources/views/CRUD/edit_integer.html.twig
src/Resources/views/CRUD/edit_sonata_type_immutable_array.html.twig
src/Resources/views/CRUD/edit_string.html.twig
src/Resources/views/CRUD/edit_text.html.twig
You MUST use Symfony's help
option instead.
Before:
$formMapper
->add('field', null, [
'help' => 'Help text <small>Please!</small>',
]);
After:
$formMapper
->add('field', null, [
'help' => 'Help text <small>Please!</small>',
'help_html' => true,
]);
We added compatibility with SonataBlockBundle 4.0, make sure you are explicitly declaring your dependency
with sonata-project/block-bundle
on your composer.json in order to avoid unwanted upgrades.
There is a minimal BC Break on AdminListBlockService
, AdminSearchBlockService
and AdminStatsBlockService
. If you are extending those clases (keep in mind that they will become final on 4.0) you should add return type hints to execute()
and configureSettings()
.
Deprecated passing callable
that does not return Symfony\Component\Routing\Route
as $element
(2nd argument) to Sonata\AdminBundle\Route\RouteCollection::addElement($code, $element)
When calling a Sonata\AdminBundle\Route\RouteCollection::addElement($code, $element)
, please pass $element
of type Route|callable():Route
. Passing callable
that returns non instance of Route
is deprecated.
Use Sonata\AdminBundle\Admin\AdminInterface::getParentFieldDescription
instead.
Use
$instance = $fieldDescription->getAssociationAdmin()->getNewInstance();
SonataAdminBundle\Manipulator\ObjectManipulator::setObject($instance, $object, $fieldDescription);
Instead of
$this->adminHelper->addNewInstance($object, $fieldDescription);
The static method setObject()
avoids the need to inject the admin helper dependency,
and adds more flexibility with the instance you're adding to the object.
This filter has been deprecated in favor of the u
filter:
Use Symfony\Component\String\UnicodeString
instead.
You can use TemplateRegistry
constants, like
$showMapper->add('foo', TemplateRegistry::TYPE_STRING)
instead of using directly a string value.
$showMapper->add('foo', 'string')
The list of available types can be found in the documentation.
text
: deprecated in favor ofTemplateRegistry::TYPE_STRING
decimal
: deprecated in favor ofTemplateRegistry::TYPE_FLOAT
smallint
: deprecated in favor ofTemplateRegistry::TYPE_INTEGER
bigint
: deprecated in favor ofTemplateRegistry::TYPE_INTEGER
Before:
$showMapper->add('nonExistingField');
$listMapper->add('nonExistingField');
was displaying nothing in the list and the show views without any warning or error.
But
$formMapper->add('nonExistingField');
was throwing an exception.
In the next major an exception will be thrown if no getter/isser/hasser is found for the property. Since most of the time the error is coming from a typo, this will allow the developer to catch it as fast as possible. Currently this will only trigger a deprecation if the field value is not found.
Deprecated not passing a Sonata\AdminBundle\Admin\AdminHelper
instance to Sonata\AdminBundle\Form\Type\AdminType::__construct()
When instantiating a Sonata\AdminBundle\Form\Type\AdminType
object, please use the 1 parameter signature ($adminHelper)
.
Deprecated not setting as false
the configuration option sonata_admin.options.legacy_twig_text_extension
This option controls which Twig text extension will be used to provide filters like
truncate
or wordwrap
.
The legacy behavior is provided by the abandoned package "twig/extensions",
while the new implementation is based on "twig/string-extra".
Its default value is true
in order to keep the legacy behavior. You should set
it to false
in order to get the behavior which will be used by default at 4.0.
sonata_admin:
options:
legacy_twig_text_extension: false
You should use the truncate.separator
and truncate.cut
options instead. Unlike
truncate.preserve
, truncate.cut
has false
as its default value and the opposite
behavior:
Before:
$showMapper
->add('field', null, [
'truncate' => [
'preserve' => true,
'separator' => '...',
],
])
;
After:
$showMapper
->add('field', null, [
'truncate' => [
'cut' => false,
'ellipsis' => '...',
],
])
;
If you are using autoconfiguration,
all the services implementing Sonata\AdminBundle\Model\ModelManagerInterface
will
be automatically tagged. Otherwise, you must tag them explicitly.
Before:
<service id="sonata.admin.manager.custom" class="App\Model\ModelManager">
<!-- ... -->
</service>
After:
<service id="sonata.admin.manager.custom" class="App\Model\ModelManager">
<!-- ... -->
<tag name="sonata.admin.manager"/>
</service>
You should use Symfony's help
option instead.
Before:
$formMapper
->add('field', null, [
'sonata_help' => 'Help text',
])
;
After:
$formMapper
->add('field', null, [
'help' => 'Help text',
])
;
Before:
$datagridMapper
->add('field', 'filter_type')
;
After:
use App\Filter\FilterType;
$datagridMapper
->add('field', FilterType::class)
;
If you extended that controller, you should split your extended controller and
extend the corresponding classes in SonataAdminBundle\Action\
.
If you need to style headers prefer to use CSS classes and not in the html DOM.
In this case please use header_class
option.
When calling SimplePager::getResults()
on non-empty result which has set $maxPerPage
, Collection
would be returned instead of array
as it is declared in PagerInterface
. Update usage of SimplePager::getResults()
, ensure you are transforming Collection
to array
and you aren't dealing with any of its methods.
// will return Collection on non-empty result and array on empty result
$results = $pager->getResults();
if ($results instanceof ArrayCollection) {
$results = $results->toArray();
}
Admin classes can now have multiple parents, when registering the service you should pass a field name:
<service id="sonata.admin.playlist" class="App\Admin\PlaylistAdmin">
<!-- ... -->
<call method="addChild">
<argument type="service" id="sonata.admin.video" />
<argument>playlist</argument>
</call>
</service>
Overwriting $parentAssociationMapping
is discouraged.
Deprecated calling of AbstractAdmin::addChild
without second argument.
The AbstractAdmin::$templates
attribute and the methods getTemplate()
and
getTemplates()
are deprecated. Please use the new TemplateRegistry services
instead. One per admin is generated and available through the admin code +
.template_registry
(for example, app.admin.news
uses app.admin.news.template_registry
).
The Pool::$templates
attribute and the methods getTemplate()
, getTemplates()
and setTemplates()
are deprecated. Please use the TemplateRegistry service
sonata.admin.global_template_registry
instead.
The Twig function get_admin_pool_template()
is deprecated. Please use
get_global_template()
instead.
The AbstractAdmin::$persistFilters
is deprecated and should not be used anymore.
The problem was that it was not easy to change the way filters are persisted.
Instead of a simple boolean var (whether to persist or not filters) you can now inject a service,
that will be responsible for doing the job (see FilterPersisterInterface
).
An implementation was added, which falls back to the previous behavior : SessionFilterPersister
.
This is not allowed anymore and will throw a 404 error in the future.
The SonataAdminExtension::output()
method is deprecated and should not be
used anymore.
The AdminVoter::setRequest
is deprecated and should not be used anymore.
This method was inconsistent with the structure of AbstractAdmin::$subClasses
,
which is supposed to contain a hash that associates aliases with FQCNs. Use AbstractAdmin::setSubClasses
instead.
The feature provided by this class was replaced with something much more simple, and you should not rely on it anymore,
as well as on the sonata.admin.menu.matcher.voter.children
service.
Call CRUDController::renderWithExtraParams()
instead.
The AbstractAdmin::baseCodeRoute
property is no longer supported.
Please use the AbstractAdmin::getBaseCodeRoute()
method instead.
The AbstractAdmin::setBaseCodeRoute()
method is no longer supported.
There is no replacement for this method.
You can still use the AbstractAdmin::setCode()
method to set the code
of an admin.
sonata:admin:generate
was based on the SensioGeneratorBundle, which is
incompatible with Symfony 4 and is no longer maintained. Please use
make:sonata:admin
instead.
The ModelChoiceList
class is no longer supported. Please use the ModelChoiceLoader
class instead.
The ModelChoiceList
is usually used on the choice_list
option of a FormBuilder
. The ModelChoiceLoader
class must be replaced on the
choice_loader
option.
Starting with version 4.0, SonataAdminBundle will no longer register annotations with JMSDiExtraBundle automatically. Please add the following to your config.yml to register the annotations yourself:
jms_di_extra:
annotation_patterns:
- JMS\DiExtraBundle\Annotation
- Sonata\AdminBundle\Annotation
The sonata.admin.exporter
is deprecated in favor of the sonata.exporter.exporter
service.
To make this service available, you have to install sonata-project.exporter
^1.7
and enable the bundle as described in the documentation.
When instantiating a ModelsToArrayTransformer object, please use the 2 parameter signature ($modelManager, $class).
Please use Pager::getFirstIndex()
and Pager::getLastIndex()
instead!
Passing no 3rd argument to Menu\Provider\GroupMenuProvider
is deprecated.
Pass Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface
as 3rd argument.
The $translator
property and the corresponding methods (setTranslator
, getTranslator
, trans
and transChoice
) in AbstractAdmin
are deprecated.
Please use CRUDController::trans
or twig templates instead.
The $container
property in Twig/GlobalVariables
is deprecated.
The Sonata\AdminBundle\Form\Type\ModelTypeList
class is now deprecated.
Use Sonata\AdminBundle\Form\Type\ModelListType
instead.
All files under the Tests
directory are now correctly handled as internal test classes.
You can't extend them anymore, because they are only loaded when running internal tests.
More information can be found in the composer docs.
The $context
argument is deprecated and will be removed.
Instead of relying on it (and using a switch
statement),
rely on an abstraction, and inject different implementations of this abstraction in different actions.
Here is an example.
Since AbstractAdmin::configureBatchActions
is present, you should not override AbstractAdmin::getBatchActions
.
This method will be final in 4.0.
Now AbstractAdmin::getSubject()
return null
or object
of subject entity. Previously,
AbstractAdmin::getSubject()
may return false
if entity identifier not match regexp /^[0-9A-Fa-f\-]+$/
.
The Admin
class is deprecated. Use AbstractAdmin
instead.
The AdminExtension
class is deprecated. Use AbstractAdminExtension
instead.
The Twig extension method that fallback to a default template when the specified one does not exist. You can no longer rely on that and should always specify templates that exist.
buildBreacrumbs
is deprecated, and no replacement is given, it will become an internal method.getBreadcrumbs
is deprecated in favor of the homonym method of thesonata.admin.breadcrumbs_builder
service.- The breadcrumbs builder accessors are deprecated,
the
sonata.admin.breadcrumbs_builder
service should be used directly instead.