From 3736c2ebc9c527916c03730e8fe4fd78f7f81358 Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Sun, 5 Jan 2025 17:58:54 +0100 Subject: [PATCH 01/14] suscribe 2.6 --- module/suscribe/changes.md | 24 +- module/suscribe/enum.json | 2 +- module/suscribe/profil/main/add.inc.php | 16 +- module/suscribe/profil/main/edit.inc.php | 16 +- module/suscribe/profil/view/add.inc.php | 38 +- module/suscribe/profil/view/edit.inc.php | 50 +- module/suscribe/suscribe.php | 1011 ++++++++++---------- module/suscribe/view/config/config.css | 40 +- module/suscribe/view/config/config.php | 204 ++-- module/suscribe/view/edit/edit.css | 42 +- module/suscribe/view/edit/edit.js.php | 60 +- module/suscribe/view/edit/edit.php | 286 +++--- module/suscribe/view/index/index.css | 72 +- module/suscribe/view/index/index.js.php | 94 +- module/suscribe/view/index/index.php | 56 +- module/suscribe/view/users/users.css | 32 +- module/suscribe/view/users/users.js.php | 40 +- module/suscribe/view/users/users.php | 28 +- module/suscribe/view/validate/validate.css | 66 +- module/suscribe/view/validate/validate.php | 44 +- 20 files changed, 1118 insertions(+), 1103 deletions(-) diff --git a/module/suscribe/changes.md b/module/suscribe/changes.md index ca7f9f2..697608f 100644 --- a/module/suscribe/changes.md +++ b/module/suscribe/changes.md @@ -1,11 +1,15 @@ -# Version 2.4 -- L'approbation par un administrateur initialise le pseudo avec l'id de l'utilisateur. -# Version 2.3 -- Warning lors de la saisie d'un email vide -# Version 2.2 -- Ajoute la gestion des profils -# Version 2.1 -- N'envoie pas d'email lorsque le domaine est invalide. -- Corrige la validation de domaines multiples séparés par des points virgules. -# Version 2.0 +# Version 2.6 +- Corrige d'un bug empêchat de terminer la procédure d'inscription après approbation. +# Version 2.5 +- Reformatage du formulaire d'approbation pour mettre en avant les actions à réaliser par l'administrateur. +# Version 2.4 +- L'approbation par un administrateur initialise le pseudo avec l'id de l'utilisateur. +# Version 2.3 +- Warning lors de la saisie d'un email vide +# Version 2.2 +- Ajoute la gestion des profils +# Version 2.1 +- N'envoie pas d'email lorsque le domaine est invalide. +- Corrige la validation de domaines multiples séparés par des points virgules. +# Version 2.0 - trop de corrections. \ No newline at end of file diff --git a/module/suscribe/enum.json b/module/suscribe/enum.json index ef1e069..06b7bb0 100644 --- a/module/suscribe/enum.json +++ b/module/suscribe/enum.json @@ -1 +1 @@ -{"name":"suscribe","realName":"Auto Inscription","version":"2.4","update":"0.0","delete":true,"dataDirectory":""} \ No newline at end of file +{"name":"suscribe","realName":"Auto Inscription","version":"2.6","update":"0.0","delete":true,"dataDirectory":""} \ No newline at end of file diff --git a/module/suscribe/profil/main/add.inc.php b/module/suscribe/profil/main/add.inc.php index 5cb3714..0b11c96 100644 --- a/module/suscribe/profil/main/add.inc.php +++ b/module/suscribe/profil/main/add.inc.php @@ -1,9 +1,9 @@ - $this->getInput('profilAddSuscribeEdit', helper::FILTER_BOOLEAN), - 'delete' => $this->getInput('profilAddSuscribeDelete', helper::FILTER_BOOLEAN), - 'user' => $this->getInput('profilAddSuscribeUser', helper::FILTER_BOOLEAN), - 'config' => $this->getInput('profilAddSuscribeAdd', helper::FILTER_BOOLEAN) || - $this->getInput('profilAddSuscribeEdit', helper::FILTER_BOOLEAN) || - $this->getInput('profilAddSuscribeDelete', helper::FILTER_BOOLEAN) || - $this->getInput('profilAddSuscribeUser', helper::FILTER_BOOLEAN) + $this->getInput('profilAddSuscribeEdit', helper::FILTER_BOOLEAN), + 'delete' => $this->getInput('profilAddSuscribeDelete', helper::FILTER_BOOLEAN), + 'user' => $this->getInput('profilAddSuscribeUser', helper::FILTER_BOOLEAN), + 'config' => $this->getInput('profilAddSuscribeAdd', helper::FILTER_BOOLEAN) || + $this->getInput('profilAddSuscribeEdit', helper::FILTER_BOOLEAN) || + $this->getInput('profilAddSuscribeDelete', helper::FILTER_BOOLEAN) || + $this->getInput('profilAddSuscribeUser', helper::FILTER_BOOLEAN) ]; \ No newline at end of file diff --git a/module/suscribe/profil/main/edit.inc.php b/module/suscribe/profil/main/edit.inc.php index 2cf314a..f2d138c 100644 --- a/module/suscribe/profil/main/edit.inc.php +++ b/module/suscribe/profil/main/edit.inc.php @@ -1,9 +1,9 @@ - $this->getInput('profilEditSuscribeEdit', helper::FILTER_BOOLEAN), - 'delete' => $this->getInput('profilEditSuscribeDelete', helper::FILTER_BOOLEAN), - 'user' => $this->getInput('profilEditSuscribeUser', helper::FILTER_BOOLEAN), - 'config' => $this->getInput('profilEditSuscribeAdd', helper::FILTER_BOOLEAN) || - $this->getInput('profilEditSuscribeEdit', helper::FILTER_BOOLEAN) || - $this->getInput('profilEditSuscribeDelete', helper::FILTER_BOOLEAN) || - $this->getInput('profilEditSuscribeUser', helper::FILTER_BOOLEAN) + $this->getInput('profilEditSuscribeEdit', helper::FILTER_BOOLEAN), + 'delete' => $this->getInput('profilEditSuscribeDelete', helper::FILTER_BOOLEAN), + 'user' => $this->getInput('profilEditSuscribeUser', helper::FILTER_BOOLEAN), + 'config' => $this->getInput('profilEditSuscribeAdd', helper::FILTER_BOOLEAN) || + $this->getInput('profilEditSuscribeEdit', helper::FILTER_BOOLEAN) || + $this->getInput('profilEditSuscribeDelete', helper::FILTER_BOOLEAN) || + $this->getInput('profilEditSuscribeUser', helper::FILTER_BOOLEAN) ]; \ No newline at end of file diff --git a/module/suscribe/profil/view/add.inc.php b/module/suscribe/profil/view/add.inc.php index c8d40b5..38f39ed 100644 --- a/module/suscribe/profil/view/add.inc.php +++ b/module/suscribe/profil/view/add.inc.php @@ -1,20 +1,20 @@ -
-
-
-

- -

-
-
- -
-
- -
-
- -
-
-
-
+
+
+
+

+ +

+
+
+ +
+
+ +
+
+ +
+
+
+
\ No newline at end of file diff --git a/module/suscribe/profil/view/edit.inc.php b/module/suscribe/profil/view/edit.inc.php index 68415aa..db36b39 100644 --- a/module/suscribe/profil/view/edit.inc.php +++ b/module/suscribe/profil/view/edit.inc.php @@ -1,26 +1,26 @@ -
-
-
-

- · -

-
-
- $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'edit']) - ]); ?> -
-
- $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'delete']) - ]); ?> -
-
- $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'user']) - ]); ?> -
-
-
-
+
+
+
+

+ · +

+
+
+ $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'edit']) + ]); ?> +
+
+ $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'delete']) + ]); ?> +
+
+ $this->getData(['profil', $this->getUrl(2), $this->getUrl(3), 'suscribe', 'user']) + ]); ?> +
+
+
+
\ No newline at end of file diff --git a/module/suscribe/suscribe.php b/module/suscribe/suscribe.php index 035b3c1..91f7a88 100755 --- a/module/suscribe/suscribe.php +++ b/module/suscribe/suscribe.php @@ -1,504 +1,507 @@ - - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -class suscribe extends common -{ - - const VERSION = '2.4'; - const REALNAME = 'Auto Inscription'; - const DELETE = true; - const UPDATE = '0.0'; - const DATADIRECTORY = ''; // Contenu localisé inclus par défaut (page.json et module.json) - - const STATUS_EMAIL_AWAITING = 0; - const STATUS_EMAIL_VALID = 1; - const STATUS_ACCOUNT_AWAITING = 2; - const STATUS_ACCOUNT_VALID = 3; - public static $statusGroups = [ - self::STATUS_EMAIL_AWAITING => 'Email non confirmé', - self::STATUS_EMAIL_VALID => 'Email valide', - self::STATUS_ACCOUNT_AWAITING => 'Email valide, en attente de confirmation', - self::STATUS_ACCOUNT_VALID => 'Email valide, compte activé', - ]; - - public static $actions = [ - 'index' => self::GROUP_VISITOR, - 'validate' => self::GROUP_VISITOR, - 'config' => self::GROUP_EDITOR, - 'users' => self::GROUP_EDITOR, - 'delete' => self::GROUP_EDITOR, - 'edit' => self::GROUP_EDITOR - ]; - - public static $layout = [ - 'inputRowContainer1' => 'Un élément par ligne', - 'inputRowContainer2' => 'Deux éléments par ligne', - 'inputRowContainer4' => 'Quatre éléments par ligne', - ]; - - public static $timeLimit = [ - 2 => '2 minutes', - 5 => '5 minutes', - 10 => '10 minutes' - ]; - - public static $users = []; - - public static $groups = []; - public static $userProfils = []; - public static $userProfilsComments = []; - - /** - * Liste des utilisateurs en attente - */ - public function users() - { - $userIdsFirstnames = helper::arraycollumn($this->getData(['module', $this->getUrl(0), 'users']), 'firstname'); - ksort($userIdsFirstnames); - foreach ($userIdsFirstnames as $userId => $userFirstname) { - self::$users[] = [ - $userId, - $userFirstname . ' ' . $this->getData(['module', $this->getUrl(0), 'users', $userId, 'lastname']), - self::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $userId, 'status'])], - helper::dateUTF8(date('Y-m-d G:i'), $this->getData(['module', $this->getUrl(0), 'users', $userId, 'timer'])), - template::button('registrationUserEdit' . $userId, [ - 'href' => helper::baseUrl() . $this->getUrl(0) . '/edit/' . $userId, - 'value' => template::ico('pencil') - ]), - template::button('registrationUserDelete' . $userId, [ - 'class' => 'userDelete red', - 'href' => helper::baseUrl() . $this->getUrl(0) . '/delete/' . $userId, - 'value' => template::ico('cancel') - ]) - ]; - } - // Valeurs en sortie - $this->addOutput([ - 'title' => 'Inscription en attente', - 'view' => 'users' - ]); - } - - - /** - * Édition - */ - public function edit() - { - if ( - $this->getUser('permission', __CLASS__, __FUNCTION__) !== true - ) { - // Valeurs en sortie - $this->addOutput([ - 'access' => false - ]); - } - // Accès refusé - if ( - // L'utilisateur n'existe pas - $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]) === null - // Droit d'édition - and ( - // Impossible de s'auto-éditer - ( - $this->getUser('id') === 'user' - and $this->getUrl('group') <= self::GROUP_VISITOR - ) - // Impossible d'éditer un autre utilisateur - or ($this->getUrl('group') < self::GROUP_EDITOR) - ) - ) { - // Valeurs en sortie - $this->addOutput([ - 'access' => false - ]); - } - // Accès autorisé - else { - // Soumission du formulaire - if ( - $this->getUser('permission', __CLASS__, __FUNCTION__) === true - && $this->isPost() - ) { - // Créer le user dans la base - $this->setData([ - 'user', - $this->getUrl(2), - [ - 'firstname' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'firstname']), - 'forgot' => 0, - 'group' => $this->getInput('registrationUserEditGroup', helper::FILTER_INT), - // Le profil vaut 0 pour les amdins et 1 pour les autres membres, profil par défaut. - 'profil' => $this->getInput('registrationUserEditGroup', helper::FILTER_INT) === self::GROUP_ADMIN - ? 0 : 1, - 'lastname' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'lastname']), - 'mail' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'mail']), - 'password' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'password']), - 'tags' => $this->getInput('registrationUserLabel', helper::FILTER_STRING_SHORT), - 'connectFail' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'connectFail']), - 'connectTimeout' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'connectTimeout']), - 'accessUrl' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'accessUrl']), - 'accessTimer' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'accessTimer']), - 'accessCsrf' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'accessCsrf']) - ] - ]); - // Notifier le user uniquement si le groupe est membre au moins membre - if ($this->getInput('registrationUserEditGroup') >= 1) { - $this->sendMail( - $this->getData(['module', $this->getUrl(0), 'users', 'mail']), - 'Approbation de l\'inscription', - '

' . $this->getdata(['module', $this->getUrl(0), 'config', 'mailValidateContent']) . '

', - null, - $this->getData(['config', 'smtp', 'from']) - ); - } - // Supprimer le user de la base temporaire, - $this->deleteData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]); - // Valeurs en sortie - $this->addOutput([ - 'redirect' => helper::baseUrl() . $this->getUrl(0) . '/users', - 'notification' => 'Modifications enregistrées', - 'state' => true - ]); - } - // Changement temporaire de libellé du groupe 0 - self::$groups = self::$groupEdits; - self::$groups[self::GROUP_BANNED] = 'En attente d\'approbation'; - - // Profils disponibles - foreach ($this->getData(['profil']) as $profilId => $profilData) { - if ($profilId < self::GROUP_MEMBER) { - continue; - } - if ($profilId === self::GROUP_ADMIN) { - self::$userProfils[$profilId][self::GROUP_ADMIN] = $profilData['name']; - self::$userProfilsComments[$profilId][self::GROUP_ADMIN] = $profilData['comment']; - continue; - } - foreach ($profilData as $key => $value) { - self::$userProfils[$profilId][$key] = $profilData[$key]['name']; - self::$userProfilsComments[$profilId][$key] = $profilData[$key]['name'] . ' : ' . $profilData[$key]['comment']; - } - } - - // Valeurs en sortie - $this->addOutput([ - 'title' => $this->getData(['module', $this->getUrl(0), 'users', 'firstname']) . ' ' . $this->getData(['user', $this->getUrl(0), 'lastname']), - 'view' => 'edit' - ]); - } - } - - - /** - * Suppression - */ - public function delete() - { - // Accès refusé - if ( - // L'utilisateur n'existe pas - $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]) === null - // Groupe insuffisant - && $this->getUser('permission', __CLASS__, __FUNCTION__) !== true - ) { - // Valeurs en sortie - $this->addOutput([ - 'access' => false - ]); - } - // Suppression - else { - $this->deleteData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]); - // Valeurs en sortie - $this->addOutput([ - 'redirect' => helper::baseUrl() . $this->getUrl(0) . '/users', - 'notification' => 'Utilisateur supprimé', - 'state' => true - ]); - } - } - - - /** - * Ajout - */ - public function index() - { - /** - * Traitement du formulaire - * Stocke les données du formulaire dans le module - * Envoie le mail de vérification de l'email - */ - // Soumission du formulaire - if ($this->isPost()) { - // Contrôler la validité du domaine saisi parmi les domaines valides - $email_to_check = $this->getInput('registrationAddMail', helper::FILTER_MAIL, true); - // Le domaine saisi est invalide si un filtre existe - if ( - empty($this->getData(['module', $this->getUrl(0), 'config', 'filter'])) === true && - empty($email_to_check) === true - ) { - - - // Récupérer la liste des domaines valides depuis la configuration et supprimer les espaces autour - $filter = trim($this->getData(['module', $this->getUrl(0), 'config', 'filter'])); - - // Vérifier si la liste contient plusieurs domaines ou un seul, puis supprimer les espaces pour chaque domaine - $valid_domains = strpos($filter, ';') === false - ? [trim($filter)] // Si un seul domaine, on supprime les espaces et on le met dans un tableau - : array_map('trim', explode(';', $filter)); // Si plusieurs domaines, on les explose en tableau et supprime les espaces - - // Extraire le domaine de l'adresse email à vérifier - $email_domain = explode('@', $email_to_check)[1]; - - // Vérifier si le domaine de l'email est dans la liste des domaines valides - if (!in_array($email_domain, $valid_domains)) { - self::$inputNotices['registrationAddMail'] = 'Ce domaine n\'est pas autorisé'; - } - - } - // Email valide, on continue le traitement - if (self::$inputNotices === []) { - // Drapeau de contrôle des données saisies. - $check = true; - $sentMailtoUser = false; - // L'identifiant d'utilisateur est indisponible - $userId = $this->getInput('registrationAddId', helper::FILTER_ID, true); - if (is_array($this->getData(['user', $userId]))) { - self::$inputNotices['registrationAddId'] = 'Identifiant invalide'; - $check = false; - } - // Le compte existe déjà - foreach ($this->getData(['user']) as $usersId => $user) { - if ($user['mail'] === $this->getInput('registrationAddMail', helper::FILTER_MAIL, true)) { - self::$inputNotices['registrationAddMail'] = 'Vous ne pouvez pas utilisez cette boite mail'; - $check = false; - break; - } - } - // Données de l'utilisateur - $userFirstname = $this->getInput('registrationAddFirstname', helper::FILTER_STRING_SHORT, true); - $userLastname = $this->getInput('registrationAddLastname', helper::FILTER_STRING_SHORT, true); - $userMail = $this->getInput('registrationAddMail', helper::FILTER_MAIL, true); - // Pas de nom saisi - if ( - empty($userFirstname) || - empty($userLastname) - ) { - $check = false; - } - // Si tout est ok - if ($check === true) { - // Enregistrement du compte dans les données du module - $auth = uniqid('', true); - $this->setData([ - 'module', - $this->getUrl(0), - 'users', - $userId, - [ - 'firstname' => $userFirstname, - 'lastname' => $userLastname, - 'mail' => $userMail, - 'password' => '', - // pas de groupe afin de le différencier dans la liste des users - 'timer' => time(), - 'pseudo' => $userId, - 'auth' => $auth, - 'status' => self::STATUS_EMAIL_AWAITING - ] - ]); - // Mail d'avertissement aux administrateurs - // Utilisateurs dans le groupe admin - $to = []; - foreach ($this->getData(['user']) as $key => $user) { - if ($user['group'] == self::GROUP_ADMIN) { - $to[] = $user['mail']; - } - } - // Envoi du mail à l'administrateur - if ($check && is_array($to)) { - $this->sendMail( - $to, - 'Auto-inscription sur le site ' . $this->getData(['config', 'title']), - '

Un nouveau membre s\'est inscrit, son email est en attente de validation

' . - '

Identifiant du compte : ' . $userId . ' (' . $userFirstname . ' ' . $userLastname . ')
' . - 'Email : ' . $userMail . '

' . - 'Validation de l\'inscription', - null, - $this->getData(['config', 'smtp', 'from']) - ); - } - - // Mail de confirmation à l'utilisateur - // forger le lien de vérification - $validateLink = helper::baseUrl(true) . $this->getUrl() . '/validate/' . $userId . '/' . $auth; - // Envoi - if ($check) { - $sentMailtoUser = $this->sendMail( - $userMail, - 'Confirmation de votre inscription', - '

' . $this->getdata(['module', $this->getUrl(0), 'config', 'mailRegisterContent']) . '

' . - '

Activer votre compte' . '

' . - '

ou copiez collez le lien suivant dans un navigateur : ' . $validateLink . '

' - , - null, - $this->getData(['config', 'smtp', 'from']) - ); - } - } - // Valeurs en sortie - $this->addOutput([ - 'redirect' => helper::baseUrl(), - //'redirect' => $validateLink, - 'notification' => $sentMailtoUser ? "Un mail vous a été envoyé." : 'Quelque chose n\'a pas fonctionné !', - 'state' => $sentMailtoUser ? true : false - ]); - } - } - // Valeurs en sortie - $this->addOutput([ - 'title' => 'Inscription', - 'view' => 'index', - 'showBarEditButton' => true, - 'showPageContent' => true - ]); - } - - /** - * Vérification de l'email - */ - public function validate() - { - // Soumission du formulaire - if ($this->isPost()) { - // Vérifie la session + l'id + le timer - $check = true; - $notification = 'Bienvenue sur le site ' . $this->getData(['config', 'title']); - $userId = $this->getUrl(2); - $auth = $this->getUrl(3); - // la validité du lien est dépassé - if ( - (time() - $this->getData(['module', $this->getUrl(0), 'users', $userId, 'timer'])) - >= $this->getdata(['module', $this->getUrl(0), 'config', 'timeOut']) - ) { - $check = false; - $notification = 'La validité du lien est dépassée'; - } - // La clé est incorrecte ou le compte n'est pas en attente de validation - if ( - $check - && $auth !== $this->getData(['module', $this->getUrl(0), 'users', $userId, 'auth']) - && $this->getData(['module', $this->getUrl(0), 'users', $userId, 'status']) !== self::STATUS_EMAIL_AWAITING - ) { - $check = false; - $notification = 'Données incorrectes !'; - } - // Double vérification pour le mot de passe - if ( - $check - && $this->getInput('registrationValidPassword', helper::FILTER_STRING_SHORT, true) !== $this->getInput('registrationValidConfirmPassword', helper::FILTER_STRING_SHORT, true) - ) { - self::$inputNotices['registrationAddConfirmPassword'] = 'Les mots de passe ne sont pas identiques'; - $check = false; - } - - if ($check) { - if ( - // Pas d'approbation par un administrateur - $this->getData(['module', $this->getUrl(0), 'config', 'approval']) === false - ) { - // Créer le compte - $this->setData([ - 'user', - $userId, - [ - 'firstname' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'firstname']), - 'lastname' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'lastname']), - 'mail' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'mail']), - 'password' => $this->getInput('registrationValidPassword', helper::FILTER_PASSWORD, true), - 'group' => self::GROUP_MEMBER, - 'profil' => 1, - 'forgot' => 0, - 'pseudo' => $userId, - 'signature' => 1, - 'language' => self::$siteContent, - ] - ]); - // Modifier le statut dans le module - $this->deleteData(['module', $this->getUrl(0), 'users', $userId]); - $notification = 'Votre inscription est confirmée'; - } else { - // Approbation nécessaire - $this->setData(['module', $this->getUrl(0), 'users', $userId, 'status', self::STATUS_ACCOUNT_AWAITING]); - $notification = 'L\'inscription doit être approuvée par un administrateur'; - } - } - // Valeurs en sortie - $this->addOutput([ - 'redirect' => $check ? helper::baseUrl() . $this->getdata(['module', $this->getUrl(0), 'config', 'pageSuccess']) : helper::baseUrl() . $this->getdata(['module', $this->getUrl(0), 'config', 'pageError']), - 'notification' => $notification, - 'state' => $check - ]); - } - // Valeurs en sortie - $this->addOutput([ - 'title' => 'Saisie du mot de passe', - 'view' => 'validate' - ]); - } - - /** - * Module de configuration - */ - public function config() - { - // Soumission du formulaire - if ( - $this->getUser('permission', __CLASS__, __FUNCTION__) === true - && $this->isPost() - ) { - - // Lire les options et les enregistrer - $this->setData([ - 'module', - $this->getUrl(0), - 'config', - [ - 'timeOut' => $this->getInput('registrationConfigTimeOut', helper::FILTER_INT) * 60, - 'pageSuccess' => $this->getInput('registrationConfigSuccess'), - 'pageError' => $this->getInput('registrationConfigError'), - 'approval' => $this->getInput('registrationConfigState', helper::FILTER_BOOLEAN), - 'mailRegisterContent' => $this->getInput('registrationconfigMailRegisterContent', null, true), - 'mailValidateContent' => $this->getInput('registrationconfigMailValidateContent', null, true), - 'layout' => $this->getInput('registrationConfigLayout'), - 'filter' => $this->getInput('registrationConfigFilter', helper::FILTER_STRING_SHORT) - ] - ]); - $this->addOutput([ - 'redirect' => helper::baseUrl() . $this->getUrl(), - 'notification' => 'Modifications enregistrées', - 'state' => true - ]); - } - // Valeurs en sortie - $this->addOutput([ - 'title' => 'Configuration', - 'view' => 'config', - 'vendor' => ['tinymce'] - ]); - } -} - + + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +class suscribe extends common +{ + + const VERSION = '2.6'; + const REALNAME = 'Auto Inscription'; + const DELETE = true; + const UPDATE = '0.0'; + const DATADIRECTORY = ''; // Contenu localisé inclus par défaut (page.json et module.json) + + const STATUS_EMAIL_AWAITING = 0; + const STATUS_EMAIL_VALID = 1; + const STATUS_ACCOUNT_AWAITING = 2; + const STATUS_ACCOUNT_VALID = 3; + public static $statusGroups = [ + self::STATUS_EMAIL_AWAITING => 'Email non confirmé', + self::STATUS_EMAIL_VALID => 'Email valide', + self::STATUS_ACCOUNT_AWAITING => 'Email valide, en attente de confirmation', + self::STATUS_ACCOUNT_VALID => 'Email valide, compte activé', + ]; + + public static $actions = [ + 'index' => self::GROUP_VISITOR, + 'validate' => self::GROUP_VISITOR, + 'config' => self::GROUP_EDITOR, + 'users' => self::GROUP_EDITOR, + 'delete' => self::GROUP_EDITOR, + 'edit' => self::GROUP_EDITOR + ]; + + public static $layout = [ + 'inputRowContainer1' => 'Un élément par ligne', + 'inputRowContainer2' => 'Deux éléments par ligne', + 'inputRowContainer4' => 'Quatre éléments par ligne', + ]; + + public static $timeLimit = [ + 2 => '2 minutes', + 5 => '5 minutes', + 10 => '10 minutes' + ]; + + public static $users = []; + + public static $groups = []; + public static $userProfils = []; + public static $userProfilsComments = []; + + /** + * Liste des utilisateurs en attente + */ + public function users() + { + $userIdsFirstnames = helper::arraycollumn($this->getData(['module', $this->getUrl(0), 'users']), 'firstname'); + ksort($userIdsFirstnames); + foreach ($userIdsFirstnames as $userId => $userFirstname) { + self::$users[] = [ + $userId, + $userFirstname . ' ' . $this->getData(['module', $this->getUrl(0), 'users', $userId, 'lastname']), + self::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $userId, 'status'])], + helper::dateUTF8(date('Y-m-d G:i'), $this->getData(['module', $this->getUrl(0), 'users', $userId, 'timer'])), + template::button('registrationUserEdit' . $userId, [ + 'href' => helper::baseUrl() . $this->getUrl(0) . '/edit/' . $userId, + 'value' => template::ico('pencil') + ]), + template::button('registrationUserDelete' . $userId, [ + 'class' => 'userDelete red', + 'href' => helper::baseUrl() . $this->getUrl(0) . '/delete/' . $userId, + 'value' => template::ico('cancel') + ]) + ]; + } + // Valeurs en sortie + $this->addOutput([ + 'title' => 'Inscription en attente', + 'view' => 'users' + ]); + } + + + /** + * Édition + */ + public function edit() + { + if ( + $this->getUser('permission', __CLASS__, __FUNCTION__) !== true + ) { + // Valeurs en sortie + $this->addOutput([ + 'access' => false + ]); + } + // Accès refusé + if ( + // L'utilisateur n'existe pas + $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]) === null + // Droit d'édition + and ( + // Impossible de s'auto-éditer + ( + $this->getUser('id') === 'user' + and $this->getUrl('group') <= self::GROUP_VISITOR + ) + // Impossible d'éditer un autre utilisateur + or ($this->getUrl('group') < self::GROUP_EDITOR) + ) + ) { + // Valeurs en sortie + $this->addOutput([ + 'access' => false + ]); + } + // Accès autorisé + else { + // Soumission du formulaire + if ( + $this->getUser('permission', __CLASS__, __FUNCTION__) === true + && $this->isPost() + ) { + // Créer le user dans la base + $this->setData([ + 'user', + $this->getUrl(2), + [ + 'firstname' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'firstname']), + 'forgot' => 0, + 'group' => $this->getInput('registrationUserEditGroup', helper::FILTER_INT), + // Le profil vaut 0 pour les amdins et 1 pour les autres membres, profil par défaut. + 'profil' => $this->getInput('registrationUserEditGroup', helper::FILTER_INT) === self::GROUP_ADMIN + ? 0 : 1, + 'lastname' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'lastname']), + 'mail' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'mail']), + 'password' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'password']), + 'tags' => $this->getInput('registrationUserLabel', helper::FILTER_STRING_SHORT), + ] + ]); + // Notifier le user + $this->sendMail( + $this->getData(['module', $this->getUrl(0), 'users', 'mail']), + 'Approbation de l\'inscription', + '

' . $this->getdata(['module', $this->getUrl(0), 'config', 'mailValidateContent']) . '

', + null, + $this->getData(['config', 'smtp', 'from']) + ); + // Supprimer le user de la base temporaire, + $this->deleteData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]); + // Valeurs en sortie + $this->addOutput([ + 'redirect' => helper::baseUrl() . $this->getUrl(0) . '/users', + 'notification' => 'Modifications enregistrées', + 'state' => true + ]); + } + // Changement temporaire de libellé du groupe 0 + self::$groups = self::$groupEdits; + self::$groups[self::GROUP_BANNED] = 'En attente d\'approbation'; + + // Profils disponibles + foreach ($this->getData(['profil']) as $profilId => $profilData) { + if ($profilId < self::GROUP_MEMBER) { + continue; + } + if ($profilId === self::GROUP_ADMIN) { + self::$userProfils[$profilId][self::GROUP_ADMIN] = $profilData['name']; + self::$userProfilsComments[$profilId][self::GROUP_ADMIN] = $profilData['comment']; + continue; + } + foreach ($profilData as $key => $value) { + self::$userProfils[$profilId][$key] = $profilData[$key]['name']; + self::$userProfilsComments[$profilId][$key] = $profilData[$key]['name'] . ' : ' . $profilData[$key]['comment']; + } + } + + // Valeurs en sortie + $this->addOutput([ + 'title' => $this->getData(['module', $this->getUrl(0), 'users', 'firstname']) . ' ' . $this->getData(['user', $this->getUrl(0), 'lastname']), + 'view' => 'edit' + ]); + } + } + + + /** + * Suppression + */ + public function delete() + { + // Accès refusé + if ( + // L'utilisateur n'existe pas + $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]) === null + // Groupe insuffisant + && $this->getUser('permission', __CLASS__, __FUNCTION__) !== true + ) { + // Valeurs en sortie + $this->addOutput([ + 'access' => false + ]); + } + // Suppression + else { + $this->deleteData(['module', $this->getUrl(0), 'users', $this->getUrl(2)]); + // Valeurs en sortie + $this->addOutput([ + 'redirect' => helper::baseUrl() . $this->getUrl(0) . '/users', + 'notification' => 'Utilisateur supprimé', + 'state' => true + ]); + } + } + + + /** + * Ajout + */ + public function index() + { + /** + * Traitement du formulaire + * Stocke les données du formulaire dans le module + * Envoie le mail de vérification de l'email + */ + // Soumission du formulaire + if ($this->isPost()) { + // Contrôler la validité du domaine saisi parmi les domaines valides + $email_to_check = $this->getInput('registrationAddMail', helper::FILTER_MAIL, true); + // Le domaine saisi est invalide si un filtre existe + if ( + empty($this->getData(['module', $this->getUrl(0), 'config', 'filter'])) === true && + empty($email_to_check) === true + ) { + + + // Récupérer la liste des domaines valides depuis la configuration et supprimer les espaces autour + $filter = trim($this->getData(['module', $this->getUrl(0), 'config', 'filter'])); + + // Vérifier si la liste contient plusieurs domaines ou un seul, puis supprimer les espaces pour chaque domaine + $valid_domains = strpos($filter, ';') === false + ? [trim($filter)] // Si un seul domaine, on supprime les espaces et on le met dans un tableau + : array_map('trim', explode(';', $filter)); // Si plusieurs domaines, on les explose en tableau et supprime les espaces + + // Extraire le domaine de l'adresse email à vérifier + $email_domain = explode('@', $email_to_check)[1]; + + // Vérifier si le domaine de l'email est dans la liste des domaines valides + if (!in_array($email_domain, $valid_domains)) { + self::$inputNotices['registrationAddMail'] = 'Ce domaine n\'est pas autorisé'; + } + + } + // Email valide, on continue le traitement + if (self::$inputNotices === []) { + // Drapeau de contrôle des données saisies. + $check = true; + $sentMailtoUser = false; + // L'identifiant d'utilisateur est indisponible + $userId = $this->getInput('registrationAddId', helper::FILTER_ID, true); + if (is_array($this->getData(['user', $userId]))) { + self::$inputNotices['registrationAddId'] = 'Identifiant invalide'; + $check = false; + } + // Le compte existe déjà + foreach ($this->getData(['user']) as $usersId => $user) { + if ($user['mail'] === $this->getInput('registrationAddMail', helper::FILTER_MAIL, true)) { + self::$inputNotices['registrationAddMail'] = 'Vous ne pouvez pas utilisez cette boite mail'; + $check = false; + break; + } + } + // Données de l'utilisateur + $userFirstname = $this->getInput('registrationAddFirstname', helper::FILTER_STRING_SHORT, true); + $userLastname = $this->getInput('registrationAddLastname', helper::FILTER_STRING_SHORT, true); + $userMail = $this->getInput('registrationAddMail', helper::FILTER_MAIL, true); + // Pas de nom saisi + if ( + empty($userFirstname) || + empty($userLastname) + ) { + $check = false; + } + // Si tout est ok + if ($check === true) { + // Enregistrement du compte dans les données du module + $auth = uniqid('', true); + $this->setData([ + 'module', + $this->getUrl(0), + 'users', + $userId, + [ + 'firstname' => $userFirstname, + 'lastname' => $userLastname, + 'mail' => $userMail, + 'password' => '', + // pas de groupe afin de le différencier dans la liste des users + 'timer' => time(), + 'pseudo' => $userId, + 'auth' => $auth, + 'status' => self::STATUS_EMAIL_AWAITING + ] + ]); + // Mail d'avertissement aux administrateurs + // Utilisateurs dans le groupe admin + $to = []; + foreach ($this->getData(['user']) as $key => $user) { + if ($user['group'] == self::GROUP_ADMIN) { + $to[] = $user['mail']; + } + } + // Envoi du mail à l'administrateur + if ($check && is_array($to)) { + $this->sendMail( + $to, + 'Auto-inscription sur le site ' . $this->getData(['config', 'title']), + '

Un nouveau membre s\'est inscrit, son email est en attente de validation

' . + '

Identifiant du compte : ' . $userId . ' (' . $userFirstname . ' ' . $userLastname . ')
' . + 'Email : ' . $userMail . '

' . + '
Validation de l\'inscription', + null, + $this->getData(['config', 'smtp', 'from']) + ); + } + + // Mail de confirmation à l'utilisateur + // forger le lien de vérification + $validateLink = helper::baseUrl(true) . $this->getUrl() . '/validate/' . $userId . '/' . $auth; + // Envoi + if ($check) { + $sentMailtoUser = $this->sendMail( + $userMail, + 'Confirmation de votre inscription', + '

' . $this->getdata(['module', $this->getUrl(0), 'config', 'mailRegisterContent']) . '

' . + '

Activer votre compte' . '

' . + '

ou copiez collez le lien suivant dans un navigateur : ' . $validateLink . '

' + , + null, + $this->getData(['config', 'smtp', 'from']) + ); + } + } + // Valeurs en sortie + $this->addOutput([ + 'redirect' => helper::baseUrl(), + //'redirect' => $validateLink, + 'notification' => $sentMailtoUser ? "Un mail vous a été envoyé." : 'Quelque chose n\'a pas fonctionné !', + 'state' => $sentMailtoUser ? true : false + ]); + } + } + // Valeurs en sortie + $this->addOutput([ + 'title' => 'Inscription', + 'view' => 'index', + 'showBarEditButton' => true, + 'showPageContent' => true + ]); + } + + /** + * Vérification de l'email + */ + public function validate() + { + // Soumission du formulaire + if ($this->isPost()) { + // Vérifie la session + l'id + le timer + $check = true; + $notification = 'Bienvenue sur le site ' . $this->getData(['config', 'title']); + $userId = $this->getUrl(2); + $auth = $this->getUrl(3); + // la validité du lien est dépassé + if ( + (time() - $this->getData(['module', $this->getUrl(0), 'users', $userId, 'timer'])) + >= $this->getdata(['module', $this->getUrl(0), 'config', 'timeOut']) + ) { + $check = false; + $notification = 'La validité du lien est dépassée'; + } + // La clé est incorrecte ou le compte n'est pas en attente de validation + if ( + $check + && $auth !== $this->getData(['module', $this->getUrl(0), 'users', $userId, 'auth']) + && $this->getData(['module', $this->getUrl(0), 'users', $userId, 'status']) !== self::STATUS_EMAIL_AWAITING + ) { + $check = false; + $notification = 'Données incorrectes !'; + } + // Double vérification pour le mot de passe + if ( + $check + && $this->getInput('registrationValidPassword', helper::FILTER_STRING_SHORT, true) !== $this->getInput('registrationValidConfirmPassword', helper::FILTER_STRING_SHORT, true) + ) { + self::$inputNotices['registrationValidConfirmPassword'] = 'Les mots de passe ne sont pas identiques'; + $check = false; + } + if ($check) { + if ( + // Pas d'approbation par un administrateur + $this->getData(['module', $this->getUrl(0), 'config', 'approval']) === false + ) { + // Créer le compte + $this->setData([ + 'user', + $userId, + [ + 'firstname' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'firstname']), + 'lastname' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'lastname']), + 'mail' => $this->getData(['module', $this->getUrl(0), 'users', $userId, 'mail']), + 'password' => $this->getInput('registrationValidPassword', helper::FILTER_PASSWORD, true), + 'group' => self::GROUP_MEMBER, + 'profil' => 1, + 'forgot' => 0, + 'pseudo' => $userId, + 'signature' => 1, + 'language' => self::$siteContent, + ] + ]); + // Modifier le statut dans le module + $this->deleteData(['module', $this->getUrl(0), 'users', $userId]); + $notification = 'Votre inscription est confirmée'; + } else { + // Approbation nécessaire + $this->setData(['module', $this->getUrl(0), 'users', $userId, 'status', self::STATUS_ACCOUNT_AWAITING]); + $notification = 'L\'inscription doit être approuvée par un administrateur'; + // Stocker le mot de passe temporairement + $this->setData([ + 'module', + $this->getUrl(0), + 'users', + $userId, + 'password', + $this->getInput('registrationValidPassword', helper::FILTER_PASSWORD, true), + ]); + + } + } + + // Valeurs en sortie + $this->addOutput([ + 'redirect' => $check ? helper::baseUrl() . $this->getdata(['module', $this->getUrl(0), 'config', 'pageSuccess']) : helper::baseUrl() . $this->getdata(['module', $this->getUrl(0), 'config', 'pageError']), + 'notification' => $notification, + 'state' => $check + ]); + } + // Valeurs en sortie + $this->addOutput([ + 'title' => 'Saisie du mot de passe', + 'view' => 'validate' + ]); + } + + /** + * Module de configuration + */ + public function config() + { + // Soumission du formulaire + if ( + $this->getUser('permission', __CLASS__, __FUNCTION__) === true + && $this->isPost() + ) { + + // Lire les options et les enregistrer + $this->setData([ + 'module', + $this->getUrl(0), + 'config', + [ + 'timeOut' => $this->getInput('registrationConfigTimeOut', helper::FILTER_INT) * 60, + 'pageSuccess' => $this->getInput('registrationConfigSuccess'), + 'pageError' => $this->getInput('registrationConfigError'), + 'approval' => $this->getInput('registrationConfigState', helper::FILTER_BOOLEAN), + 'mailRegisterContent' => $this->getInput('registrationconfigMailRegisterContent', null, true), + 'mailValidateContent' => $this->getInput('registrationconfigMailValidateContent', null, true), + 'layout' => $this->getInput('registrationConfigLayout'), + 'filter' => $this->getInput('registrationConfigFilter', helper::FILTER_STRING_SHORT) + ] + ]); + $this->addOutput([ + 'redirect' => helper::baseUrl() . $this->getUrl(), + 'notification' => 'Modifications enregistrées', + 'state' => true + ]); + } + // Valeurs en sortie + $this->addOutput([ + 'title' => 'Configuration', + 'view' => 'config', + 'vendor' => ['tinymce'] + ]); + } +} + diff --git a/module/suscribe/view/config/config.css b/module/suscribe/view/config/config.css index adc81bd..66f9d77 100755 --- a/module/suscribe/view/config/config.css +++ b/module/suscribe/view/config/config.css @@ -1,21 +1,21 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Rémi Jean - * @copyright Copyright (C) 2008-2018, Rémi Jean - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -/** NE PAS EFFACER -* admin.css -*/ - -textarea .editorWysiwyg { - height : 100px; +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Rémi Jean + * @copyright Copyright (C) 2008-2018, Rémi Jean + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +/** NE PAS EFFACER +* admin.css +*/ + +textarea .editorWysiwyg { + height : 100px; } \ No newline at end of file diff --git a/module/suscribe/view/config/config.php b/module/suscribe/view/config/config.php index 363ada1..061e7cc 100755 --- a/module/suscribe/view/config/config.php +++ b/module/suscribe/view/config/config.php @@ -1,103 +1,103 @@ - -
-
- 'buttonGrey', - 'href' => helper::baseUrl() . 'page/edit/' . $this->getUrl(0) . '/' . self::$siteContent, - 'value' => template::ico('left') - ]); ?> -
-
- helper::baseUrl() . $this->getUrl(0) . '/users', - 'value' => 'Inscriptions' - ]); ?> -
-
- 'green' - ]); ?> -
-
-
-
-
-

Paramètres

-
-
- 'Disposition', - 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'layout']) - ]); ?> -
-
- getData(['page']), 'title', 'SORT_ASC'), [ - 'label' => 'Redirection après confirmation', - 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'pageSuccess']) - ]); ?> -
-
- getData(['page']), 'title', 'SORT_ASC'), [ - 'label' => 'Redirection après erreur', - 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'pageError']) - ]); ?> -
-
-
-
-
-
-
-
-

Communication

-
-
- 'Validité du lien', - 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'timeOut']) / 60 - ]); ?> -
-
- 'Domaines acceptés', - 'value' => $this->getData(['module', $this->getUrl(0), 'config', 'filter']), - 'help' => 'Champ vide sinon limitation à des domaines spécifiques, le séparateur est ;' - ]); ?> -
-
-
-
- Confirmez votre inscription en cliquant sur ce lien dans les ... minutes.

'; ?> - 'Corps du mail de confirmation', - 'value' => !empty($this->getData(['module', $this->getUrl(0), 'config', 'mailRegisterContent'])) ? $this->getData(['module', $this->getUrl(0), 'config', 'mailRegisterContent']) : $messageDefault, - 'class' => 'editorWysiwyg', - 'help' => 'Précisez la durée de validité. Le lien sera inséré après ces explications.' - ]); ?> -
-
-
-
- $this->getData(['module', $this->getUrl(0), 'config', 'approval']), - 'help' => 'Les comptes sont inactifs tant que les inscriptions ne sont pas approuvées par un administrateur.', - 'check' => true - ]); ?> -
-
-
-
- Votre inscription a été approuvée par un administrateur.

'; ?> - 'Corps du mail d\'approbation', - 'value' => !empty($this->getData(['module', $this->getUrl(0), 'config', 'mailValidateContent'])) ? $this->getData(['module', $this->getUrl(0), 'config', 'mailValidateContent']) : $messageDefault, - 'class' => 'editorWysiwyg' - ]); ?> -
-
-
-
-
- -
Version n° + +
+
+ 'buttonGrey', + 'href' => helper::baseUrl() . 'page/edit/' . $this->getUrl(0) . '/' . self::$siteContent, + 'value' => template::ico('left') + ]); ?> +
+
+ helper::baseUrl() . $this->getUrl(0) . '/users', + 'value' => 'Inscriptions' + ]); ?> +
+
+ 'green' + ]); ?> +
+
+
+
+
+

Paramètres

+
+
+ 'Disposition', + 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'layout']) + ]); ?> +
+
+ getData(['page']), 'title', 'SORT_ASC'), [ + 'label' => 'Redirection après confirmation', + 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'pageSuccess']) + ]); ?> +
+
+ getData(['page']), 'title', 'SORT_ASC'), [ + 'label' => 'Redirection après erreur', + 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'pageError']) + ]); ?> +
+
+
+
+
+
+
+
+

Communication

+
+
+ 'Validité du lien', + 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'timeOut']) / 60 + ]); ?> +
+
+ 'Domaines acceptés', + 'value' => $this->getData(['module', $this->getUrl(0), 'config', 'filter']), + 'help' => 'Champ vide sinon limitation à des domaines spécifiques, le séparateur est ;' + ]); ?> +
+
+
+
+ Confirmez votre inscription en cliquant sur ce lien dans les ... minutes.

'; ?> + 'Corps du mail de confirmation', + 'value' => !empty($this->getData(['module', $this->getUrl(0), 'config', 'mailRegisterContent'])) ? $this->getData(['module', $this->getUrl(0), 'config', 'mailRegisterContent']) : $messageDefault, + 'class' => 'editorWysiwyg', + 'help' => 'Précisez la durée de validité. Le lien sera inséré après ces explications.' + ]); ?> +
+
+
+
+ $this->getData(['module', $this->getUrl(0), 'config', 'approval']), + 'help' => 'Les comptes sont inactifs tant que les inscriptions ne sont pas approuvées par un administrateur.', + 'check' => true + ]); ?> +
+
+
+
+ Votre inscription a été approuvée par un administrateur.

'; ?> + 'Corps du mail d\'approbation', + 'value' => !empty($this->getData(['module', $this->getUrl(0), 'config', 'mailValidateContent'])) ? $this->getData(['module', $this->getUrl(0), 'config', 'mailValidateContent']) : $messageDefault, + 'class' => 'editorWysiwyg' + ]); ?> +
+
+
+
+
+ +
Version n°
\ No newline at end of file diff --git a/module/suscribe/view/edit/edit.css b/module/suscribe/view/edit/edit.css index 3c06906..0a71300 100755 --- a/module/suscribe/view/edit/edit.css +++ b/module/suscribe/view/edit/edit.css @@ -1,21 +1,21 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Rémi Jean - * @copyright Copyright (C) 2008-2018, Rémi Jean - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -/** NE PAS EFFACER -* admin.css -*/ -#registrationUserEditProfil1Wrapper, -#registrationUserEditProfil2Wrapper { - padding: 0; -} +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Rémi Jean + * @copyright Copyright (C) 2008-2018, Rémi Jean + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +/** NE PAS EFFACER +* admin.css +*/ +#registrationUserEditProfil1Wrapper, +#registrationUserEditProfil2Wrapper { + padding: 0; +} diff --git a/module/suscribe/view/edit/edit.js.php b/module/suscribe/view/edit/edit.js.php index 92416ed..20080fb 100755 --- a/module/suscribe/view/edit/edit.js.php +++ b/module/suscribe/view/edit/edit.js.php @@ -1,31 +1,31 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -/** - * Droits des groupes - */ - - -$(document).ready(function () { - $(".registrationUserEditGroupProfil").hide(); - $(".registrationUserCommentProfil").hide(); - $("#registrationUserEditGroupProfil" + $("#registrationUserEditGroup").val()).show(); - $("#registrationUserCommentProfil" + $("#registrationUserEditGroup").val()).show(); - - $("#registrationUserEditGroup").on("change", function () { - $(".registrationUserEditGroupProfil").hide(); - $(".registrationUserCommentProfil").hide(); - $("#registrationUserEditGroupProfil" + $(this).val()).show(); - $("#registrationUserCommentProfil" + $(this).val()).show(); - }); - +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +/** + * Droits des groupes + */ + + +$(document).ready(function () { + $(".registrationUserEditGroupProfil").hide(); + $(".registrationUserCommentProfil").hide(); + $("#registrationUserEditGroupProfil" + $("#registrationUserEditGroup").val()).show(); + $("#registrationUserCommentProfil" + $("#registrationUserEditGroup").val()).show(); + + $("#registrationUserEditGroup").on("change", function () { + $(".registrationUserEditGroupProfil").hide(); + $(".registrationUserCommentProfil").hide(); + $("#registrationUserEditGroupProfil" + $(this).val()).show(); + $("#registrationUserCommentProfil" + $(this).val()).show(); + }); + }); \ No newline at end of file diff --git a/module/suscribe/view/edit/edit.php b/module/suscribe/view/edit/edit.php index 87eb4fb..52ad2e0 100755 --- a/module/suscribe/view/edit/edit.php +++ b/module/suscribe/view/edit/edit.php @@ -1,140 +1,148 @@ - -
-
- 'buttonGrey', - 'href' => helper::baseUrl() . $this->geturl(0) . '/users', - 'value' => template::ico('left') - ]); ?> -
-
- 'green' - ]); ?> -
-
-
-
-
-

Confirmation de l'inscription

-
-
-
-
- 'off', - 'label' => 'Prénom', - 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'firstname']), - 'disabled' => true - ]); ?> -
-
- 'off', - 'label' => 'Nom', - 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'lastname']), - 'disabled' => true - ]); ?> -
-
-
-
- 'off', - 'label' => 'Adresse électronique', - 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'mail']), - 'disabled' => true - ]); ?> -
-
-
-
- 'État de l\'inscription', - 'value' => $module::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'status'])], - 'disabled' => true, - 'help' => 'En attente : le mail n\'a pas encore été validé
Email validé : approbation nécessaire.' - ]); ?> -
-
- 'Date de demande', - 'value' => helper::dateUTF8(date('Y-m-d G:i'), $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'timer'])), - 'disabled' => true - ]); ?> -
-
-
-
-
-
- 'Étiquette' - ]); ?> -
-
- getUser('group') === self::GROUP_ADMIN): ?> - ($this->getUrl(2) === $this->getUser('id')), - 'help' => ($this->getUrl(2) === $this->getUser('id') ? 'Impossible de modifier votre propre groupe.' : ''), - 'label' => 'Groupe', - 'selected' => $this->getData(['module', $this->getUrl(0), 'registrationUsers', $this->getUrl(2), 'status']) - ]); ?> - -
-
-
- 'Profil', - 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), - 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, - ]); ?> -
-
- 'Profil', - 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), - 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, - ]); ?> -
-
-
-
-
- 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_MEMBER]), - 'readonly' => true, - - ]); - ?> -
-
- 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_EDITOR]), - 'readonly' => true, - - ]); - ?> -
-
- 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_ADMIN]), - 'readonly' => true, - ]); - ?> -
-
-
-
-
-
-
+ +
+
+ 'buttonGrey', + 'href' => helper::baseUrl() . $this->geturl(0) . '/users', + 'value' => template::ico('left') + ]); ?> +
+
+ 'green' + ]); ?> +
+
+
+
+
+

Approbation de l'inscription

+
+
+ 'Étiquettes', + 'help' => 'Les étiquettes sont séparées par des espaces', + ]); ?> +
+
+ getUser('group') === self::GROUP_ADMIN): ?> + ($this->getUrl(2) === $this->getUser('id')), + 'help' => ($this->getUrl(2) === $this->getUser('id') ? 'Impossible de modifier votre propre groupe.' : ''), + 'label' => 'Groupe', + 'selected' => $this->getData(['module', $this->getUrl(0), 'registrationUsers', $this->getUrl(2), 'status']) + ]); ?> + +
+
+
+ 'Profil', + 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), + 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, + ]); ?> +
+
+ 'Profil', + 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), + 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, + ]); ?> +
+
+
+
+
+ 'Commentaire', + 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_MEMBER]), + 'readonly' => true, + + ]); + ?> +
+
+ 'Commentaire', + 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_EDITOR]), + 'readonly' => true, + + ]); + ?> +
+
+ 'Commentaire', + 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_ADMIN]), + 'readonly' => true, + ]); + ?> +
+
+
+
+
+
+
+
+
+
+

Identité du compte

+
+
+
+
+ 'off', + 'label' => 'Prénom', + 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'firstname']), + 'disabled' => true + ]); ?> +
+
+ 'off', + 'label' => 'Nom', + 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'lastname']), + 'disabled' => true + ]); ?> +
+
+
+
+ 'off', + 'label' => 'Adresse électronique', + 'value' => $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'mail']), + 'disabled' => true + ]); ?> +
+
+
+
+ 'État de l\'inscription', + 'value' => $module::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'status'])], + 'disabled' => true, + 'help' => 'En attente : le mail n\'a pas encore été validé
Email validé : approbation nécessaire.' + ]); ?> +
+
+ 'Date de demande', + 'value' => helper::dateUTF8(date('Y-m-d G:i'), $this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'timer'])), + 'disabled' => true + ]); ?> +
+
+
+
+
+
+
\ No newline at end of file diff --git a/module/suscribe/view/index/index.css b/module/suscribe/view/index/index.css index 11b0ba2..459b7ed 100644 --- a/module/suscribe/view/index/index.css +++ b/module/suscribe/view/index/index.css @@ -1,37 +1,37 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Rémi Jean - * @copyright Copyright (C) 2008-2018, Rémi Jean - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -.inputRowContainer1, -.inputRowContainer2, -.inputRowContainer4, -.inputColContainer { - display: grid; - gap: 10px; /* Espacement entre les inputs */ -} - -/* En lignes */ -.inputRowContainer1 { - grid-template-columns: repeat(1, 1fr); /* 3 colonnes de largeur égale */ -} -.inputRowContainer2 { - grid-template-columns: repeat(2, 1fr); /* 3 colonnes de largeur égale */ -} -.inputRowContainer4 { - grid-template-columns: repeat(4, 1fr); /* 3 colonnes de largeur égale */ -} - -.inputColContainer { - grid-template-rows: repeat(50px, auto); /* 3 rangées ajustées à la hauteur des contenus */ - +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Rémi Jean + * @copyright Copyright (C) 2008-2018, Rémi Jean + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +.inputRowContainer1, +.inputRowContainer2, +.inputRowContainer4, +.inputColContainer { + display: grid; + gap: 10px; /* Espacement entre les inputs */ +} + +/* En lignes */ +.inputRowContainer1 { + grid-template-columns: repeat(1, 1fr); /* 3 colonnes de largeur égale */ +} +.inputRowContainer2 { + grid-template-columns: repeat(2, 1fr); /* 3 colonnes de largeur égale */ +} +.inputRowContainer4 { + grid-template-columns: repeat(4, 1fr); /* 3 colonnes de largeur égale */ +} + +.inputColContainer { + grid-template-rows: repeat(50px, auto); /* 3 rangées ajustées à la hauteur des contenus */ + } \ No newline at end of file diff --git a/module/suscribe/view/index/index.js.php b/module/suscribe/view/index/index.js.php index ca8495f..3baf44f 100755 --- a/module/suscribe/view/index/index.js.php +++ b/module/suscribe/view/index/index.js.php @@ -1,47 +1,47 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - - -/** - * Affichage de l'id en simulant FILTER_ID - */ -$("#registrationAddId").on("change keydown keyup", function(event) { - var userId = $(this).val(); - if( - event.keyCode !== 8 // BACKSPACE - && event.keyCode !== 37 // LEFT - && event.keyCode !== 39 // RIGHT - && event.keyCode !== 46 // DELETE - && window.getSelection().toString() !== userId // Texte sélectionné - ) { - var searchReplace = { - "á": "a", "à": "a", "â": "a", "ä": "a", "ã": "a", "å": "a", "ç": "c", "é": "e", "è": "e", "ê": "e", "ë": "e", "í": "i", "ì": "i", "î": "i", "ï": "i", "ñ": "n", "ó": "o", "ò": "o", "ô": "o", "ö": "o", "õ": "o", "ú": "u", "ù": "u", "û": "u", "ü": "u", "ý": "y", "ÿ": "y", - "Á": "A", "À": "A", "Â": "A", "Ä": "A", "Ã": "A", "Å": "A", "Ç": "C", "É": "E", "È": "E", "Ê": "E", "Ë": "E", "Í": "I", "Ì": "I", "Î": "I", "Ï": "I", "Ñ": "N", "Ó": "O", "Ò": "O", "Ô": "O", "Ö": "O", "Õ": "O", "Ú": "U", "Ù": "U", "Û": "U", "Ü": "U", "Ý": "Y", "Ÿ": "Y", - "'": "-", "\"": "-", " ": "-" - }; - userId = userId.replace(/[áàâäãåçéèêëíìîïñóòôöõúùûüýÿ'" ]/ig, function(match) { - return searchReplace[match]; - }); - userId = userId.replace(/[^a-z0-9-]/ig, ""); - $(this).val(userId); - } -}); - -/** - * Droits des groupes - */ -$("#registrationAddGroup").on("change", function() { - $(".registrationAddGroupDescription").hide(); - $("#registrationAddGroupDescription" + $(this).val()).show(); -}).trigger("change"); - - +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + + +/** + * Affichage de l'id en simulant FILTER_ID + */ +$("#registrationAddId").on("change keydown keyup", function(event) { + var userId = $(this).val(); + if( + event.keyCode !== 8 // BACKSPACE + && event.keyCode !== 37 // LEFT + && event.keyCode !== 39 // RIGHT + && event.keyCode !== 46 // DELETE + && window.getSelection().toString() !== userId // Texte sélectionné + ) { + var searchReplace = { + "á": "a", "à": "a", "â": "a", "ä": "a", "ã": "a", "å": "a", "ç": "c", "é": "e", "è": "e", "ê": "e", "ë": "e", "í": "i", "ì": "i", "î": "i", "ï": "i", "ñ": "n", "ó": "o", "ò": "o", "ô": "o", "ö": "o", "õ": "o", "ú": "u", "ù": "u", "û": "u", "ü": "u", "ý": "y", "ÿ": "y", + "Á": "A", "À": "A", "Â": "A", "Ä": "A", "Ã": "A", "Å": "A", "Ç": "C", "É": "E", "È": "E", "Ê": "E", "Ë": "E", "Í": "I", "Ì": "I", "Î": "I", "Ï": "I", "Ñ": "N", "Ó": "O", "Ò": "O", "Ô": "O", "Ö": "O", "Õ": "O", "Ú": "U", "Ù": "U", "Û": "U", "Ü": "U", "Ý": "Y", "Ÿ": "Y", + "'": "-", "\"": "-", " ": "-" + }; + userId = userId.replace(/[áàâäãåçéèêëíìîïñóòôöõúùûüýÿ'" ]/ig, function(match) { + return searchReplace[match]; + }); + userId = userId.replace(/[^a-z0-9-]/ig, ""); + $(this).val(userId); + } +}); + +/** + * Droits des groupes + */ +$("#registrationAddGroup").on("change", function() { + $(".registrationAddGroupDescription").hide(); + $("#registrationAddGroupDescription" + $(this).val()).show(); +}).trigger("change"); + + diff --git a/module/suscribe/view/index/index.php b/module/suscribe/view/index/index.php index d419acc..fe523b6 100755 --- a/module/suscribe/view/index/index.php +++ b/module/suscribe/view/index/index.php @@ -1,29 +1,29 @@ - -
- 'off', - 'label' => 'Prénom' - ]); ?> - 'off', - 'label' => 'Nom' - ]); ?> - 'off', - 'label' => 'Identifiant de connexion' - ]); ?> - 'off', - 'label' => 'Adresse électronique' - ]); ?> -
-
-
-
- 'Envoyer' - ]); ?> -
-
-
+ +
+ 'off', + 'label' => 'Prénom' + ]); ?> + 'off', + 'label' => 'Nom' + ]); ?> + 'off', + 'label' => 'Identifiant de connexion' + ]); ?> + 'off', + 'label' => 'Adresse électronique' + ]); ?> +
+
+
+
+ 'Envoyer' + ]); ?> +
+
+
\ No newline at end of file diff --git a/module/suscribe/view/users/users.css b/module/suscribe/view/users/users.css index 6aeea6c..85db3ce 100644 --- a/module/suscribe/view/users/users.css +++ b/module/suscribe/view/users/users.css @@ -1,17 +1,17 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Rémi Jean - * @copyright Copyright (C) 2008-2018, Rémi Jean - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -/** NE PAS EFFACER -* admin.css +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Rémi Jean + * @copyright Copyright (C) 2008-2018, Rémi Jean + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +/** NE PAS EFFACER +* admin.css */ \ No newline at end of file diff --git a/module/suscribe/view/users/users.js.php b/module/suscribe/view/users/users.js.php index e7026fe..1ed4c16 100644 --- a/module/suscribe/view/users/users.js.php +++ b/module/suscribe/view/users/users.js.php @@ -1,21 +1,21 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -/** - * Confirmation de suppression - */ -$(".registrationUserDelete").on("click", function() { - var _this = $(this); - return core.confirm("Êtes-vous sûr de vouloir supprimer cet utilisateur ?", function() { - $(location).attr("href", _this.attr("href")); - }); +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +/** + * Confirmation de suppression + */ +$(".registrationUserDelete").on("click", function() { + var _this = $(this); + return core.confirm("Êtes-vous sûr de vouloir supprimer cet utilisateur ?", function() { + $(location).attr("href", _this.attr("href")); + }); }); \ No newline at end of file diff --git a/module/suscribe/view/users/users.php b/module/suscribe/view/users/users.php index 8262182..3cad998 100644 --- a/module/suscribe/view/users/users.php +++ b/module/suscribe/view/users/users.php @@ -1,15 +1,15 @@ -
-
- 'buttonGrey', - 'href' => helper::baseUrl() . $this->getUrl(0) . '/config', - 'value' => template::ico('left') - ]); ?> -
-
- - - - - +
+
+ 'buttonGrey', + 'href' => helper::baseUrl() . $this->getUrl(0) . '/config', + 'value' => template::ico('left') + ]); ?> +
+
+ + + + + \ No newline at end of file diff --git a/module/suscribe/view/validate/validate.css b/module/suscribe/view/validate/validate.css index 68fbfb1..6fb8540 100644 --- a/module/suscribe/view/validate/validate.css +++ b/module/suscribe/view/validate/validate.css @@ -1,34 +1,34 @@ -/** - * This file is part of Zwii. - * - * For full copyright and license information, please see the LICENSE - * file that was distributed with this source code. - * - * @author Rémi Jean - * @copyright Copyright (C) 2008-2018, Rémi Jean - * @author Frédéric Tempez - * @copyright Copyright (C) 2018-2020, Frédéric Tempez - * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International - * @link http://zwiicms.com/ - */ - -.inputRowContainer1, -.inputRowContainer2, -.inputRowContainer4, -.inputColContainer { - display: grid; - gap: 10px; -} - -/* En lignes */ -.inputRowContainer1 { - grid-template-columns: repeat(1, 1fr); -} - -.inputRowContainer2 { - grid-template-columns: repeat(2, 1fr); -} - -.inputRowContainer4 { - grid-template-columns: repeat(2, 1fr); +/** + * This file is part of Zwii. + * + * For full copyright and license information, please see the LICENSE + * file that was distributed with this source code. + * + * @author Rémi Jean + * @copyright Copyright (C) 2008-2018, Rémi Jean + * @author Frédéric Tempez + * @copyright Copyright (C) 2018-2020, Frédéric Tempez + * @license CC Attribution-NonCommercial-NoDerivatives 4.0 International + * @link http://zwiicms.com/ + */ + +.inputRowContainer1, +.inputRowContainer2, +.inputRowContainer4, +.inputColContainer { + display: grid; + gap: 10px; +} + +/* En lignes */ +.inputRowContainer1 { + grid-template-columns: repeat(1, 1fr); +} + +.inputRowContainer2 { + grid-template-columns: repeat(2, 1fr); +} + +.inputRowContainer4 { + grid-template-columns: repeat(2, 1fr); } \ No newline at end of file diff --git a/module/suscribe/view/validate/validate.php b/module/suscribe/view/validate/validate.php index 7add1ff..b50d659 100755 --- a/module/suscribe/view/validate/validate.php +++ b/module/suscribe/view/validate/validate.php @@ -1,23 +1,23 @@ - -

Email confirmé

-
- 'off', - 'label' => 'Mot de passe' - ]); ?> - 'off', - 'label' => 'Confirmation du mot de passe' - ]); ?> -
-
-
-
- 'Envoyer', - 'class' => 'green' - ]); ?> -
-
-
+ +

Email confirmé

+
+ 'off', + 'label' => 'Mot de passe' + ]); ?> + 'off', + 'label' => 'Confirmation du mot de passe' + ]); ?> +
+
+
+
+ 'Envoyer', + 'class' => 'green' + ]); ?> +
+
+
\ No newline at end of file From 6104123582185f8a6d34495fb8cdfe0addda6968 Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Sun, 5 Jan 2025 18:00:52 +0100 Subject: [PATCH 02/14] Suscribe 2.6 --- module/suscribe/i18n/fr_FR.json | 30 ++++++++++++++++++++++++++++++ module/suscribe/suscribe.php | 10 +++++----- 2 files changed, 35 insertions(+), 5 deletions(-) create mode 100644 module/suscribe/i18n/fr_FR.json diff --git a/module/suscribe/i18n/fr_FR.json b/module/suscribe/i18n/fr_FR.json new file mode 100644 index 0000000..7061306 --- /dev/null +++ b/module/suscribe/i18n/fr_FR.json @@ -0,0 +1,30 @@ +{ + "Inscription en attente": "", + "Édition de l'utilisateur": "", + "Suppression de l'utilisateur": "", + "2 minutes": "", + "5 minutes": "", + "10 minutes": "", + "Email non confirmé": "", + "Email valide": "", + "Email valide, en attente de confirmation": "", + "Email valide, compte activé": "", + "Un élément par ligne": "", + "Deux éléments par ligne": "", + "Quatre éléments par ligne": "", + "En attente d'approbation": "", + "Inscription supprimée": "", + "Ce domaine n'est pas autorisé": "", + "Identifiant invalide": "", + "Vous ne pouvez pas utilisez cet email": "", + "Un mail vous a été envoyé pour confirmer votre inscription": "", + "Quelque chose n'a pas fonctionné !": "", + "Inscription": "", + "Bienvenue sur le site": "", + "La validité du lien est dépassée !": "", + "Les données saisies sont incorrectes !": "", + "Les mots de passe ne sont pas identiques !": "", + "Votre inscription est confirmée !": "", + "L'inscription doit être approuvée par un administrateur": "", + "Saisie du mot de passe": "" +} \ No newline at end of file diff --git a/module/suscribe/suscribe.php b/module/suscribe/suscribe.php index 91f7a88..708d470 100755 --- a/module/suscribe/suscribe.php +++ b/module/suscribe/suscribe.php @@ -217,7 +217,7 @@ class suscribe extends common // Valeurs en sortie $this->addOutput([ 'redirect' => helper::baseUrl() . $this->getUrl(0) . '/users', - 'notification' => 'Utilisateur supprimé', + 'notification' => 'Inscription supprimée', 'state' => true ]); } @@ -276,7 +276,7 @@ class suscribe extends common // Le compte existe déjà foreach ($this->getData(['user']) as $usersId => $user) { if ($user['mail'] === $this->getInput('registrationAddMail', helper::FILTER_MAIL, true)) { - self::$inputNotices['registrationAddMail'] = 'Vous ne pouvez pas utilisez cette boite mail'; + self::$inputNotices['registrationAddMail'] = 'Vous ne pouvez pas utilisez cet email'; $check = false; break; } @@ -356,7 +356,7 @@ class suscribe extends common $this->addOutput([ 'redirect' => helper::baseUrl(), //'redirect' => $validateLink, - 'notification' => $sentMailtoUser ? "Un mail vous a été envoyé." : 'Quelque chose n\'a pas fonctionné !', + 'notification' => $sentMailtoUser ? "Un mail vous a été envoyé pour confirmer votre inscription" : 'Quelque chose n\'a pas fonctionné !', 'state' => $sentMailtoUser ? true : false ]); } @@ -388,7 +388,7 @@ class suscribe extends common >= $this->getdata(['module', $this->getUrl(0), 'config', 'timeOut']) ) { $check = false; - $notification = 'La validité du lien est dépassée'; + $notification = 'La validité du lien est dépassée !'; } // La clé est incorrecte ou le compte n'est pas en attente de validation if ( @@ -397,7 +397,7 @@ class suscribe extends common && $this->getData(['module', $this->getUrl(0), 'users', $userId, 'status']) !== self::STATUS_EMAIL_AWAITING ) { $check = false; - $notification = 'Données incorrectes !'; + $notification = 'Les données saisies sont incorrectes !'; } // Double vérification pour le mot de passe if ( From 9b92e29a960d91143b05837dc02cd61df4c13443 Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Mon, 6 Jan 2025 15:54:20 +0100 Subject: [PATCH 03/14] =?UTF-8?q?Libell=C3=A9=20:=20cl=C3=A9=20de=20s?= =?UTF-8?q?=C3=A9curit=C3=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- core/module/install/ressource/i18n/en_EN.json | 2 +- core/module/install/ressource/i18n/es.json | 2 +- core/module/install/ressource/i18n/fr_FR.json | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/core/module/install/ressource/i18n/en_EN.json b/core/module/install/ressource/i18n/en_EN.json index 16be19c..4abccc8 100644 --- a/core/module/install/ressource/i18n/en_EN.json +++ b/core/module/install/ressource/i18n/en_EN.json @@ -700,7 +700,7 @@ "Connexion réussie": "Login successful", "Erreur de mot de passe": "Password error", "Erreur de captcha": "Captcha error", - "Clé envoyée par message": "Key sent via message", + "Clé de sécurité": "Security key", "Message de test": "Test message", "Clé d'authentification envoyée à votre adresse mail %s": "Authentication key sent to your email address %s" } \ No newline at end of file diff --git a/core/module/install/ressource/i18n/es.json b/core/module/install/ressource/i18n/es.json index b54826f..10d3bcb 100644 --- a/core/module/install/ressource/i18n/es.json +++ b/core/module/install/ressource/i18n/es.json @@ -700,7 +700,7 @@ "Connexion réussie": "Conexión exitosa", "Erreur de mot de passe": "Error de contraseña", "Erreur de captcha": "Error de captcha", - "Clé envoyée par message": "Clave enviada por mensaje", + "Clé de sécurité": "Clave de seguridad", "Message de test": "Mensaje de prueba", "Clé d'authentification envoyée à votre adresse mail %s": "Clave de autenticación enviada a su dirección de correo electrónico %s" } \ No newline at end of file diff --git a/core/module/install/ressource/i18n/fr_FR.json b/core/module/install/ressource/i18n/fr_FR.json index 475820b..cd66183 100644 --- a/core/module/install/ressource/i18n/fr_FR.json +++ b/core/module/install/ressource/i18n/fr_FR.json @@ -700,7 +700,7 @@ "Connexion réussie": "", "Erreur de mot de passe": "", "Erreur de captcha": "", - "Clé envoyée par message": "", + "Clé de sécurité": "", "Message de test": "", "Clé d'authentification envoyée à votre adresse mail %s": "" } \ No newline at end of file From b147f447765dd7bf555102444a2368d786d24c4d Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Mon, 6 Jan 2025 16:17:44 +0100 Subject: [PATCH 04/14] =?UTF-8?q?-=20Remplacement=20du=20nom=20g=C3=A9n?= =?UTF-8?q?=C3=A9rique=20de=20classe=20dans=20les=20vues.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- module/blog/blog.php | 2 +- module/blog/changes.md | 4 +++- module/form/changes.md | 4 +++- module/form/form.php | 2 +- module/suscribe/changes.md | 2 ++ module/suscribe/suscribe.php | 2 +- module/suscribe/view/config/config.php | 6 +++--- module/suscribe/view/edit/edit.php | 14 +++++++------- module/suscribe/view/users/users.php | 4 ++-- module/workshop/changes.md | 2 ++ module/workshop/view/config/config.php | 6 +++--- module/workshop/view/index/index.php | 4 ++-- module/workshop/workshop.php | 2 +- 13 files changed, 31 insertions(+), 23 deletions(-) create mode 100644 module/workshop/changes.md diff --git a/module/blog/blog.php b/module/blog/blog.php index 84b0508..f45ace4 100755 --- a/module/blog/blog.php +++ b/module/blog/blog.php @@ -16,7 +16,7 @@ class blog extends common { - const VERSION = '8.1'; + const VERSION = '8.2'; const REALNAME = 'Blog'; const DELETE = true; const UPDATE = '0.0'; diff --git a/module/blog/changes.md b/module/blog/changes.md index cbc5770..ef98e12 100755 --- a/module/blog/changes.md +++ b/module/blog/changes.md @@ -1,4 +1,6 @@ -# Version 8.01 +# Version 8.2 +- Remplacement du nom générique de classe dans les vues. +# Version 8.1 - Un mail de notification est seulement envoyé lorsque le captcha est passé et que le commentaire est déposé. - Le mail de notification contient désormais le nom de l'auteur du commentaire ainsi que le commentaire. # Version 8.00 diff --git a/module/form/changes.md b/module/form/changes.md index 8536f3e..2863224 100644 --- a/module/form/changes.md +++ b/module/form/changes.md @@ -1,4 +1,6 @@ -# Versions 4.4 +# Version 4.5 +- Remplacement du nom générique de classe dans les vues. +# Version 4.4 - Le sélecteur de fichier affiche par défaut le chemin vers le fichier présent dans le champ. # Version 4.3 - Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts. diff --git a/module/form/form.php b/module/form/form.php index 13fd1b5..5dd2a66 100644 --- a/module/form/form.php +++ b/module/form/form.php @@ -17,7 +17,7 @@ class form extends common { - const VERSION = '4.4'; + const VERSION = '4.5'; const REALNAME = 'Formulaire'; const DATADIRECTORY = ''; // Contenu localisé inclus par défaut (page.json et module.json) diff --git a/module/suscribe/changes.md b/module/suscribe/changes.md index 697608f..4157ab9 100644 --- a/module/suscribe/changes.md +++ b/module/suscribe/changes.md @@ -1,3 +1,5 @@ +# Version 2.7 +- Remplacement du nom générique de classe dans les vues. # Version 2.6 - Corrige d'un bug empêchat de terminer la procédure d'inscription après approbation. # Version 2.5 diff --git a/module/suscribe/suscribe.php b/module/suscribe/suscribe.php index 708d470..06d37be 100755 --- a/module/suscribe/suscribe.php +++ b/module/suscribe/suscribe.php @@ -15,7 +15,7 @@ class suscribe extends common { - const VERSION = '2.6'; + const VERSION = '2.7'; const REALNAME = 'Auto Inscription'; const DELETE = true; const UPDATE = '0.0'; diff --git a/module/suscribe/view/config/config.php b/module/suscribe/view/config/config.php index 061e7cc..58ed61e 100755 --- a/module/suscribe/view/config/config.php +++ b/module/suscribe/view/config/config.php @@ -25,7 +25,7 @@

Paramètres

- 'Disposition', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'layout']) ]); ?> @@ -52,7 +52,7 @@

Communication

- 'Validité du lien', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'timeOut']) / 60 ]); ?> @@ -99,5 +99,5 @@
-
Version n° +
Version n°
\ No newline at end of file diff --git a/module/suscribe/view/edit/edit.php b/module/suscribe/view/edit/edit.php index 52ad2e0..2833eec 100755 --- a/module/suscribe/view/edit/edit.php +++ b/module/suscribe/view/edit/edit.php @@ -26,7 +26,7 @@
getUser('group') === self::GROUP_ADMIN): ?> - ($this->getUrl(2) === $this->getUser('id')), 'help' => ($this->getUrl(2) === $this->getUser('id') ? 'Impossible de modifier votre propre groupe.' : ''), 'label' => 'Groupe', @@ -37,7 +37,7 @@
- 'Profil', 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, @@ -45,7 +45,7 @@
- 'Profil', 'selected' => $this->getData(['user', $this->getUrl(2), 'profil']), 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN, @@ -58,7 +58,7 @@ class="col12 registrationUserCommentProfil"> 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_MEMBER]), + 'value' => implode("\n", suscribe::$userProfilsComments[self::GROUP_MEMBER]), 'readonly' => true, ]); @@ -68,7 +68,7 @@ class="col12 registrationUserCommentProfil"> 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_EDITOR]), + 'value' => implode("\n", suscribe::$userProfilsComments[self::GROUP_EDITOR]), 'readonly' => true, ]); @@ -78,7 +78,7 @@ class="col12 registrationUserCommentProfil"> 'Commentaire', - 'value' => implode("\n", $module::$userProfilsComments[self::GROUP_ADMIN]), + 'value' => implode("\n", suscribe::$userProfilsComments[self::GROUP_ADMIN]), 'readonly' => true, ]); ?> @@ -127,7 +127,7 @@
'État de l\'inscription', - 'value' => $module::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'status'])], + 'value' => suscribe::$statusGroups[$this->getData(['module', $this->getUrl(0), 'users', $this->getUrl(2), 'status'])], 'disabled' => true, 'help' => 'En attente : le mail n\'a pas encore été validé
Email validé : approbation nécessaire.' ]); ?> diff --git a/module/suscribe/view/users/users.php b/module/suscribe/view/users/users.php index 3cad998..0c6df3f 100644 --- a/module/suscribe/view/users/users.php +++ b/module/suscribe/view/users/users.php @@ -8,8 +8,8 @@
- - + + \ No newline at end of file diff --git a/module/workshop/changes.md b/module/workshop/changes.md new file mode 100644 index 0000000..4cfc998 --- /dev/null +++ b/module/workshop/changes.md @@ -0,0 +1,2 @@ +# Version 1.2 +- Remplacement du nom générique de classe dans les vues. \ No newline at end of file diff --git a/module/workshop/view/config/config.php b/module/workshop/view/config/config.php index 91b2444..501129c 100644 --- a/module/workshop/view/config/config.php +++ b/module/workshop/view/config/config.php @@ -13,7 +13,7 @@
- 'Catégorie à afficher', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'category']) ]); ?> @@ -76,7 +76,7 @@
- 'Présentation en colonnes', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'layout']), 'help' => 'Chaque contenu est présenté dans une colonne' @@ -186,5 +186,5 @@
Version n° - +
\ No newline at end of file diff --git a/module/workshop/view/index/index.php b/module/workshop/view/index/index.php index c26dce8..2776ec8 100644 --- a/module/workshop/view/index/index.php +++ b/module/workshop/view/index/index.php @@ -56,7 +56,7 @@

- +

@@ -66,7 +66,7 @@ getData(['module', $this->getUrl(0), 'config', 'enrolment']) === true): ?>

- +

getData(['course', $courseId, 'limitEnrolment']) === true): ?> diff --git a/module/workshop/workshop.php b/module/workshop/workshop.php index 9376be9..46e461d 100644 --- a/module/workshop/workshop.php +++ b/module/workshop/workshop.php @@ -15,7 +15,7 @@ class workshop extends common { - const VERSION = '1.01'; + const VERSION = '1.2'; const REALNAME = 'Liste des espaces'; const DATADIRECTORY = ''; // Contenu localisé inclus par défaut (page.json et module.json) From 1a746acfecb99c5027271410f9cefbba55e55f4b Mon Sep 17 00:00:00 2001 From: Fred Tempez Date: Mon, 6 Jan 2025 16:19:43 +0100 Subject: [PATCH 05/14] =?UTF-8?q?Remplacement=20du=20nom=20g=C3=A9n=C3=A9r?= =?UTF-8?q?ique=20de=20classe=20dans=20les=20vues=20des=20modules?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- module/blog/view/add/add.php | 14 +++--- module/blog/view/article/article.php | 24 +++++----- module/blog/view/comment/comment.php | 8 ++-- module/blog/view/config/config.php | 8 ++-- module/blog/view/edit/edit.php | 14 +++--- module/blog/view/index/index.php | 28 ++++++------ module/blog/view/option/option.php | 12 ++--- module/form/form.php | 2 + module/form/view/config/config.php | 4 +- module/form/view/data/data.php | 8 ++-- module/form/view/index/index.php | 14 +++--- module/form/view/option/option.php | 18 ++++---- module/gallery/changes.md | 2 + module/gallery/gallery.php | 2 +- module/gallery/view/add/add.php | 2 +- module/gallery/view/config/config.php | 6 +-- module/gallery/view/edit/edit.php | 6 +-- module/gallery/view/gallery/gallery.php | 12 ++--- module/gallery/view/index/index.php | 6 +-- module/gallery/view/option/option.php | 12 ++--- module/gallery/view/theme/theme.php | 22 ++++----- module/news/changes.md | 6 ++- module/news/news.php | 4 +- module/news/view/add/add.php | 2 +- module/news/view/article/article.php | 16 ++++--- module/news/view/config/config.php | 8 ++-- module/news/view/edit/edit.php | 2 +- module/news/view/index/index.php | 20 +++++---- module/news/view/option/option.php | 35 +++++++++------ module/search/changes.md | 2 +- module/search/search.php | 59 +++++++++++++------------ module/search/view/config/config.php | 4 +- module/search/view/index/index.php | 16 +++---- module/slider/changes.md | 6 ++- module/slider/slider.php | 2 +- module/slider/view/config/config.php | 6 +-- module/slider/view/index/index.php | 4 +- module/slider/view/theme/theme.php | 18 ++++---- module/slider/view/update/update.php | 54 +++++++++++----------- 39 files changed, 258 insertions(+), 230 deletions(-) diff --git a/module/blog/view/add/add.php b/module/blog/view/add/add.php index d2de652..c4a4329 100755 --- a/module/blog/view/add/add.php +++ b/module/blog/view/add/add.php @@ -49,12 +49,12 @@ ]); ?>
- 'Largeur de l\'image' ]); ?>
- 'Position', 'help' => 'Le texte de l\'article est adapté autour de l\'image' ]); ?> @@ -79,7 +79,7 @@

- 'Auteur', 'selected' => $this->getUser('id'), 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN ? true : false @@ -95,9 +95,9 @@ ]); ?>
- 'Édition - Suppression', - 'selected' => $module::EDIT_ALL, + 'selected' => blog::EDIT_ALL, 'help' => 'Les utilisateurs des groupes supérieurs accèdent à l\'article sans restriction' ]); ?>
@@ -117,7 +117,7 @@
- 'Choix du nombre maximum de caractères pour chaque commentaire de l\'article, mise en forme html comprise.', 'label' => 'Caractères par commentaire' ]); ?> @@ -128,7 +128,7 @@
- +
diff --git a/module/blog/view/article/article.php b/module/blog/view/article/article.php index dca58e3..be4f6c5 100755 --- a/module/blog/view/article/article.php +++ b/module/blog/view/article/article.php @@ -34,7 +34,7 @@ 'left']); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true @@ -43,14 +43,14 @@ getData(['module', $this->getUrl(0), 'config', 'showTime']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> isConnected() === true and ( // Propriétaire - ($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'editConsent']) === $module::EDIT_OWNER + ($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'editConsent']) === blog::EDIT_OWNER and ($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'userId']) === $this->getUser('id') or $this->getUser('group') === self::GROUP_ADMIN) ) @@ -62,8 +62,8 @@ ) or ( // Tout le monde - $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'editConsent']) === $module::EDIT_ALL - and $this->getUser('group') >= $module::$actions['config'] + $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'editConsent']) === blog::EDIT_ALL + and $this->getUser('group') >= blog::$actions['config'] ) ) ): ?> @@ -95,8 +95,8 @@

'right']); - if ($module::$nbCommentsApproved > 0) { - echo $module::$nbCommentsApproved . ' commentaire' . ($module::$nbCommentsApproved > 1 ? 's' : ''); + if (blog::$nbCommentsApproved > 0) { + echo blog::$nbCommentsApproved . ' commentaire' . (blog::$nbCommentsApproved > 1 ? 's' : ''); } else { echo 'Pas encore de commentaire'; } @@ -114,7 +114,7 @@ 'Nom', 'readonly' => true, - 'value' => $module::$editCommentSignature + 'value' => blog::$editCommentSignature ]); ?> $this->getUser('id') @@ -172,17 +172,17 @@
- $comment): ?> + $comment): ?>

- + - +

- \ No newline at end of file + \ No newline at end of file diff --git a/module/blog/view/comment/comment.php b/module/blog/view/comment/comment.php index 2a8826c..3007bc2 100755 --- a/module/blog/view/comment/comment.php +++ b/module/blog/view/comment/comment.php @@ -8,14 +8,14 @@ ]); ?>

- +
- +
- - '; ?> + + '; ?>
diff --git a/module/blog/view/config/config.php b/module/blog/view/config/config.php index d87cfea..4acacb0 100755 --- a/module/blog/view/config/config.php +++ b/module/blog/view/config/config.php @@ -25,13 +25,13 @@
- - - + + +
Version n° - +
diff --git a/module/blog/view/edit/edit.php b/module/blog/view/edit/edit.php index 9ea26fb..2eee41a 100755 --- a/module/blog/view/edit/edit.php +++ b/module/blog/view/edit/edit.php @@ -53,13 +53,13 @@ ]); ?>
- 'Largeur de l\'image', 'selected' => $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'pictureSize']) ]); ?>
- 'Position', 'selected' => $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'picturePosition']), 'help' => 'Le texte de l\'article est adapté autour de l\'image' @@ -86,7 +86,7 @@

- 'Auteur', 'selected' => $this->getUser('id'), 'disabled' => $this->getUser('group') !== self::GROUP_ADMIN ? true : false @@ -101,9 +101,9 @@ ]); ?>
- 'Édition - Suppression', - 'selected' => is_numeric($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'editConsent'])) ? $module::EDIT_GROUP : $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'editConsent']), + 'selected' => is_numeric($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'editConsent'])) ? blog::EDIT_GROUP : $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'editConsent']), 'help' => 'Les utilisateurs des groupes supérieurs accèdent à l\'article sans restriction' ]); ?>
@@ -128,7 +128,7 @@ ]); ?>
- 'Choix du nombre maximum de caractères pour chaque commentaire de l\'article, mise en forme html comprise.', 'label' => 'Caractères par commentaire', 'selected' => $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'commentMaxlength']) @@ -143,7 +143,7 @@ ]); ?>
- $this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(2), 'commentGroupNotification']), ]); ?>
diff --git a/module/blog/view/index/index.php b/module/blog/view/index/index.php index b6f7d13..d0edc14 100755 --- a/module/blog/view/index/index.php +++ b/module/blog/view/index/index.php @@ -8,9 +8,9 @@
- +
- $article): ?> + $article): ?> getData(['module', $this->getUrl(0), 'config', 'layout']) === true): ?>
@@ -39,7 +39,7 @@ 'left']); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true @@ -48,7 +48,7 @@ getData(['module', $this->getUrl(0), 'config', 'showTime']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?>
@@ -75,7 +75,7 @@ $this->isConnected() === true and ( // Propriétaire - ($this->getData(['module', $this->getUrl(0), 'posts', $articleId, 'editConsent']) === $module::EDIT_OWNER + ($this->getData(['module', $this->getUrl(0), 'posts', $articleId, 'editConsent']) === blog::EDIT_OWNER and ($this->getData(['module', $this->getUrl(0), 'posts', $articleId, 'userId']) === $this->getUser('id') or $this->getUser('group') === self::GROUP_ADMIN) ) @@ -87,8 +87,8 @@ ) or ( // Tout le monde - $this->getData(['module', $this->getUrl(0), 'posts', $articleId, 'editConsent']) === $module::EDIT_ALL - and $this->getUser('group') >= $module::$actions['config'] + $this->getData(['module', $this->getUrl(0), 'posts', $articleId, 'editConsent']) === blog::EDIT_ALL + and $this->getUser('group') >= blog::$actions['config'] ) ) ): ?> @@ -104,9 +104,9 @@

'right']); ?> 0) { + if (blog::$comments[$articleId] > 0) { echo ''; - echo $module::$comments[$articleId] . ' commentaire' . ($module::$comments[$articleId] > 1 ? 's' : ''); + echo blog::$comments[$articleId] . ' commentaire' . (blog::$comments[$articleId] > 1 ? 's' : ''); echo ''; } else { echo 'Pas encore de commentaire'; @@ -153,8 +153,8 @@

- - + + 'left']); ?> @@ -174,7 +174,7 @@ 'left']); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true @@ -183,7 +183,7 @@ getData(['module', $this->getUrl(0), 'config', 'showTime']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $articleId, 'publishedOn']), self::$i18nUI); ?>
getData(['module', $this->getUrl(0), 'config', 'articlesLenght']); ?> @@ -207,7 +207,7 @@
- + \ No newline at end of file diff --git a/module/blog/view/option/option.php b/module/blog/view/option/option.php index fd5d0bb..19fb1e3 100755 --- a/module/blog/view/option/option.php +++ b/module/blog/view/option/option.php @@ -36,7 +36,7 @@ ]); ?>
- 'Format des dates', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'dateFormat']) ]); ?> @@ -47,7 +47,7 @@ ]); ?>
- 'Format des heures', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'timeFormat']) ]); ?> @@ -55,19 +55,19 @@
- 'Disposition', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'layout']) ]); ?>
- 'Aperçus', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'articlesLenght']) ]); ?>
- 'Articles par page', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'itemsperPage']) ]); ?> @@ -91,5 +91,5 @@
Version n° - +
\ No newline at end of file diff --git a/module/form/form.php b/module/form/form.php index 5dd2a66..3b0bdff 100644 --- a/module/form/form.php +++ b/module/form/form.php @@ -503,6 +503,8 @@ class form extends common 'notification' => ($sent === true ? helper::translate('Formulaire soumis') : $sent), 'redirect' => $redirect ? helper::baseUrl() . $redirect : '', 'state' => ($sent === true ? true : false), + 'vendor' => [ + ], ]); } // Valeurs en sortie diff --git a/module/form/view/config/config.php b/module/form/view/config/config.php index b594e5f..c7d901c 100644 --- a/module/form/view/config/config.php +++ b/module/form/view/config/config.php @@ -16,7 +16,7 @@ ]); ?>
- 'formConfigType' ]); ?>
@@ -93,5 +93,5 @@
Version n° - +
diff --git a/module/form/view/data/data.php b/module/form/view/data/data.php index e8f600d..2064b71 100644 --- a/module/form/view/data/data.php +++ b/module/form/view/data/data.php @@ -22,12 +22,12 @@ ]); ?> - - - + + +
Version n° - +
\ No newline at end of file diff --git a/module/form/view/index/index.php b/module/form/view/index/index.php index b0dad14..1337963 100644 --- a/module/form/view/index/index.php +++ b/module/form/view/index/index.php @@ -6,12 +6,12 @@ ?>"> getData(['module', $this->getUrl(0), 'input']) as $index => $input): ?> - + 'formInput_' . $index, 'label' => $input['name'] ]); ?> - + $key) { @@ -22,28 +22,28 @@ 'id' => 'formInput_' . $index, 'label' => $input['name'] ]); ?> - + 'formInput_' . $index, 'label' => $input['name'] ]); ?> - + 'formInput_' . $index, 'label' => $input['name'] ]); ?> - + 'formInput_' . $index, 'label' => $input['name'], 'type' => 'date', ]); ?> - + - +


diff --git a/module/form/view/option/option.php b/module/form/view/option/option.php index 4539298..7f5c4d3 100644 --- a/module/form/view/option/option.php +++ b/module/form/view/option/option.php @@ -36,7 +36,7 @@ ]); ?>
- 'displayNone', 'label' => 'Page du site', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'pageId']) @@ -52,7 +52,7 @@

- 'Alignement du formulaire', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'align']) ]); ?> @@ -60,13 +60,13 @@
- 'Décalage à gauche', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'offset']) ]); ?>
- 'Largeur', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'width']) ]); ?> @@ -97,7 +97,7 @@
@@ -107,9 +107,9 @@ ]); ?>
- 'A un membre', - 'selected' => array_search($this->getData(['module', $this->getUrl(0), 'config', 'user']), $module::$listUsers) + 'selected' => array_search($this->getData(['module', $this->getUrl(0), 'config', 'user']), form::$listUsers) ]); ?>
@@ -121,7 +121,7 @@
- 'Type de signature', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'signature']) ]); ?> @@ -135,7 +135,7 @@ ]); ?>
- 'Largeur du logo', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'logoWidth']) ]); ?> diff --git a/module/gallery/changes.md b/module/gallery/changes.md index ee0354f..e143165 100644 --- a/module/gallery/changes.md +++ b/module/gallery/changes.md @@ -1,3 +1,5 @@ +# Version 4.3 +- Remplacement du nom générique de classe dans les vues. # Version 4.2 - Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts. # Version 4.1 diff --git a/module/gallery/gallery.php b/module/gallery/gallery.php index 5ebf94f..322e0bc 100644 --- a/module/gallery/gallery.php +++ b/module/gallery/gallery.php @@ -18,7 +18,7 @@ class gallery extends common { - const VERSION = '4.2'; + const VERSION = '4.3'; const REALNAME = 'Galerie'; const DATADIRECTORY = self::DATA_DIR . 'gallery/'; diff --git a/module/gallery/view/add/add.php b/module/gallery/view/add/add.php index d0d1830..8b5a73a 100644 --- a/module/gallery/view/add/add.php +++ b/module/gallery/view/add/add.php @@ -35,7 +35,7 @@
- $this->getData(['module', $this->getUrl(0), 'content', $this->getUrl(2), 'config', 'sort']), 'label' => 'Tri des images', 'help' => 'Tri manuel : déplacez le images dans le tableau ci-dessous. L\'ordre est sauvegardé automatiquement.' diff --git a/module/gallery/view/config/config.php b/module/gallery/view/config/config.php index 483cc51..d438669 100644 --- a/module/gallery/view/config/config.php +++ b/module/gallery/view/config/config.php @@ -31,14 +31,14 @@
- - 'galleryTable'],$module::$galleriesId); ?> + + 'galleryTable'],gallery::$galleriesId); ?>
Version n° - +
diff --git a/module/gallery/view/edit/edit.php b/module/gallery/view/edit/edit.php index f80d301..96a0ea0 100644 --- a/module/gallery/view/edit/edit.php +++ b/module/gallery/view/edit/edit.php @@ -19,8 +19,8 @@
- - 'galleryTable'], $module::$picturesId ); ?> + + 'galleryTable'], gallery::$picturesId ); ?> $this->getData(['module', $this->getUrl(0), 'content', $this->getUrl(2), 'config', 'sort' ])]);?> $this->getUrl(2)]); ?> @@ -30,6 +30,6 @@
Version n° - +
diff --git a/module/gallery/view/gallery/gallery.php b/module/gallery/view/gallery/gallery.php index 7d68a83..4d76f72 100644 --- a/module/gallery/view/gallery/gallery.php +++ b/module/gallery/view/gallery/gallery.php @@ -1,4 +1,4 @@ -
+
helper::baseUrl() . $this->getUrl(0), @@ -6,14 +6,14 @@ ]); ?>
-
- $legend): ?> + -
+
helper::baseUrl() . $this->getUrl(0), diff --git a/module/gallery/view/index/index.php b/module/gallery/view/index/index.php index d08b0b3..1dbcd38 100644 --- a/module/gallery/view/index/index.php +++ b/module/gallery/view/index/index.php @@ -1,11 +1,11 @@ - +
- $gallery): ?> + $gallery): ?>
diff --git a/module/gallery/view/option/option.php b/module/gallery/view/option/option.php index 8df9121..ecb961b 100644 --- a/module/gallery/view/option/option.php +++ b/module/gallery/view/option/option.php @@ -11,7 +11,7 @@
- +
@@ -29,7 +29,7 @@
- 'Position du bouton de retour à l\'index des galeries', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'showUniqueGallery']) === true ? 'none' @@ -40,7 +40,7 @@ ]); ?>
- 'Alignement du bouton de retour', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'showUniqueGallery']) === true ? 'none' @@ -54,7 +54,7 @@
- +
@@ -81,7 +81,7 @@
- $this->getData(['module', $this->getUrl(0), 'content', $this->getUrl(3), 'config', 'sort']), 'label' => 'Tri des images', 'help' => 'Tri manuel : déplacez le images dans le tableau ci-dessous. L\'ordre est sauvegardé automatiquement.' @@ -114,7 +114,7 @@
Version n° - +
\ No newline at end of file diff --git a/module/gallery/view/theme/theme.php b/module/gallery/view/theme/theme.php index f4fddf3..c09fc6a 100644 --- a/module/gallery/view/theme/theme.php +++ b/module/gallery/view/theme/theme.php @@ -17,25 +17,25 @@

- 'Largeur', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbWidth']) ]); ?>
- 'Hauteur', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbHeight']) ]); ?>
- 'Alignement', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbAlign']) ]); ?>
- 'Marge', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbMargin']) ]); ?> @@ -43,7 +43,7 @@
- 'Bordure', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbBorder']) ]); ?> @@ -57,7 +57,7 @@ ]); ?>
- 'Arrondi des angles', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbRadius']) ]); ?> @@ -65,7 +65,7 @@
- 'Ombre', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbShadows']) ]); ?> @@ -79,7 +79,7 @@ ]); ?>
- 'Opacité au survol', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','thumbOpacity']) ]); ?> @@ -110,13 +110,13 @@ ]); ?>
- 'Hauteur', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','legendHeight']) ]); ?>
- 'Alignement', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme','legendAlign']) ]); ?> @@ -128,7 +128,7 @@
Version n° - +
\ No newline at end of file diff --git a/module/news/changes.md b/module/news/changes.md index c662869..ecdc645 100644 --- a/module/news/changes.md +++ b/module/news/changes.md @@ -1,5 +1,7 @@ -# Versions 6.0 -- Ajoute deux nouvelles options pour afficher ou masquer la date et l'heure de l'article. +# Version 6.1 +- Remplacement du nom générique de classe dans les vues. +# Version 6.0 +- Ajoute trois nouvelles options pour afficher ou masquer la signature, la date et l'heure de l'article. - Corrige un mauvais format de la propriété buttonBack non stockée au type booléen. # Versions 5.9 - Largeur d'un bouton de retour. diff --git a/module/news/news.php b/module/news/news.php index 7b52f8e..7291d0e 100644 --- a/module/news/news.php +++ b/module/news/news.php @@ -16,7 +16,7 @@ class news extends common { - const VERSION = '6.0'; + const VERSION = '6.1'; const REALNAME = 'News'; const DATADIRECTORY = self::DATA_DIR . 'news/'; @@ -316,6 +316,7 @@ class news extends common 'buttonBack' => $this->getInput('newsOptionButtonBack', helper::FILTER_BOOLEAN), 'showDate' => $this->getInput('newsOptionShowDate', helper::FILTER_BOOLEAN), 'showTime' => $this->getInput('newsOptionShowTime', helper::FILTER_BOOLEAN), + 'showPseudo' => $this->getInput('newsOptionShowPseudo', helper::FILTER_BOOLEAN), 'versionData' => $this->getData(['module', $this->getUrl(0), 'config', 'versionData']), ] ]); @@ -621,6 +622,7 @@ class news extends common $this->setData(['module', $this->getUrl(0), 'config', 'buttonBack', true]); $this->setData(['module', $this->getUrl(0), 'config', 'showTime', true]); $this->setData(['module', $this->getUrl(0), 'config', 'showDate', true]); + $this->setData(['module', $this->getUrl(0), 'config', 'showPseudo', true]); // Mettre à jour la version $this->setData(['module', $this->getUrl(0), 'config', 'versionData', '6.0']); } diff --git a/module/news/view/add/add.php b/module/news/view/add/add.php index 525e159..e41947e 100644 --- a/module/news/view/add/add.php +++ b/module/news/view/add/add.php @@ -42,7 +42,7 @@

- 'Auteur', 'selected' => $this->getUser('id') ]); ?> diff --git a/module/news/view/article/article.php b/module/news/view/article/article.php index a0c037b..09dae2c 100644 --- a/module/news/view/article/article.php +++ b/module/news/view/article/article.php @@ -13,8 +13,12 @@
- - + getData(['module', $this->getUrl(0), 'config', 'showPseudo']) === true + ): ?> + + signature($this->getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'userId'])); ?> + getData(['module', $this->getUrl(0), 'config', 'showDate']) === true @@ -23,7 +27,7 @@ 'left']); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> + getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> getData(['module', $this->getUrl(0), 'config', 'showDate']) === true @@ -32,8 +36,8 @@ getData(['module', $this->getUrl(0), 'config', 'showTime']) === true): ?> - getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> - + getData(['module', $this->getUrl(0), 'posts', $this->getUrl(1), 'publishedOn']), self::$i18nUI); ?> + isConnected() === true and @@ -51,7 +55,7 @@
- - - + + +
Version n° - +
\ No newline at end of file diff --git a/module/news/view/edit/edit.php b/module/news/view/edit/edit.php index bb1a8d6..5e1abac 100644 --- a/module/news/view/edit/edit.php +++ b/module/news/view/edit/edit.php @@ -44,7 +44,7 @@

- 'Auteur', 'selected' => $this->getUser('id') ]); ?> diff --git a/module/news/view/index/index.php b/module/news/view/index/index.php index 8a97abe..270a2b5 100644 --- a/module/news/view/index/index.php +++ b/module/news/view/index/index.php @@ -1,4 +1,4 @@ - + getData(['module', $this->getUrl(0), 'config', 'feeds'])): ?> @@ -14,16 +14,20 @@
- + \ No newline at end of file diff --git a/module/news/view/option/option.php b/module/news/view/option/option.php index 9d16be8..05104aa 100644 --- a/module/news/view/option/option.php +++ b/module/news/view/option/option.php @@ -15,6 +15,18 @@

+
+
+ $this->getData(['module', $this->getUrl(0), 'config', 'buttonBack']) + ]); ?> +
+
+ $this->getData(['module', $this->getUrl(0), 'config', 'showPseudo']) + ]); ?> +
+
- 'Format des dates', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'dateFormat']) ]); ?> @@ -33,7 +45,7 @@ ]); ?>
- 'Format des heures', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'timeFormat']) ]); ?> @@ -41,31 +53,26 @@
- 'Nombre de colonnes', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'itemsperCol']) ]); ?>
- 'Articles par page', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'itemsperPage']) ]); ?>
- 'Abrégé de l\'article', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'height']) ]); ?>
-
- $this->getData(['module', $this->getUrl(0), 'config', 'buttonBack']) - ]); ?> -
-
+
$this->getData(['module', $this->getUrl(0), 'config', 'feeds']), 'help' => 'Flux limité aux articles de la première page.' @@ -87,13 +94,13 @@

- 'Bordure', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme', 'borderStyle']) ]); ?>
- 'Épaisseur', 'selected' => $this->getData(['module', $this->getUrl(0), 'theme', 'borderWidth']) ]); ?> @@ -120,5 +127,5 @@
Version n° - +
\ No newline at end of file diff --git a/module/search/changes.md b/module/search/changes.md index 2d9ce96..190bc68 100644 --- a/module/search/changes.md +++ b/module/search/changes.md @@ -1,5 +1,5 @@ # Version 3.3 -- Une seule lecture du fichier module.json +- Remplacement du nom générique de classe dans les vues. # Version 3.2 - Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts. # Version 3.1 diff --git a/module/search/search.php b/module/search/search.php index 97845f5..25818a5 100644 --- a/module/search/search.php +++ b/module/search/search.php @@ -172,43 +172,40 @@ class search extends common public function index() { + // Initialise un module non configuré $this->init(); - - if ($this->isPost()) { + + if ( + $this->isPost() + ) { //Initialisations variables $success = true; $result = []; $notification = ''; $total = ''; - + // Récupération du mot clef passé par le formulaire de ...view/index.php, avec caractères accentués self::$motclef = $this->getInput('searchMotphraseclef'); // Variable de travail, on conserve la variable globale pour l'affichage du résultat $motclef = self::$motclef; - - // Suppression des mots < 3 caractères et des articles > 2 caractères de la chaîne $motclef + + // Suppression des mots < 3 caractères et des articles > 2 caractères de la chaîne $motclef $arraymotclef = explode(' ', $motclef); $motclef = ''; foreach ($arraymotclef as $key => $value) { - if (strlen($value) > 2 && $value !== 'les' && $value !== 'des' && $value !== 'une' && $value !== 'aux') { + if (strlen($value) > 2 && $value !== 'les' && $value !== 'des' && $value !== 'une' && $value !== 'aux') $motclef .= $value . ' '; - } } // Suppression du dernier ' ' - if ($motclef !== '') { + if ($motclef !== '') $motclef = substr($motclef, 0, strlen($motclef) - 1); - } - + // Récupération de l'état de l'option mot entier passé par le même formulaire self::$motentier = $this->getInput('searchMotentier', helper::FILTER_BOOLEAN); - - // Lecture unique des données du module - $moduleData = $this->getData(['module']); - + if ($motclef !== '') { foreach ($this->getHierarchy(null, false, null) as $parentId => $childIds) { - // Vérification des conditions pour la page parente if ( $this->getData(['page', $parentId, 'disable']) === false && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && @@ -216,6 +213,7 @@ class search extends common ) { $url = $parentId; $titre = $this->getData(['page', $parentId, 'title']); + //$content = file_get_contents(self::DATA_DIR . self::$siteContent . '/content/' . $this->getData(['page', $parentId, 'content'])); $content = $this->getPage($parentId, self::$siteContent); $content = $titre . ' ' . $content; // Pages sauf pages filles et articles de blog @@ -224,9 +222,9 @@ class search extends common $result[] = $tempData; } } - - // Vérification des sous-pages et articles de sous-pages + foreach ($childIds as $childId) { + // Sous page if ( $this->getData(['page', $childId, 'disable']) === false && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && @@ -234,21 +232,24 @@ class search extends common ) { $url = $childId; $titre = $this->getData(['page', $childId, 'title']); + //$content = file_get_contents(self::DATA_DIR . self::$siteContent . '/content/' . $this->getData(['page', $childId, 'content'])); $content = $this->getPage($childId, self::$siteContent); $content = $titre . ' ' . $content; + //Pages filles $tempData = $this->occurrence($url, $titre, $content, $motclef, self::$motentier); if (is_array($tempData)) { $result[] = $tempData; } } - + // Articles d'une sous-page blog ou de news - if (isset($moduleData[$childId]['posts'])) { - foreach ($moduleData[$childId]['posts'] as $articleId => $article) { - if ($article['state'] === true) { + if ($this->getData(['module', $childId, 'posts'])) { + foreach ($this->getData(['module', $childId, 'posts']) as $articleId => $article) { + if ($this->getData(['module', $childId, 'posts', $articleId, 'state']) === true) { $url = $childId . '/' . $articleId; $titre = $article['title']; $contenu = ' ' . $titre . ' ' . $article['content']; + // Articles de sous-page de type blog $tempData = $this->occurrence($url, $titre, $contenu, $motclef, self::$motentier); if (is_array($tempData)) { $result[] = $tempData; @@ -257,11 +258,12 @@ class search extends common } } } - + // Articles d'un blog ou de news - if (isset($moduleData[$parentId]['posts'])) { - foreach ($moduleData[$parentId]['posts'] as $articleId => $article) { - if ($article['state'] === true) { + if ($this->getData(['module', $parentId, 'posts'])) { + + foreach ($this->getData(['module', $parentId, 'posts']) as $articleId => $article) { + if ($this->getData(['module', $parentId, 'posts', $articleId, 'state']) === true) { $url = $parentId . '/' . $articleId; $titre = $article['title']; $contenu = ' ' . $titre . ' ' . $article['content']; @@ -273,21 +275,22 @@ class search extends common } } } - // Message de synthèse de la recherche if (count($result) === 0) { self::$resultTitle = helper::translate('Aucun résultat'); self::$resultError = helper::translate('Avez-vous pensé aux accents ?'); } else { self::$resultError = ''; + //self::$resultTitle = sprintf(' %s',helper::translate('Résultat de votre recherche')); rsort($result); foreach ($result as $key => $value) { $r[] = $value['preview']; } + // Générer une chaine de caractères self::$resultList = implode("", $r); } } - + // Valeurs en sortie, affichage du résultat $this->addOutput([ 'view' => 'index', @@ -306,8 +309,6 @@ class search extends common ]); } } - - // Fonction de recherche des occurrences dans $contenu diff --git a/module/search/view/config/config.php b/module/search/view/config/config.php index 09c698f..013e059 100644 --- a/module/search/view/config/config.php +++ b/module/search/view/config/config.php @@ -23,7 +23,7 @@ ]); ?>
- 'Dimension de l\'aperçu', 'selected' => $this->getData(['module', $this->getUrl(0), 'config', 'previewLength']) ]); ?> @@ -66,5 +66,5 @@
Version n° - +
\ No newline at end of file diff --git a/module/search/view/index/index.php b/module/search/view/index/index.php index 4f685ed..35f7782 100644 --- a/module/search/view/index/index.php +++ b/module/search/view/index/index.php @@ -5,7 +5,7 @@
$this->getData(['module', $this->getUrl(0), 'config', 'placeHolder']) ? $this->getData(['module', $this->getUrl(0), 'config', 'placeHolder']) : 'Un ou plusieurs mots clef séparés par un espace', - 'value' => $module::$motclef + 'value' => search::$motclef ]); ?>
getData(['module', $this->getUrl(0), 'config', 'submitText'])) ? 'col1' : 'col3'; ?> @@ -19,7 +19,7 @@
$module::$motentier, + 'checked' => search::$motentier, ]); ?>
@@ -27,14 +27,14 @@
- - ' . $module::$resultList . '

'; + ' . search::$resultList . '

'; ?> - ' . $module::$resultError . '

'; + ' . search::$resultError . '

'; ?>
diff --git a/module/slider/changes.md b/module/slider/changes.md index 051ea44..fbfe7d3 100644 --- a/module/slider/changes.md +++ b/module/slider/changes.md @@ -1,5 +1,9 @@ +# Version 7.3 +- Remplacement du nom générique de classe dans les vues. +# Version 7.2 +- Le dossier sélectionné est affiché par défaut dans la page update. # Version 7.1 - +- Améliore le desgin du module # Version 7.0 - Ajoute un affichage de la légende sous l'image - Corrige un tri inversé diff --git a/module/slider/slider.php b/module/slider/slider.php index 125d7f7..7ed2353 100644 --- a/module/slider/slider.php +++ b/module/slider/slider.php @@ -27,7 +27,7 @@ class slider extends common 'index' => self::GROUP_VISITOR ]; - const VERSION = '7.1'; + const VERSION = '7.3'; const REALNAME = 'Carrousel'; const DELETE = true; const UPDATE = '0.0'; diff --git a/module/slider/view/config/config.php b/module/slider/view/config/config.php index 6a445f2..d440df5 100644 --- a/module/slider/view/config/config.php +++ b/module/slider/view/config/config.php @@ -38,8 +38,8 @@
- - + + @@ -50,5 +50,5 @@
Module Slider version n° - +
\ No newline at end of file diff --git a/module/slider/view/index/index.php b/module/slider/view/index/index.php index 06dc297..8ab1b7e 100644 --- a/module/slider/view/index/index.php +++ b/module/slider/view/index/index.php @@ -1,8 +1,8 @@ - +