doIndex($page, $query, $request, $session); } /** * @Route("/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("/admin/speaker/show/{entity}", name="admin_speaker_show", methods={"GET"}) */ public function show(Entity $entity): Response { return $this->doShow($entity); } /** * @Route("/admin/speaker/filter", name="admin_speaker_filter", methods={"GET"}) */ public function filter(Session $session): Response { return $this->doFilter($session); } /** * @Route("/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("/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("/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("/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'; } }