Brak opisu

Wesley van Opdorp 3f9d60d402 Removed translation as it belonged in SonataUserBundle 12 lat temu
Admin 54547dd7c1 Fix #997 12 lat temu
Block c23e0ca311 Update Block/AdminListBlockService.php 13 lat temu
Builder 94e0b118d1 Remove @abstract from phpdoc 12 lat temu
Command 73d507571c some phpdoc fixes and improve code view 13 lat temu
Controller b4c6e93fa3 Set flash messages in create and edit actions only if it's not an Ajax request 12 lat temu
Datagrid 73d507571c some phpdoc fixes and improve code view 13 lat temu
DependencyInjection 4a3cec84f8 Fixed variable name 12 lat temu
Exception 5b75b51303 Refactoring of NoValueException 13 lat temu
Export 73d507571c some phpdoc fixes and improve code view 13 lat temu
Filter fe11f07f77 fixed filtering on sub-entities for sf 2.1 12 lat temu
Form 618af44f48 Remove obsolete code, now built in with sf2.1 12 lat temu
Guesser 73d507571c some phpdoc fixes and improve code view 13 lat temu
Model 73d507571c some phpdoc fixes and improve code view 13 lat temu
Resources 3f9d60d402 Removed translation as it belonged in SonataUserBundle 12 lat temu
Route bff64d2dff Fixed Symfony naming convetion break 12 lat temu
Security 73d507571c some phpdoc fixes and improve code view 13 lat temu
Show 83eb838e13 Add a safe option for template 12 lat temu
Tests 54547dd7c1 Fix #997 12 lat temu
Translator 4c9bff8a46 Fix CS 13 lat temu
Twig 73d507571c some phpdoc fixes and improve code view 13 lat temu
Util 73d507571c some phpdoc fixes and improve code view 13 lat temu
Validator 24c52778ad fixed extra constraint violations 12 lat temu
.gitignore 106e96a94d fixed merging bugs 13 lat temu
.travis.yml 5d78a0098f remove SYMFONY_VERSION env var from .travis.yml 12 lat temu
CHANGELOG.md 984a6c32ff Fixed typos 12 lat temu
CREDITS 1f2459c1e8 restore famfam icon for legacy BC 12 lat temu
LICENSE 1f2459c1e8 restore famfam icon for legacy BC 12 lat temu
README.md adc00621a5 Fixed list of available translations 12 lat temu
SonataAdminBundle.php 59285d5b29 Fix some CS 13 lat temu
UPGRADE-2.1.md c8a1b417f2 revert back to KnpMenuBundle 1.1.* (ie. revert 33a7649afa51a009a8849de46e79cc600fc5dba3) 13 lat temu
build.xml eab3965686 Update composer.json 12 lat temu
composer.json 5d0b067977 require security-bundle 12 lat temu
phpunit.xml.dist c30bd9426d Add build process for jenkins integration 13 lat temu

README.md

SonataAdminBundle - The missing Symfony2 Admin Generator

Build Status

The online documentation of the bundle is in http://sonata-project.org/bundles/admin

The demo website can be found in http://demo.sonata-project.org/admin/dashboard (admin as user and password)

For contribution to the documentation you can find it on 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.

Warning: The bundle has been split into 4 bundles :

Google Groups: For questions and proposals you can post on this google groups

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 (dependency injection container).

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 22 languages : BG, CA, CS, DE, EN, ES, EU, FA, FR, HR, IT, JA, LB, NL, PL, PT, PT_BR, RU, SK, SL, UK and zh_CN.
    • Built to be extended
    • Explain command line utility

Usage examples

TODO

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