Moteur de recherche - résultats condensés

This commit is contained in:
Fred Tempez 2020-08-19 15:18:57 +02:00
parent 6647cf8bea
commit 6a075b9880
3 changed files with 52 additions and 70 deletions

View File

@ -23,18 +23,17 @@ class search extends common {
'config' => self::GROUP_MODERATOR 'config' => self::GROUP_MODERATOR
]; ];
// Variable pour l'affichage des résultats
public static $resultList = ''; public static $resultList = '';
public static $resultError = '';
public static $nbResults = 0;
public static $resultTitle = ''; public static $resultTitle = '';
public static $nbResults = 0;
public static $motclef = ''; public static $motclef = '';
public static $motentier = ''; public static $motentier = '';
// paramètres pas défaut
public static $defaultButtonText = 'Rechercher'; public static $defaultButtonText = 'Rechercher';
public static $defaultPlaceHolder = 'Entrez un ou plusieurs mots-clés.'; public static $defaultPlaceHolder = 'Entrez un ou plusieurs mots-clés.';
const SEARCH_VERSION = '1.1'; const SEARCH_VERSION = '1.1';
@ -78,7 +77,6 @@ class search extends common {
self::$motentier=$this->getInput('searchMotentier', helper::FILTER_BOOLEAN); self::$motentier=$this->getInput('searchMotentier', helper::FILTER_BOOLEAN);
//Pour affichage de l'entête du résultat //Pour affichage de l'entête du résultat
self::$resultTitle = 'Aucun résultat';
$keywords = '/('; $keywords = '/(';
$a = explode(' ',self::$motclef); $a = explode(' ',self::$motclef);
foreach ($a as $key => $value) { foreach ($a as $key => $value) {
@ -97,8 +95,9 @@ class search extends common {
$titre = $this->getData(['page', $parentId, 'title']); $titre = $this->getData(['page', $parentId, 'title']);
$contenu = $this->getData(['page', $parentId, 'content']); $contenu = $this->getData(['page', $parentId, 'content']);
// Pages sauf pages filles et articles de blog // Pages sauf pages filles et articles de blog
if (!empty($this->occurrence($url, $titre, $contenu, $keywords, self::$motentier)) ) { $tempData = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
$result [] = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier); if (is_array($tempData) ) {
$result [] = $tempData;
} }
} }
@ -111,8 +110,9 @@ class search extends common {
$titre = $this->getData(['page', $childId, 'title']); $titre = $this->getData(['page', $childId, 'title']);
$contenu = $this->getData(['page', $childId, 'content']); $contenu = $this->getData(['page', $childId, 'content']);
//Pages filles //Pages filles
if (!empty($this->occurrence($url, $titre, $contenu, $keywords, self::$motentier)) ) { $tempData = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
$result [] = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier); if (is_array($tempData) ) {
$result [] = $tempData;
} }
} }
@ -125,8 +125,9 @@ class search extends common {
$titre = $article['title']; $titre = $article['title'];
$contenu = $article['content']; $contenu = $article['content'];
// Articles de sous-page de type blog // Articles de sous-page de type blog
if (!empty($this->occurrence($url, $titre, $contenu, $keywords, self::$motentier)) ) { $tempData = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
$result [] = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier); if (is_array($tempData) ) {
$result [] = $tempData;
} }
} }
} }
@ -134,7 +135,6 @@ class search extends common {
} }
// Articles d'un blog // Articles d'un blog
if ($this->getData(['page', $parentId, 'moduleId']) === 'blog' ) { if ($this->getData(['page', $parentId, 'moduleId']) === 'blog' ) {
foreach($this->getData(['module',$parentId]) as $articleId => $article) { foreach($this->getData(['module',$parentId]) as $articleId => $article) {
if($this->getData(['module',$parentId,$articleId,'state']) === true) if($this->getData(['module',$parentId,$articleId,'state']) === true)
@ -143,44 +143,34 @@ class search extends common {
$titre = $article['title']; $titre = $article['title'];
$contenu = $article['content']; $contenu = $article['content'];
// Articles de Blog // Articles de Blog
if (!empty($this->occurrence($url, $titre, $contenu, $keywords, self::$motentier)) ) { $tempData = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
$result [] = $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier); if (is_array($tempData) ) {
$result [] = $tempData;
} }
} }
} }
} }
} }
// Message de synthèse de la recherche
if (self::$nbResults === 0) {
$result [] ='Avez-vous pensé aux accents ?'; // Message de synthèse de la recherche
$success = false; if (count($result) === 0) {
self::$resultTitle = 'Aucun résultat';
self::$resultError = 'Avez-vous pensé aux accents ?';
} else { } else {
//$r = self::$nbResults == 1 ? '' : '( ' .self::$nbResults . ' éléments découverts )'; self::$resultError = '';
self::$resultTitle = ' Résultat de votre recherche';// ' . $r ; self::$resultTitle = ' Résultat de votre recherche';
$success = true; rsort($result);
foreach ($result as $key => $value) {
$r [] = $value['preview'];
}
// Générer une chaine de caractères
self::$resultList= implode("<br />", $r);
} }
} else { } else {
$result [] = 'Trop court ! Minimum 3 caract&egrave;res'; self::$resultTitle = 'Aucun résultat';
$success = false; self::$resultError = 'Trop court ! Minimum 3 caract&egrave;res';
} }
// Calculer les longeurs des résultats dans $t
foreach ($result as $key => $value) {
$t[$key] = strlen($value);
}
// Trier $t par longueur de chaines
rsort($t);
// Affecter la nouvelle liste dans $r
foreach ($t as $key => $value) {
foreach ($result as $keyResult => $valueResult) {
if (strlen($result[$keyResult]) === $value) {
$r [] = $result[$keyResult];
continue;
}
}
}
// Générer une chaine de cararctères
self::$resultList= implode("<br />", $r);
// Valeurs en sortie, affichage du résultat // Valeurs en sortie, affichage du résultat
$this->addOutput([ $this->addOutput([
'view' => 'index', 'view' => 'index',
@ -207,34 +197,29 @@ class search extends common {
// Accentuation // Accentuation
$contenu = html_entity_decode($contenu); $contenu = html_entity_decode($contenu);
// Initialisations // Initialisations
$nboccu = 0;
$dejavu = ''; $valid = preg_match_all($motclef,$contenu,$matches,PREG_OFFSET_CAPTURE);
$total = ''; if ($valid > 0 ) {
$resultat= ''; if (($matches[0][0][1]) > 0) {
$occu = preg_match_all($motclef,$contenu,$matches,PREG_OFFSET_CAPTURE); $resultat = '<h2><a href="./?'.$url.'" target="_blank" rel="noopener">' . $titre . '</a></h2>';
if ($occu !== false && !empty($matches[0]) ) {
if ($titre !== $dejavu) {
$resultat = '<h3><a class="searchTitle" href="./?'.$url.'" target="_blank" rel="noopener">'.$titre.'</a></h3>';
}
$dejavu = $titre;
$nboccu .= count($matches[0]);
foreach ($matches[0] as $key => $value) {
// Création de l'aperçu // Création de l'aperçu
// Eviter de découper avec une valeur négative // Eviter de découper avec une valeur négative
$d = $value[1] - 50 < 0 ? 1 : $value[1] - 50; $d = $matches[0][0][1] - 50 < 0 ? 1 : $matches[0][0][1] - 50;
// Eviter de découper avec une valeur au-delà de la longueur
$d = $value[1] - 50 < 0 ? 1 : $value[1] - 50;
// Rechercher l'espace le plus proche // Rechercher l'espace le plus proche
$d = $d > 1 ? strpos($contenu,' ',$d) : $d; $d = $d > 1 ? strpos($contenu,' ',$d) : $d;
// Découper l'aperçu // Découper l'aperçu
$t = substr($contenu,(int) $d ,200); $t = substr($contenu,(int) $d ,300);
// Applique une mise en évidence // Applique une mise en évidence
$t = preg_replace($motclef, '<span class="searchKeyword">\1</span>',$t); $t = preg_replace($motclef, '<span class="searchKeyword">\1</span>',$t);
// Sauver résultat // Sauver résultat
$resultat .='<div class="searchResult">'.$t.'...</div>'; $resultat .= '<p class="searchResult">'.$t.'...</p>';
$resultat .= '<p class="searchTitle">'.count($matches[0]) . ' occurence(s)<p>';
//}
return ([
'matches' => count($matches[0]),
'preview' => $resultat
]);
} }
} }
self::$nbResults = self::$nbResults + $nboccu; // Nombre total d'occurences
return $resultat;
} }
} }

View File

@ -1,5 +1,7 @@
.seachTitle { .searchTitle {
/* rien */ font: caption;
font-style: italic;
margin-left: .5em;
} }
.searchKeyword { .searchKeyword {
background: yellow; background: yellow;

View File

@ -23,16 +23,11 @@
</div> </div>
</div> </div>
</div> </div>
<?php if ($module::$resultTitle && $module::$resultList): ?>
<div class="col12"> <div class="col12">
<div class="block"> <div class="block">
<h4><?php echo $module::$resultTitle; ?></h4> <h4><?php echo $module::$resultTitle; ?></h4>
<?php if (!empty($module::$resultList)) { <p><?php echo $module::$resultList; ?>
echo( $module::$resultList ); <p><?php echo $module::$resultError; ?>
} else {
echo "Rien à afficher";
} ?>
</div> </div>
</div> </div>
<?php endif;?>
<?php echo template::formClose(); ?> <?php echo template::formClose(); ?>