Sem descrição

Mike Meier 3d8818dd2c add missing spaces há 12 anos atrás
Admin 3d8818dd2c add missing spaces há 12 anos atrás
Block cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Builder cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Command cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Controller 2e89b6155c Added isXmlHttp check há 12 anos atrás
Datagrid cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
DependencyInjection b9170e8218 Fix issue with JMSDiExtraBundle há 12 anos atrás
Exception cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Export 0ba9efeba3 Added BOM to CSV export files há 12 anos atrás
Filter cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Form cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Guesser cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Model cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Resources 0602f6d71f Fix export option being hidden when no batch are defined há 12 anos atrás
Route cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Security cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Show cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Tests 7767eaeb4e reorder batch field only if exists há 12 anos atrás
Translator f15aabd6bc made the logger optional in AdminExtractor há 12 anos atrás
Twig ffde3358de Add Twig filter urlsafeid há 12 anos atrás
Util cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
Validator e5fcf6f461 added addConstraint() to ErrorElement closes #1200 há 12 anos atrás
.gitignore 106e96a94d fixed merging bugs há 13 anos atrás
.travis.yml 5d78a0098f remove SYMFONY_VERSION env var from .travis.yml há 12 anos atrás
CHANGELOG.md 984a6c32ff Fixed typos há 12 anos atrás
CREDITS 1f2459c1e8 restore famfam icon for legacy BC há 12 anos atrás
LICENSE 1f2459c1e8 restore famfam icon for legacy BC há 12 anos atrás
README.md adc00621a5 Fixed list of available translations há 12 anos atrás
SonataAdminBundle.php cae5a7df03 Apply PHP-CS-Fixer há 12 anos atrás
UPGRADE-2.1.md c8a1b417f2 revert back to KnpMenuBundle 1.1.* (ie. revert 33a7649afa51a009a8849de46e79cc600fc5dba3) há 13 anos atrás
build.xml eab3965686 Update composer.json há 12 anos atrás
composer.json ad0b47cef1 Fixed dependencies for 2.1 branch há 12 anos atrás
phpunit.xml.dist c30bd9426d Add build process for jenkins integration há 13 anos atrás

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