Publication du module NewsSlider 1.2b
Ce module permet d'afficher cinq blocs de type "slider" reprenant les titres d'articles du module News, et de les présenter divers effets visuels
Vous pouvez également y ajouter des images particulières, un exemple est visible dans l'image ci-dessous.

Vous pouvez télécharger ce module à partir de cette adresse.![]()
Deux extensions "Xoops" pour Google Chrome et Chromium
Le Laboratoire XooFoo.org, dans le cadre de ses actions de promotion du système de gestion de contenu Web "XOOPS", vient de créer deux extensions pour Google Chrome, l'une est similaire à la XooFooBar conçu pour Firefox, avec des liens vers les principaux sites de supports pour Xoops, les pages et groupes sur Facebook, sur Twitter, de partenaires, ainsi que les liens pertinents vers des sites d'Outils ou d'Astuces, .... ; la seconde vous permettra d'effectuer facilement des recherches sur les principaux sites de support Xoops, et principalement : FrXoops.org, Labs.XooFoo.org, TV.XooFoo.org, Xoops Project et Xuups.com.![]()
Héritage de la class xoopsForm
Héritage de la class xoopsForm
Qu'est ce que l'héritage ?
L'héritage est un principe propre à la programmation orientée objet (POO), permettant de créer une nouvelle classe à partir d'une classe existante. La nouvelle classe "hérite" des propriétés et méthodes de la classe dont elle hérite, appelée classe "mère". La classe qui hérite est appelée classe "fille".
Cette définition est très succincte vous pouvez compléter vos connaissances en programmation orienté objet sur le web, un petit lien concernant l'héritage : http://wind.developpez.com/tutoriels/windev/windev-poo-heritage/
Xoops et l'héritage
Comme tout bon projet informatique, xoops utilise la POO. En effet ses développeurs (que je remercie au passage) ont écrit un ensemble de classes qui régissent ce projet.
Donc nous pouvons utiliser l'héritage pour ajouter, modifier le comportement de XOOPS.
Tout ça, c'est très bien, mais pourquoi faire ?
- on peut modifier n'importe quelles classes directement dans le projet.
Ces modifications sont appelées des "HACKs".
C'est a ce moment précis, que vous introduisez dans votre code le grain de sable qui risque de vous miner la vie, pour l'évolution et la maintenance de votre site.
- Que vas t'il se passer à la prochaine mise à jour ? Dans 1 an.......
Plus rien ne vas fonctionner correctement, il va falloir recommencer toutes les modifica-tions une par une; Comme vous êtes un développeur compétent vous avez pris soin de consigner dans un fichier ou sur un "petit cahier" toutes les modifications à faire.
Dans le cas contraire : je vous souhaite bon courage !
L'autre solution c'est d'utiliser l'héritage, allons y !
Prenons un exemple avec un formulaire dans XOOPS.
Les formulaires dans XOOPS, bien que souvent suffisants, ne peuvent pas répondent à l'ensemble de vos besoins spécifiques.
Nous allons ici, voir 2 applications de l'héritage avec XOOPS et plus précisément avec les éléments xoopsThemeForm et xoopsElement , ce n'est que des exemples et absolument pas restrictif.
- changer l'url de action du formulaire à la volé
- ajouter un nouvel élément, pas disponible dans le projet initial
Nous partons du principe, que nous avons un module appelé myModule et que ce module tout à fait standard contient un répertoire class dans lequel nous allons pouvoir placer nos nouvelles classes.
La première chose, c'est comprendre comment sont hiérarchisées les classes qui génèrent le formulaire.
La classe XoopsForm est la classe de base du formulaire, c'est une classe abstraite, ce qui signifie que cette classe ne doit pas être utilisée directement mais qu'elle doit être étendue, généralisée. C'est en faite une sorte de gabarit, des propriétés et des méthodes.
Je vous laisse vous plonger dans la POO pour plus de détail.
La classe XoopsThemeForm est la classe qui généralise XoopSForm et qui vas afficher le formulaire sous forme de table, c'est cette classe dont nous hériterons, pour modifier le comportement général du formulaire.

Note : si nous voulons que notre formulaire ne s?affiche plus sous forme de tableau, alors il nous suffirait de partir directement de XoopsForm et refaire le travail à notre sauce; Pour ça, s'en se prendre la tête, il suffit de partir de xoopsThemeForm et de modifié la méthode render() qui est responsable de l'affichage.
Comme vous l'aurez remarqué, dans XoopsForm (voir API) la méthode render() est vide, et oui ! C'est ça une classe abstraite; Elle nous dit juste que cette méthode doit être redé-finie dans la classe qui l'étend.
Donc dans XoopsThemeForm la méthode est redéfinie pour affiché un formulaire sous forme de table :
function render()
{
$ele_name = $this->getName();
$ret = '' . NWLINE;
$ret .= $this->renderValidationJS(true);
return $ret;
} Mise en pratique
Dans notre premier exemple nous souhaitons envoyer notre formulaire à un traitement différent en fonction d'une action utilisateur.
Notre formulaire est le suivant :
// Création de l'objet formulaire
$my_form = new ThemeForm("mon formulaire", 'Form_bien', "han-dle_bien.php?action=save");
// Création des éléments de formulaire
$reference = new XoopsFormText("Référence", "reference", 50, 100);
$prix= new XoopsFormText("Prix","prix",50,100);
// Ajout des éléments au formulaire
$my_form->addElement($reference,true);
$my_form->addElement($prix, true);
// Idem pour un bouton
$button = new XoopsFormButton('', 'post', _SEND, 'submit');
$my_form->addElement($button);
// Affichage du formulaire
$my_form->display(); Jusqu'ici rien de bien sorcier ! Nous allons donc modifier le comportement de XoopsThemeForm pour cela,nous créons un fichier php dans le répertoire class, que nous nommons de manière très original : my_form.php
Nous obtenons maintenant la séquence d?héritage suivante :

Pour que cette classe hérite de XoopsThemeForm, on dit aussi pour qu'elle étend, ou en-core qu'elle généralise, on écrit en php :
class MyForm extends XoopsThemeForm{
}
?> Bien sûr pour que cela fonctionne, il faut que la classe "fille" trouve sa classe "mère", donc il faut inclure la classe XoopsThemeForm ce qui donne :
include_once(./../XoopsThemeForm.php)
class MyForm extends XoopsThemeForm{
}
?> Vous pouvez aussi utiliser xoops_load de la manière suivante :
defined('XOOPS_ROOT_PATH') or die('Restricted access');
xoops_load('XoopsThemeForm');
class MyForm extends XoopsThemeForm {} Ensuite on peut soit ajouter de nouvelles propriétés ou de nouvelles méthodes ou bien redéfinir des méthodes existantes, on dit dans ce cas "Que l'on surcharge (override) la méthode".
Nous allons ajouter à notre formulaire une nouvelle méthode, actuellement la classe XoopsThemeForm ne permet pas de changer le paramètre action du formulaire après avoir déclaré le constructeur, ce paramètre est passé au constructeur une fois pour toute; Mais on veut le modifier en fonction des actions utilisateurs et diriger le formulaire vers des traitement différents.
Nous allons donc ajouter une méthode :
xoops_load('XoopsThemeForm');
class MyForm extends XoopsThemeForm {
private $newAction;
public function setNewAction($url=null){
$url===null?$this->newAction=$this->getAction(): $this->newAction=$action;
}
}
?> Cette nouvelle méthode (appelé aussi "setter") affecte l'url a la nouvelle propriété $newAc-tion si le paramètre de la fonction est passé.
Note importante :
La classe xoopsForm, n'a pas était optimisée pour être généralisée de manière a donner a ux développeurs la possibilité de faire ce qu'ils veulent, à mon grand regret. Pour cela il aurait fallu que les propriétés de la classe xoopsForm soit "protected" et non "private" (je vous renvois à la POO) ou alors que : chaque propriété soit associée à un "setter" et à un "getter". j'ignore les raisons de cette absence.
Ceci vas nous obliger a redéfinir la fonction render(). Ceux qui n'aurait pas été obligatoire si nous avions eu des "setter" ou que les propriétés eût étées "protected"
La classe avec la fonction render() redéfinie, on remplace $this->getAction par notre nouvelle propriété $newAction, ce qui donne :
xoops_load('XoopsThemeForm');
class MyForm extends XoopsThemeForm {
private $newAction;
public function setNewAction($url=null){
$url===null?$this->newAction=$this->getAction(): $this->newAction=$action;
}
function render()
{
$ele_name = $this->getName();
$ret = '' . NWLINE;
$ret .= $this->renderValidationJS(true);
return $ret;
}
}
?> Maintenant nous pouvons l'utiliser de la manière suivante :
$my_form=new MyForm(paramètres);
If(condition){
// maintenant on change l'url du formulaire
$MyForm->setNewAction('test.php')
} Vous pouvez faire une mise à jour s'en risque......
Deuxième exemple on souhaite ajouter un élément qui n'existe pas dans les classes de XOOPS, par exemple on veut que notre formulaire affiche des images précédemment téléchargées sur le serveur, pour informer l'utilisateur.
Il n'y a pas d'élément, affiche image, dans les formulaires de XOOPS. Nous allons donc le créer en étendant la classe XoopsFormElement, qui est la classe chargée de créer un élément de formulaire, comme formcolorpicker etc....
ce qui donne comme héritage :

classe :
defined('XOOPS_ROOT_PATH') or die('Restricted access');
class MyElement extends XoopsFormElement
{
var $_content;
function __construct($caption = '', $value = '', $name = '')
{
$this->setCaption($caption);
$this->setName($name);
$this->_value = $value;
}
function setContent($content)
{
$this->_content=$content;
}
function getContent($encode=false){
return $encode ? htmlspecialchars($this->_content, ENT_QUOTES) : $this->_content;
}
function render()
{
return $this->getContent();
}
}
?> La méthode fonction setContent($content) vas nous permettre d?insérer du contenu.
- Utilisation :
$planchePhoto=new myElement();
$planchePhoto->setContent('vos photos'); Maintenant que nous avons créer un nouvel élément de formulaire , ajoutons le à notre formulaire
$my_form->addElement($planchePhoto); Voilà nous avons ajouté un élément à notre formulaire
TDMmoney 1.1
Liste des bugs corrigés :
- Bug avec les redirections (Mage)
- Il était impossible de modifier une opération dans l'administration (Mage)
- Les caractères UTF-8 ne s'affichaient pas correctement dans le PDF (Mage).
Liste des améliorations:
- La partie administration à été recodée (compatible à 100% avec xoops 2.5) (Mage)
Informations
- Voir le fichier "lang_diff.txt" pour les changements de langues..
Installation:
- Vous devez effacer le dossier "TDMMoney qui se trouve dans "modules".
- Uploader le dossier "TDMMoney" sur votre serveur dans le dossier "modules"
- Faire une mise à jour du module.
Important
Le module nécessite l'utilisation du Frameworks "ModuleClasses" pour fonctionner.
Le module travail uniquement sur xoops 2.5x
Téléchargement
TDMmoney 1.1 et sa traduction française![]()
APCal mis à jour à la version 2.0.3
La traduction espagnol est maintenant complète.
Nous avons également amélioré la boîte descriptive dans la vue mensuelle afin qu'elle ne dépasse pas les limites de la fenêtre du navigateur.
De plus, nous avons corrigé a petit bug lors de l'insertion d'un évènement.![]()
Trois nouveaux thèmes gratuit pour Xoops
Ces thèmes se composent de 3 colonnes et sont compatibles avec Internet explorer, Firefox, Safari, Chrome et Opera.
XDGrey est basé sur le thème défaut et du template templatemo_162_gray_company.

Téléchargement : à cette adresse et en action : sur ce site.
XDClassified est basé sur le thème défaut et du template Classified

Téléchargement : à cette adresse et en action : sur ce site
XDBlack_wall est basé sur le thème défaut et du template templatemo_335_black_wall.

Téléchargement : à cette adresse, et en action : sur ce site.![]()
XDTazer : Template GRATUIT pour Xoops
Xoops demo vous présente l'adaptation d'un nouveau thème pour Xoops nommé XDTazer
Voici un nouveau template Réalisé avec le gabarit default et le PSD de myjilson.Il dispose de 2 colonnes (une à gauche ou a droite ).

Vous pouvez utiliser ce thème avec xoops 2.4.5 et 2.5.x
Visible ici
Téléchargeable ici
APCal v2.0.2 Final - Calendrier avec carte pour XOOPS 2.4 / 2.5
APCal est un module vous permettant d'afficher un calendrier d'événements avec une carte sur votre site web. Plusieurs autres caractéristiques ont été ajoutés, optionnelles pour la plupart. Ce module est basé sur PiCal.
Ce module va copier vos données de PiCal pour une transition simple.
Cette version est un grand pas en avant depuis la version 1.
Visiter http://xoops.antiquepromotion.com pour le télécharger !
NOUVELLES CARACTÉRISTIQUES :
- Événements sur une ligne (au lieu de le répéter chaque jour) dans la vue mensuelle.
- Images miniatures et visualisateur dans la vue événementielle.
- Nouveaux champs pour le courriel et le site web.
- Chaque catégorie possède une couleur.
- Légende des catégories avec couleurs associées.
- Couleurs par défaut plus neutre pour une meilleure intégration.
- Réorganisation de l'interface administrateur.
- Bouton "parlez-en à un ami".
- Boutons de partage sur les principaux réseaux sociaux (Facebook, Twiter, Google+, LinkedIn, Delicious).
- Option : Ajouter des photos à un événement avec une image principale.
- Option : Choisir une catégorie principale pour chaque événement.
- Option : Choisir des heures différentes pour chaque jour d'un événement (s'il est sur plusieurs jours).
Veuillez reporter tout problèmes rapidement sur xoops.antiquepromotion.com ou ici.
Nous allons essayer d'avoir une version RC d'ici une semaine.
Caractéristiques originales :
- Marqueurs contenant la date de l'événement sur la carte.
- Optimisé pour Google (titre et description).
- Possibilité d'ajouter une description en HTML pour chaque catégorie.
- Amélioration de la personnalisation du thème.
- Option : Carte affichant tous les événements.
- Option : Carte affichant l'emplacement de l'événement spécifié.
- Option : Afficher le titre de la catégorie en H1.
- Option : API qui permet à vos utilisateurs d'afficher votre calendrier sur leur site (Avec un lien vers votre site).
- Option : Menu de navigation permettant de naviguer à travers les événements.
- Option : Colonnes plus larges pour les jours spécifiés.
- Option : Calendrier perpétuel des fêtes nationales (Uniquement pour les États-Unis (EN), le Canada (EN), le Québec (FR) et la France (FR).
- Option : Réécriture d'URL (si le serveur le permet).
- 4 vues différentes (Journalière, hebdomadaire, mensuelle et annuelle).
- Les utilisateurs peuvent ajouter des événements si les permissions le permettent.
- Exportation et importation au format ICS.
Flux RSS
Rubrique Flux RSS Cms - Nb abonnés : 7
| Adresse du flux RSS à copier/coller |





xoops france