action_create_edit.rst 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. Creating and Editing objects
  2. ============================
  3. .. note::
  4. This document is a stub representing a new work in progress. If you're reading
  5. this you can help contribute, **no matter what your experience level with Sonata
  6. is**. Check out the `issues on Github`_ for more information about how to get involved.
  7. This document will cover the Create and Edit actions. It will cover configuration
  8. of the fields and forms available in these views and any other relevant settings.
  9. Basic configuration
  10. -------------------
  11. To do:
  12. - global (yml) options that affect the create and edit actions
  13. - a note about Routes and how disabling them disables the related action
  14. - using configureFormFields() to set which fields to display
  15. - options available when adding fields, inc custom templates
  16. - link to the field_types document for more details about specific field types
  17. FormGroup options
  18. ~~~~~~~~~~~~~~~~~
  19. When adding a form group to your edit/create form, you may specify some options for the group itself.
  20. - ``collapsed``: unused at the moment
  21. - ``class``: the class for your form group in the admin; by default, the value is set to ``col-md-12``.
  22. - ``fields``: the fields in your form group (you should NOT override this unless you know what you're doing).
  23. - ``box_class``: the class for your form group box in the admin; by default, the value is set to ``box box-primary``.
  24. - ``description``: to complete
  25. - ``translation_domain``: to complete
  26. To specify options, do as follows:
  27. .. code-block:: php
  28. <?php
  29. // src/AppBundle/Admin/PersonAdmin.php
  30. class PersonAdmin extends Admin
  31. {
  32. // ...
  33. public function configureFormFields(FormMapper $formMapper)
  34. {
  35. $formMapper
  36. ->tab('General') // the tab call is optional
  37. ->with('Addresses', array(
  38. 'class' => 'col-md-8',
  39. 'box_class' => 'box box-solid box-danger',
  40. 'description' => 'Lorem ipsum',
  41. // ...
  42. ))
  43. ->add('title')
  44. // ...
  45. ->end()
  46. ->end()
  47. ;
  48. }
  49. Here is an example of what you can do with customizing the box_class on a group
  50. .. figure:: ../images/box_class.png
  51. :align: center
  52. :alt: Box Class
  53. :width: 500
  54. Embedding other Admins
  55. ----------------------
  56. To do:
  57. - how to embed one Admin in another (1:1, 1:M, M:M)
  58. - how to access the right object(s) from the embedded Admin's code
  59. Customizing just one of the actions
  60. -----------------------------------
  61. To do:
  62. - how to create settings/fields that appear on just one of the create/edit views
  63. and any controller changes needed to manage them
  64. .. _`issues on GitHub`: https://github.com/sonata-project/SonataAdminBundle/issues/1519