No Description

Thomas Rabaix f9f72e08bb tweak the ModelManager find* methods 13 years ago
Admin f9f72e08bb tweak the ModelManager find* methods 13 years ago
Builder a6b917da90 Add a remove option for list mode 13 years ago
Command c38627afe3 add more details in explain command output 14 years ago
Controller e172203b1c Fix issue with nested admin and create action 13 years ago
Datagrid 81bfb1da01 add operator to all fields, update documentation 13 years ago
DependencyInjection 1e46436098 Inject the MenuFactory service in the Admin class 13 years ago
Filter 82e2c3c8a4 add alias for admin query (because of sql keyword) 13 years ago
Form 79f48d93e9 mmutableArrayType buildForm with FormBuilder as option 13 years ago
Guesser 81bfb1da01 add operator to all fields, update documentation 13 years ago
Model f9f72e08bb tweak the ModelManager find* methods 13 years ago
Resources 5eef7fdc3f Update documentation 13 years ago
Route ab62310543 make RouteCollection::remove() fluent 13 years ago
Security 221ed40d73 Update phpdocs 13 years ago
Show 3896ed5c24 Fixed the phpdoc for the mappers to make the fluent api friendly with IDEs 14 years ago
Tests cf8361af1c Update number filter to match the string behavior on undefined type 13 years ago
Twig 61747738c2 Fix bug when no related admin is defined 13 years ago
Util 0dc07aea65 Initial form refactoring 14 years ago
Validator fd22ec7246 Update phpdocs, fix bug with undefined variable 13 years ago
.gitignore f5c060c3ac Updated translations to be aligned to english translations 14 years ago
CHANGES fc187bf483 Refactoring the Menu/Breadcrumb management due to a change in the KnpLab Menu lib 13 years ago
CREDITS e0e3e92a69 update README, add missing type 14 years ago
LICENSE 5b24344281 add jquery.form.js to allows file upload from a modal window 14 years ago
README.md 74db6a7157 added syntax highlighting for php in readme 13 years ago
SonataAdminBundle.php f6380b316f Add extension feature (allows to alter an Admin Instance from an external service) 13 years ago
phpunit.xml.dist 51fb49c0ca update references from BaseApplicationBundle to AdminBundle 14 years ago

README.md

SonataAdminBundle - The missing Symfony2 Admin Generator

The documentation of the bundle is in Resources/doc.

Warning: documentation files are not rendering correctly in Github (reStructuredText format) and some content might be broken or hidden, make sure to read raw files.

Quick example

Defining an Admin class is pretty easy: simply define configure[Show|Form|List|Datagrid]Fields methods

<?php
namespace Sonata\NewsBundle\Admin;

use Sonata\AdminBundle\Admin\Admin;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Show\ShowMapper;

class PostAdmin extends Admin
{
    public function configureShowFields(ShowMapper $showMapper)
    {
        $showMapper
            ->add('author')
            ->add('enabled')
            ->add('title')
            ->add('abstract')
            ->add('content')
            ->add('tags')
        ;
    }

    public function configureFormFields(FormMapper $formMapper)
    {
        $formMapper
            ->with('General')
                ->add('enabled', null, array('required' => false))
                ->add('author', 'sonata_type_model', array(), array('edit' => 'list'))
                ->add('title')
                ->add('abstract')
                ->add('content')
            ->end()
            ->with('Tags')
                ->add('tags', 'sonata_type_model', array('expanded' => true))
            ->end()
            ->with('Options', array('collapsed' => true))
                ->add('commentsCloseAt')
                ->add('commentsEnabled', null, array('required' => false))
            ->end()
        ;
    }

    public function configureListFields(ListMapper $listMapper)
    {
        $listMapper
            ->addIdentifier('title')
            ->add('author')
            ->add('enabled')
            ->add('tags')
            ->add('commentsEnabled')
        ;
    }

    public function configureDatagridFilters(DatagridMapper $datagridMapper)
    {
        $datagridMapper
            ->add('title')
            ->add('enabled')
            ->add('tags', null, array('filter_field_options' => array('expanded' => true, 'multiple' => true)))
    }
}

Screenshots : http://www.dropbox.com/gallery/581816/2/BaseApplicationBundle/preview?h=59b2e8

Of course, power users will be happy as an Admin class is very flexible as all dependencies are injected by the DIC.

Features

  • Dashboard

  • List

    • Automatic sort
    • Link to associated admin (Post => User)
    • Custom templates
    • Row Action : edit, view, ...
    • Batch Action
    • Clever row visualisation : boolean values are represented with 'check picture'
    • Filter
    • Pagination
  • Edit/Create

    • Inline edition
    • Association management (create related model with + icon)
    • Group fields
    • Sortable option
    • Modal window to select model (when the list can be important)
    • Dynamic form on [one|many]-to-many association (add new element)
  • Templating

    • base templates (field, list, filter) can be overwritten
    • layout templates can be defined into the Service Container
  • Others

    • Nested Admin, ie /news/post/5/comment/list : filter and create comments only for the post with id=5
    • Contextual Breadcrumb
    • persistent parameters across an Admin
    • side menu option
    • Translated into 12 languages : DE, EN, ES, FR, IT, JA, NL, PL, PT_BR, PT_PT, RU and UK.
    • Built to be extended
    • Explain command line utility

Usage examples

TODO

  • create the ODM version
  • save filter criteria
  • export list