SP:Composant:Module

De Hegyd Doc.

(Différences entre les versions)
(base de données)
(Autres éléments associés)
Ligne 41 : Ligne 41 :
=== Autres éléments associés ===
=== Autres éléments associés ===
-
* pages & contenu
+
* pages & contenu, définies via [[SP:Part:Modules|l'interface d'aministration des modules]].
-
* type de blocObject
+
* type de blocObject ([[SP:Composant:BlocObject#D.C3.A9finition_des_types_de_blocObject|méthodologie pour créer des types de blocObject]]).
* propriétés de styles
* propriétés de styles
* pages d'administration permettant d'administrer le module
* pages d'administration permettant d'administrer le module
-
 
==Activation / Désactivation ==
==Activation / Désactivation ==

Version du 16 juillet 2010 à 12:32

Sommaire

Les modules

Un module permet d'étendre les fonctionnalités primaire de l'éditeur, en ajoutant par exemple un système de gestion d'actualités, ou un support e-commerce.

Implémentation

base de données

Le module est enregistré dans la table module, ses champs:

  • moduleId: identifiant
  • modeleName: nom du module
  • modeuleCleanedName: nom du module sans caractères spéciaux. Servira pour nommer les répertoires associés.
  • siteOptions: s'il est rélié avec une option lié au packages.

Il est lié à un site par le bias d'une table de jointure jModule_SiteClient, ses champs:

  • moduleId
  • siteClientId
  • status: indique s'il est activé pour le client ou non.


Une autre table permet de définir les pages qui devront être associées au module modulePages, ses champs:

  • modulePageId: identifiant
  • moduleId: identifiant du module
  • modulePageName: nom de la page
  • urlPattern: expression réulière permettant de reconnaitre la page à partir d'une url


Le module pourra également avoir ses propres tables. Elle devront toutes être préfixées par {moduleCleanedName}.

Classes

La classe Module contient les méthode génériques de gestion des modules.

Chaque module dispose ensuite de sa propre classe, nommée {moduleCleanedName}.

D'autres classes peuvent être associées au modules. Elle devront se trouver dans le répertoire lib/model/EasySite/modules/{moduleCLeanedName}/ dans un fichier {moduleCleandName}_ClassName.php et se nommer {moduleCleandName}_ClassName.

Autres éléments associés

Activation / Désactivation