X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=module%2FGalerie%2Fsrc%2FGalerie%2FController%2FIndexController.php;h=78aa858ed813c2bfa5fcfa861dd26a87204ad53e;hb=34c823d7546c4d016383e848e8971e3491479ddb;hp=536c332893ae05855adc24fd6d12ce995f774428;hpb=507fcd4dcfa13781525db8071a4689841a6b30dc;p=zf2.biz%2Fgalerie.git diff --git a/module/Galerie/src/Galerie/Controller/IndexController.php b/module/Galerie/src/Galerie/Controller/IndexController.php index 536c332..78aa858 100644 --- a/module/Galerie/src/Galerie/Controller/IndexController.php +++ b/module/Galerie/src/Galerie/Controller/IndexController.php @@ -5,6 +5,9 @@ namespace Galerie\Controller; use Zend\Mvc\Controller\AbstractActionController; use Zend\View\Model\ViewModel; +use Galerie\Model\Galerie; +use Galerie\Form\GalerieForm; + class IndexController extends AbstractActionController { @@ -39,21 +42,89 @@ class IndexController extends AbstractActionController } public function editAction() - { - return array(); + { + // Création du formulaire + $form = new GalerieForm; + + // Récupération de l'objet de travail + $id = $this->params()->fromRoute('id', null); + if (!$id) { + $galerie = null; + } else { + $galerie = $this->_getGalerieTable()->any(array('id' => $id)); + } + + // Sommes-nous en ajout ou en édition ? + if (!$galerie) { + // Nous sommes en ajout + $form->get('submit')->setValue('Ajouter'); + // Il faut créer un nouveau objet Galerie + $galerie = new Galerie; + // Garder cette information pour la vue + $is_new = true; + } else { + // Nous sommes en modification + $form->get('submit')->setValue('Modifier'); + // Il faut préremplir le formulaire avec les données actuelles + $form->bind($galerie); + // Garder cette information pour la vue + $is_new = false; + } + + // Récupération de l'objet requête + $request = $this->getRequest(); + if ($request->isPost()) { + // Mise en place pour la validation du formulaire + $form->setInputFilter($galerie->getInputFilter()); + $form->setData($request->getPost()); + + // Validation des données + if ($form->isValid()) { + // Sauvegarde des données + $galerie = $form->getData(); + if ($is_new) { + // Si l'objet n'est pas nouveau, les autres paramètres restent inchangés + // Si l'objet est nouveau, il faut renseigner l'id de l'utilisateur courant + $galerie->id_user = 1; //TODO: Mettre ici le user connecté + } + $this->_getGalerieTable()->save($galerie); + + // Redirection + return $this->redirect()->toRoute('galerie'); + } + } + + // On prépare l'affichage du formulaire + if ($is_new) { + $form->setAttribute('action', $this->url()->fromRoute('galerie/add')); + } else { + $form->setAttribute('action', $this->url()->fromRoute('galerie/edit', array('id' => $id))); + } + $form->prepare(); + + // On passe la main à la vue + return new ViewModel(array( + 'id' => $id, + 'form' => $form, + 'is_new' => $is_new, + )); } public function delAction() { - return array(); + return $this->redirect()->toRoute('galerie/view', array( + 'id' => $this->params()->fromRoute('id', null), + )); } public function viewAction() - { + { + $id = $this->params()->fromRoute('id', null); + $galerie = $this->_getGalerieInfoTable()->any($id); return new ViewModel(array( - 'galerie' => $this->_getGalerieInfoTable()->one( - 1 - ), - )); + 'id' => $id, + 'galerie' => $galerie, + )); } + }