Différences
Ci-dessous, les différences entre deux révisions de la page.
| Les deux révisions précédentes Révision précédente Prochaine révision | Révision précédente | ||
| framework-web:symfony:td6 [2018/03/20 19:33] – jcheron | framework-web:symfony:td6 [2019/08/31 14:21] (Version actuelle) – modification externe 127.0.0.1 | ||
|---|---|---|---|
| Ligne 35: | Ligne 35: | ||
| ==== Doctrine repositories ==== | ==== Doctrine repositories ==== | ||
| + | Les repositories de chacun des models héritent de **MainRepository**, | ||
| - | <classDiagram> | + | <classdiagram> |
| [MainRepository|+get(); | [MainRepository|+get(); | ||
| - | </classDiagram> | + | </classdiagram> |
| + | Chaque Repository héritant de MainRepository a juste à définir dans son constructeur la classe métier auquel il correspond : | ||
| + | <sxh php; | ||
| + | <?php | ||
| + | |||
| + | namespace App\Repository; | ||
| + | |||
| + | use Symfony\Bridge\Doctrine\RegistryInterface; | ||
| + | use App\Entity\Developer; | ||
| + | |||
| + | class DeveloperRepository extends MainRepository{ | ||
| + | public function __construct(RegistryInterface $registry){ | ||
| + | parent:: | ||
| + | } | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | ==== Services Semantic ==== | ||
| + | Les services Semantic de chacun des models héritent de **SemanticGui**, | ||
| + | |||
| + | < | ||
| + | [SemanticGui|+dataTable(objects type); | ||
| + | </ | ||
| + | |||
| + | Chaque Classe Gui dérivée de **SemanticGui** doit logiquement redéfinir les méthodes **dataTable** et **dataForm**. | ||
| + | |||
| + | ==== CRUD contrôleurs ==== | ||
| + | Chaque contrôleur pilotant une classe métier hérite de **CrudController**, | ||
| + | |||
| + | {{: | ||
| + | |||
| + | * Chaque Repository héritant de MainRepository utilise les méthodes protégées de **CrudController**. | ||
| + | * Le constructeur doit initialiser par injection de dépendances une instance de **MainRepository** et de **SemanticGui** dérivées dans son constructeur. | ||
| + | <sxh php; | ||
| + | <?php | ||
| + | class DevelopersController extends CrudController{ | ||
| + | |||
| + | public function __construct(DevelopersGui $gui, | ||
| + | $this-> | ||
| + | $this-> | ||
| + | $this-> | ||
| + | $this-> | ||
| + | $this-> | ||
| + | } | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function index(){ | ||
| + | return $this-> | ||
| + | } | ||
| + | | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function refresh(){ | ||
| + | return $this-> | ||
| + | } | ||
| + | | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function edit($id){ | ||
| + | return $this-> | ||
| + | } | ||
| + | | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function add(){ | ||
| + | return $this-> | ||
| + | } | ||
| + | |||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function update(Request $request){ | ||
| + | return $this-> | ||
| + | } | ||
| + | | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function deleteConfirm($id){ | ||
| + | return $this-> | ||
| + | } | ||
| + | | ||
| + | /** | ||
| + | * @Route("/ | ||
| + | */ | ||
| + | public function delete($id, | ||
| + | return $this-> | ||
| + | } | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | ===== Fonctionnalités à implémenter ===== | ||
| + | ==== CRUD ==== | ||
| + | |||
| + | <wrap mytodo> | ||
| + | |||
| + | Pour les models **Tag**, **Step**, **Task**, ajouter les fonctionnalités de base CRUD : | ||
| + | * Listage des instances dans une table | ||
| + | * Suppression | ||
| + | * Modification | ||
| + | * Ajout | ||
| + | |||
| + | Consignes : | ||
| + | * Respecter la logique fonctionnelle et structurelle (implémentation) mise en place dans le projet initial | ||
| + | * Factoriser au mieux le code | ||
| + | |||
| + | ==== Route index ==== | ||
| + | |||
| + | <wrap mytodo> | ||
| + | |||
| + | Modifier la route **index**, pour qu' | ||
| + | |||
| + | {{: | ||