Search 3.3 une seule lecture de module

This commit is contained in:
Fred Tempez 2024-09-07 09:53:54 +02:00
parent c244651b62
commit f7cf0f94fc
3 changed files with 33 additions and 32 deletions

View File

@ -51,7 +51,7 @@ class common
const ACCESS_TIMER = 1800; const ACCESS_TIMER = 1800;
// Numéro de version // Numéro de version
const ZWII_VERSION = '1.12.01'; const ZWII_VERSION = '1.12.02';
// URL autoupdate // URL autoupdate
const ZWII_UPDATE_URL = 'https://forge.chapril.org/ZwiiCMS-Team/campus-update/raw/branch/master/'; const ZWII_UPDATE_URL = 'https://forge.chapril.org/ZwiiCMS-Team/campus-update/raw/branch/master/';

View File

@ -1,3 +1,5 @@
# Version 3.3
- Une seule lecture du fichier module.json
# Version 3.2 # Version 3.2
- Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts. - Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts.
# Version 3.1 # Version 3.1

View File

@ -20,7 +20,7 @@
class search extends common class search extends common
{ {
const VERSION = '3.2'; const VERSION = '3.3';
const REALNAME = 'Recherche'; const REALNAME = 'Recherche';
const DATADIRECTORY = self::DATA_DIR . 'search/'; const DATADIRECTORY = self::DATA_DIR . 'search/';
@ -172,40 +172,43 @@ class search extends common
public function index() public function index()
{ {
// Initialise un module non configuré // Initialise un module non configuré
$this->init(); $this->init();
if ( if ($this->isPost()) {
$this->isPost()
) {
//Initialisations variables //Initialisations variables
$success = true; $success = true;
$result = []; $result = [];
$notification = ''; $notification = '';
$total = ''; $total = '';
// Récupération du mot clef passé par le formulaire de ...view/index.php, avec caractères accentués // Récupération du mot clef passé par le formulaire de ...view/index.php, avec caractères accentués
self::$motclef = $this->getInput('searchMotphraseclef'); self::$motclef = $this->getInput('searchMotphraseclef');
// Variable de travail, on conserve la variable globale pour l'affichage du résultat // Variable de travail, on conserve la variable globale pour l'affichage du résultat
$motclef = self::$motclef; $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); $arraymotclef = explode(' ', $motclef);
$motclef = ''; $motclef = '';
foreach ($arraymotclef as $key => $value) { 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 . ' '; $motclef .= $value . ' ';
}
} }
// Suppression du dernier ' ' // Suppression du dernier ' '
if ($motclef !== '') if ($motclef !== '') {
$motclef = substr($motclef, 0, strlen($motclef) - 1); $motclef = substr($motclef, 0, strlen($motclef) - 1);
}
// Récupération de l'état de l'option mot entier passé par le même formulaire // 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); self::$motentier = $this->getInput('searchMotentier', helper::FILTER_BOOLEAN);
// Lecture unique des données du module
$moduleData = $this->getData(['module']);
if ($motclef !== '') { if ($motclef !== '') {
foreach ($this->getHierarchy(null, false, null) as $parentId => $childIds) { foreach ($this->getHierarchy(null, false, null) as $parentId => $childIds) {
// Vérification des conditions pour la page parente
if ( if (
$this->getData(['page', $parentId, 'disable']) === false && $this->getData(['page', $parentId, 'disable']) === false &&
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
@ -213,7 +216,6 @@ class search extends common
) { ) {
$url = $parentId; $url = $parentId;
$titre = $this->getData(['page', $parentId, 'title']); $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 = $this->getPage($parentId, self::$siteContent);
$content = $titre . ' ' . $content; $content = $titre . ' ' . $content;
// Pages sauf pages filles et articles de blog // Pages sauf pages filles et articles de blog
@ -222,9 +224,9 @@ class search extends common
$result[] = $tempData; $result[] = $tempData;
} }
} }
// Vérification des sous-pages et articles de sous-pages
foreach ($childIds as $childId) { foreach ($childIds as $childId) {
// Sous page
if ( if (
$this->getData(['page', $childId, 'disable']) === false && $this->getData(['page', $childId, 'disable']) === false &&
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) && $this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
@ -232,24 +234,21 @@ class search extends common
) { ) {
$url = $childId; $url = $childId;
$titre = $this->getData(['page', $childId, 'title']); $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 = $this->getPage($childId, self::$siteContent);
$content = $titre . ' ' . $content; $content = $titre . ' ' . $content;
//Pages filles
$tempData = $this->occurrence($url, $titre, $content, $motclef, self::$motentier); $tempData = $this->occurrence($url, $titre, $content, $motclef, self::$motentier);
if (is_array($tempData)) { if (is_array($tempData)) {
$result[] = $tempData; $result[] = $tempData;
} }
} }
// Articles d'une sous-page blog ou de news // Articles d'une sous-page blog ou de news
if ($this->getData(['module', $childId, 'posts'])) { if (isset($moduleData[$childId]['posts'])) {
foreach ($this->getData(['module', $childId, 'posts']) as $articleId => $article) { foreach ($moduleData[$childId]['posts'] as $articleId => $article) {
if ($this->getData(['module', $childId, 'posts', $articleId, 'state']) === true) { if ($article['state'] === true) {
$url = $childId . '/' . $articleId; $url = $childId . '/' . $articleId;
$titre = $article['title']; $titre = $article['title'];
$contenu = ' ' . $titre . ' ' . $article['content']; $contenu = ' ' . $titre . ' ' . $article['content'];
// Articles de sous-page de type blog
$tempData = $this->occurrence($url, $titre, $contenu, $motclef, self::$motentier); $tempData = $this->occurrence($url, $titre, $contenu, $motclef, self::$motentier);
if (is_array($tempData)) { if (is_array($tempData)) {
$result[] = $tempData; $result[] = $tempData;
@ -258,12 +257,11 @@ class search extends common
} }
} }
} }
// Articles d'un blog ou de news // Articles d'un blog ou de news
if ($this->getData(['module', $parentId, 'posts'])) { if (isset($moduleData[$parentId]['posts'])) {
foreach ($moduleData[$parentId]['posts'] as $articleId => $article) {
foreach ($this->getData(['module', $parentId, 'posts']) as $articleId => $article) { if ($article['state'] === true) {
if ($this->getData(['module', $parentId, 'posts', $articleId, 'state']) === true) {
$url = $parentId . '/' . $articleId; $url = $parentId . '/' . $articleId;
$titre = $article['title']; $titre = $article['title'];
$contenu = ' ' . $titre . ' ' . $article['content']; $contenu = ' ' . $titre . ' ' . $article['content'];
@ -275,22 +273,21 @@ class search extends common
} }
} }
} }
// Message de synthèse de la recherche // Message de synthèse de la recherche
if (count($result) === 0) { if (count($result) === 0) {
self::$resultTitle = helper::translate('Aucun résultat'); self::$resultTitle = helper::translate('Aucun résultat');
self::$resultError = helper::translate('Avez-vous pensé aux accents ?'); self::$resultError = helper::translate('Avez-vous pensé aux accents ?');
} else { } else {
self::$resultError = ''; self::$resultError = '';
//self::$resultTitle = sprintf(' %s',helper::translate('Résultat de votre recherche'));
rsort($result); rsort($result);
foreach ($result as $key => $value) { foreach ($result as $key => $value) {
$r[] = $value['preview']; $r[] = $value['preview'];
} }
// Générer une chaine de caractères
self::$resultList = implode("", $r); self::$resultList = implode("", $r);
} }
} }
// Valeurs en sortie, affichage du résultat // Valeurs en sortie, affichage du résultat
$this->addOutput([ $this->addOutput([
'view' => 'index', 'view' => 'index',
@ -309,6 +306,8 @@ class search extends common
]); ]);
} }
} }
// Fonction de recherche des occurrences dans $contenu // Fonction de recherche des occurrences dans $contenu