action_create_edit.rst 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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 follow:
  27. .. code-block:: php
  28. <?php
  29. MyAdmin extends Admin
  30. {
  31. # ...
  32. public function configureFormFields(FormMapper $formMapper)
  33. {
  34. $formMapper
  35. ->tab('General') // the tab call is optional
  36. ->with('Addresses',
  37. array(
  38. 'class' => 'col-md-8',
  39. 'box_class' => 'box box-solid box-danger',
  40. 'description' => 'Lorem ipsum',
  41. // ...
  42. ))
  43. // ...
  44. ->end()
  45. ->end()
  46. ;
  47. }
  48. Here is an example of what you can do with customizing the box_class on a group
  49. .. figure:: ../images/box_class.png
  50. :align: center
  51. :alt: Dashboard
  52. :width: 500
  53. Embedding other Admins
  54. ----------------------
  55. To do:
  56. - how to embed one Admin in another (1:1, 1:M, M:M)
  57. - how to access the right object(s) from the embedded Admin's code
  58. Customizing just one of the actions
  59. -----------------------------------
  60. To do:
  61. - how to create settings/fields that appear on just one of the create/edit views
  62. and any controller changes needed to manage them
  63. .. _`issues on GitHub`: https://github.com/sonata-project/SonataAdminBundle/issues/1519