暂无描述

julien.legrand 98a0893ab1 NEW correctif et mise à jour du Readme après test réel 9 年之前
CD67.ModeleMVC.Entity 4186ced43f NEW Ajout de l'exemple Viking avec table liée pour le type 9 年之前
CD67.ModeleMVC.Factory 98a0893ab1 NEW correctif et mise à jour du Readme après test réel 9 年之前
CD67.ModeleMVC.MVC 3171e279ea NEW Ajout d'un Helper pour DescriptionFor 9 年之前
CD67.ModeleMVC.Tests b92d27af27 FIX Connexion du modèle à la BDD ok 9 年之前
.gitattributes 93b0e6952b NEW initial commit 9 年之前
.gitignore 93b0e6952b NEW initial commit 9 年之前
CD67.ModeleMVC.sln 262e0c372c NEW Controller Entity ok, passage à Factory à faire 9 年之前
README.md 98a0893ab1 NEW correctif et mise à jour du Readme après test réel 9 年之前

README.md

Mode d'emploi du projet modle MVC-entity

Historique

v0.1 19/07/2016 (Julien Legrand) : 1re version

Dmarrage d'un nouveau projet avec le modle : pas--pas

  1. GIT 1.1. Cloner le projet modle dans le dossier de votre choix : "git clone [adresse du projet]" faire dans le dossier parent (le dossier CD67.ModeleMVC sera cr automatiquement) 2.2. Renommer le dossier du projet avec le nom de votre choix 2.3. Supprimer le sous-dossier cach ".git" la racine du projet pour supprimer le lien avec le projet modle 2.4. Initialiser un nouveau dpt GIT : "git init" faire dans le dossier du projet 2.5. C'est le bon moment pour faire un premier commit : "git commit -m "NEW Reprise du projet modle"" 2.6. Ajout de la rfrence du repository en ligne : "git remote add origin [adresse du nouveau projet]" 2.7. 1er envoi sur le serveur : "git push --set-upstream origin master" (par la suite, "git push" suffira)

  2. Renommer et exctuer la maquette : 2.1. Renommer la solution et les projets en suivant ce schma : "CD67.[nom appli].[Entity/Factory/MVC/Tests/Batchs]" 2.2. Renommer galement les assemblies et espaces de nom de chaque projet (dans les proprits des projets, onglet "Application") 2.3. Quitter Visual Studio 2.4. Supprimer si ncessaire tous les fichiers commencant par "CD67.ModeleMVC.*" dans les dossiers suivants : "\CD67.Toto.MVC\bin", "\CD67.Toto.Factory\bin\Debug", "\CD67.Toto.Entity\bin\Debug", "CD67.Toto.Tests\bin\Debug" 2.5. Modifier le noms des dossiers des projets en consquence et modifier le chemin des fichiers projets dans le fichier solution *.sln 2.4. Ouvrir nouveau la solution et faire un rechercher/remplacer global la solution pour remplacer "CD67.ModeleMVC" par "CD67.[nom appli]" 2.5. Nettoyer et rgnere la solution 2.6. Excuter l pour contrler qu'elle fonctionne correctement ce stade avec les donnes de tests 2.7. Noter dans le code les exemples disposition 2.8. Un petit commit avant de continuer : "git commit -m "NEW Renommage du projet modle""

  3. Nouvelle connexion : 2.1. Mettre jour la chaine de connexion "Entities" dans les fichiers : "CD67.Toto.Entity\App.config" et "CD67.Toto.MVC\Web.config" 2.2. Option : il est possible d'ajouter une projet de type base de donnes pour grer votre base de donnes dans la mme solution (en vous connectant avec la chaine de connexion mis jour au point prcdent) 2.3. Ouvrer le model Entity : "CD67.Toto.Entity\EntityModel.edmx" et supprimer les tables d'exemples 2.4. Supprimer les classes partielles d'exemple : "CD67.ModeleMVC.Entity\Extend\EXEMPLE_VIKINGS.cs" et "CD67.ModeleMVC.Entity\Extend\EXEMPLE_TYPE_VIKING.cs" 2.5. Supprimer les fichiers "Factory" d'exemple : "CD67.ModeleMVC.Factory\VIKINGSFactory.cs" et "CD67.ModeleMVC.Factory\TYPE_VIKINGFactory.cs" 2.6. Supprimer les contrleurs et vues d'exemple dans : "CD67.ModeleMVC.MVC\Controllers" et "CD67.ModeleMVC.MVC\Views" 2.7. C'est le moment du commit : "git commit -m "NEW Fin de l'initialisation du projet modle"" 2.8. A ce stade le nouveau projet est prt rellement dmarrer, on crer donc une nouvelle branche "develop" : "git branch develop" et "git checkout develop" 2.9. On pousse la nouvelle branche en ligne : "git push --set-upstream origin develop" (par la suite, "git push" suffira)

  4. Dmarrage du nouveau projet : 3.1. Mettre jour le modle par rapport la base de donnes pour ajouter de nouvelles tables et vues ncessaire l'application 3.2. Vrifier les types des entits gnres depuis la base de donnes, particulirement les chiffres et cls en numro auto ou avec un trigger/sequence Oracle (le champ "StoreGeneratedPattern" doit tre gal "Identity" pour les cls automatiques) 3.3. Crer vos propres fichiers d'extension avec DataAnnotation ici : "CD67.ModeleMVC.Entity\Extend" 3.4. Crer vos propres factory ici : "CD67.ModeleMVC.Factory" 3.5. Crer vos propres controller/vues ici : "CD67.ModeleMVC.MVC\Controllers" et "CD67.ModeleMVC.MVC\Views" (NOTE : personellement j'utilise la cration du controller le modle "Contrleur MV5 avec vues, utilisant Entity Framework" en gnrant les vues et avec la page de disposition que je souhaite, ensuite je modifie le code du contrleur pour utiliser les classes "Factory") 3.7. Modifier le fichier "CD67.ModeleMVC.MVC\App_Start\RouteConfig.cs" par rapport vos contrleurs et variables ncessaires 3.8. Ajout des tests unitaires pour tester les fonctions principales dans le projet ddi "CD67.ModeleMVC.Tests" (CRUD sur les classes, processus complet, etc.) 3.9. On fait des commits chaque avance majeure, on fait une fusion avec la branche "master" ds que l'outil est en production, puis son continue les dveloppements sur "develop"

  5. Supprimer ce fichier la fin pour ne pas que l'on sache que vous avez utilis un modle :p

Description gnrale

La solution est consitue de 4 projets :

  • CD67.ModeleMVC.Entity : Projet qui contient les objets mtiers, c'est dire dans le cas de projets Entity : le modle entity framework
  • CD67.ModeleMVC.Factory : Projet qui contient les classes permettant la gestion des objets : les actions CRUD pour chacun minima
  • CD67.ModeleMVC.MVC : Projet qui comprend le site Web MVC, les packages Bootstrap et FontAwesome sont dj installs
  • CD67.ModeleMVC.Tests : Tests unitaires

Description du projet : CD67.ModeleMVC.Entity

Le modle se nomme par dfaut "EntityModel". Pour se connecter la base de donnes afin de faire voluer le modle, il faut utiliser la connexion "OracleConnection (CD67.ModeleMVC.MVC)".

Le dossier "Extend" contient les extensions ventuelles de classe Entity (qui se trouvent dans "EntityModel.edmx\EntityModel.tt\"). C'est notamment utile pour ajouter les DataAnnotations permettant de dcrire le donnes en vue d'une gnration de contrles plus appropis dans les vues MVC. Attention bien surveiller l'espace de noms lors de la cration d'une classe dans ce sous-dossier (erreur frquente) :

  • par dfaut ce sera : "CD67.ModeleMVC.Entity.Extend",
  • mais il faut "CD67.ModeleMVC.Entity" (le mme que les classes de bases Entity).

Le dossier "Internal" contient :

  • "FormattedDbEntityValidationException.cs" : classe hrite de Exception qui permet un affichage plus complet dans les messages d'erreur pour les exceptions lies au format de donnes du modle Entity
  • "Entities.cs" : classe partielle permettant d'utiliser les nouvelles Exceptions FormattedDbEntityValidationException en surchargeant "SaveChanges()" En cas d'ajout d'une nouvelle connexion avec Entity Framework, il faut ajouter une nouvelle classe d'extension du mme type.

Description du projet : CD67.ModeleMVC.Factory

Les classes Factory sont nommes ainsi : "[Nom objet]Factory" On cre autant de classe Factory que d'objet grer Elles doivent contenir un constructeur public avec le context Entities en paramtre qui se base sur le constructeur de la classe parente. Elles contiennent gnralement les fonctions suivantes : getById, getAll, add, update, delete. C'est adapter chaque cas.

Le dossier "Internal" contient la classe de base "baseFactory" dont chaque "Factory" hrite.

Description du projet : CD67.ModeleMVC.MVC

La partie Model du projet n'est pas ncessaire que pour dfinir des classes ne servant qu' l'affichage, les classes mtiers tant dans le projet Entity.

Le dossier "Views" contient par dfaut :

  • "Shared_AppLayout.cshtml" : une page de disposition pour l'application
  • "DisplayTemplates\YesNo.cshtml" et "EditorTemplates\YesNo.cshtml" : ils s'agit d'exemple de personnalisation d'affichage pour un type de champ, ici "YesNo". On attribut un type avec la DataAnnotation "[UIHint("YesNo")]" dans la classe Metadata et ce sont les fichiers dans DisplayTemplates et EditorTemplates du mme nom qui seront utiliss pour crer le contrle l'affichage.

Le dossier "style" contient :

  • un sous dossier "images" destin contenir toutes les images utilises dans la mise en page
  • "AppStyleSheet.css" : feuille de style modifier pour le projet courant
  • "ModeleStyleSheet.css" : feuille de style du modle CD67 ne pas modifier

Les scripts et styles sont chargs l'aide des commandes : "@Scripts.Render("~/bundles/jquery")", "@Scripts.Render("~/bundles/bootstrap")" et "@Styles.Render("~/Content/css")". La configuration de ceci se trouve dans ce fichier : "App_Start\BundleConfig.cs"

Les Glyphicons Bootstrap sont ici : http://getbootstrap.com/components/#glyphicons Et les icnes FontAwesome l : http://fontawesome.io/icons/

Le dossier "Internal" contient du code permettant l'ajout de la commande "@Html.DescriptionFor" dans les vues.

Description du projet : CD67.ModeleMVC.Tests

Projet le plus important de la solution :)