<?php
namespace AdminBundle\Admin\Service;
use Sonata\AdminBundle\Datagrid\ProxyQueryInterface;
use Sonata\AdminBundle\Admin\AbstractAdmin;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Route\RouteCollection;
use Sonata\AdminBundle\Route\RouteCollectionInterface;
use Symfony\Component\Finder\Exception\AccessDeniedException;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Component\Security\Core\Security;
class PartAdmin extends AbstractAdmin
{
protected Security $security;
public function setContainerServices(Security $security): void
{
$this->security = $security;
}
/**
* @param RouteCollection $collection
*/
protected function configureRoutes(RouteCollectionInterface $collection): void
{
$collection->remove('view');
$collection->remove('create');
}
protected function configureDatagridFilters(DatagridMapper $datagridMapper): void
{
$datagridMapper->add('id');
$datagridMapper->add('number', null, ['label' => 'Код']);
$datagridMapper->add('in_regulation',null, ['label' => 'Учавствует в ТО'], ChoiceType::class, [ 'choices' => [
'Да' => 1,
'Нет' => 0,
]]);
}
public function prePersist($object): void
{
$this->prePare($object);
}
public function preUpdate($object): void
{
$this->prePare($object);
parent::preUpdate($object);
}
private function prePare($object) {
$object->setInRegulation((int) $object->getInRegulation());
}
/**
* @param FormMapper $formMapper
*/
protected function configureFormFields(FormMapper $formMapper): void
{
$formMapper
->add('title',null, ['label' => 'Название 1C'])
->add('name_ru',null, ['label' => 'Название публичное RU'])
->add('name_ua',null, ['label' => 'Название публичное UA'])
->add('price',null, ['label' => 'Цена'])
->add('in_regulation',CheckboxType::class, ['label' => 'Учавствует в ТО', 'required' => false])
;
}
/**
* @param string $context
* @return ProxyQueryInterface
*/
public function configureQuery($context = 'list'): ProxyQueryInterface
{
$user = $this->security->getUser();
$query = parent::configureQuery($context);
$dealer = $user->getDealer();
if(!$dealer) {
throw new AccessDeniedException();
}
$query->andWhere(
$query->expr()->eq($query->getRootAliases()[0].'.dealer',':dealer')
);
$query->setParameter('dealer', $dealer->getId());
return $query;
}
/**
* @param ListMapper $listMapper
*/
protected function configureListFields(ListMapper $listMapper): void
{
$listMapper->addIdentifier('id')
->add('number',null, ['label' => 'Код'])
->add('title', null, ['label' => 'Название 1С'])
->add('count', null, ['label' => 'Остаток'])
->add('price',null, ['label' => 'Цена'])
->add('in_regulation','choice', ['label' => 'Учавствует в ТО', 'editable' => true, 'choices' => [
1 => 'Да',
0 => 'Нет',
]])
->add('_action', 'actions', [
'label' => 'Действия',
'actions' => [
'edit' => [],
]
])
;
}
}