'\d+'])] public function index(RepositoryQuery $query, Request $request, Session $session, int $page = 1): Response { return $this->doIndex($page, $query, $request, $session); } #[Route(path: '/admin/speaker/new', name: 'admin_speaker_new', methods: ['GET', 'POST'])] public function new(Factory $factory, EntityManager $entityManager, Request $request, OpenSSL $openSSL): Response { return $this->doNew($factory->create(), $entityManager, $request, function (Entity $entity) use ($openSSL) { $openSSL->encryptEntity($entity); }); } #[Route(path: '/admin/speaker/show/{entity}', name: 'admin_speaker_show', methods: ['GET'], options: ['expose' => true])] public function show(Entity $entity): Response { return $this->doShow($entity); } #[Route(path: '/admin/speaker/filter', name: 'admin_speaker_filter', methods: ['GET'])] public function filter(Session $session): Response { return $this->doFilter($session); } #[Route(path: '/admin/speaker/edit/{entity}', name: 'admin_speaker_edit', methods: ['GET', 'POST'])] public function edit(Entity $entity, EntityManager $entityManager, Request $request, OpenSSL $openSSL): Response { $openSSL->decryptEntity($entity); $caldavPassword = $entity->getCaldavPassword(); return $this->doEdit($entity, $entityManager, $request, function (Entity $entity) use ($openSSL, $caldavPassword) { if (!$entity->getCaldavPassword()) { $entity->setCaldavPassword($caldavPassword); } $openSSL->encryptEntity($entity); }); } #[Route(path: '/admin/speaker/sort/{page}', name: 'admin_speaker_sort', methods: ['POST'], requirements: ['page' => '\d+'])] public function sort(RepositoryQuery $query, EntityManager $entityManager, Request $request, Session $session, int $page = 1): Response { return $this->doSort($page, $query, $entityManager, $request, $session); } #[Route(path: '/admin/speaker/batch/{page}', name: 'admin_speaker_batch', methods: ['POST'], requirements: ['page' => '\d+'])] public function batch(RepositoryQuery $query, EntityManager $entityManager, Request $request, Session $session, int $page = 1): Response { return $this->doBatch($page, $query, $entityManager, $request, $session); } #[Route(path: '/admin/speaker/delete/{entity}', name: 'admin_speaker_delete', methods: ['DELETE'])] public function delete(Entity $entity, EntityManager $entityManager, Request $request): Response { return $this->doDelete($entity, $entityManager, $request); } protected function getConfiguration(): CrudConfiguration { return CrudConfiguration::create() ->setPageTitle('index', 'Intervenant⋅e⋅s') ->setPageTitle('edit', '{name}') ->setPageTitle('new', 'Nouvelle·au intervenant⋅e') ->setPageTitle('show', '{name}') ->setPageRoute('index', 'admin_speaker_index') ->setPageRoute('new', 'admin_speaker_new') ->setPageRoute('edit', 'admin_speaker_edit') ->setPageRoute('show', 'admin_speaker_show') ->setPageRoute('sort', 'admin_speaker_sort') ->setPageRoute('batch', 'admin_speaker_batch') ->setPageRoute('delete', 'admin_speaker_delete') ->setPageRoute('filter', 'admin_speaker_filter') ->setForm('edit', Type::class, []) ->setForm('new', Type::class) // ->setForm('filter', Type::class) // ->setMaxPerPage('index', 20) // ->setIsSortableCollection('index', false) // ->setSortableCollectionProperty('sortOrder') // ->setAction('index', 'new', true) ->setAction('index', 'show', false) // ->setAction('index', 'edit', true) // ->setAction('index', 'delete', true) // ->setAction('edit', 'back', true) ->setAction('edit', 'show', false) // ->setAction('edit', 'delete', true) // ->setAction('show', 'back', true) // ->setAction('show', 'edit', true) ->setDefaultSort('index', 'name') ->setFormOptions('new', [ 'edit_caldav' => $this->isGranted('ROLE_ADMIN'), ]) ->setFormOptions('edit', [ 'edit_caldav' => $this->isGranted('ROLE_ADMIN'), ]) ->setField('index', 'Name', Field\TextField::class, [ 'property' => 'name', 'sort' => ['name', '.name'], ]) ->setBatchAction('index', 'delete', 'Delete', function (EntityInterface $entity, EntityManager $manager) { $manager->delete($entity); }) ; } protected function getSection(): string { return 'speaker'; } }