forked from ZwiiCMS-Team/ZwiiCMS
Regex de nettoyage + mise en évidence
This commit is contained in:
parent
6976594a14
commit
784a4935fd
@ -25,7 +25,7 @@ class init extends common {
|
|||||||
'timezone' => 'Europe/Paris',
|
'timezone' => 'Europe/Paris',
|
||||||
'itemsperPage' => 10,
|
'itemsperPage' => 10,
|
||||||
'legalPageId' => 'mentions-legales',
|
'legalPageId' => 'mentions-legales',
|
||||||
'searchPageId' => 'rechercher',
|
'searchPageId' => 'recherche',
|
||||||
'metaDescription' => 'Zwii est un CMS sans base de données qui permet de créer et gérer facilement un site web sans aucune connaissance en programmation.',
|
'metaDescription' => 'Zwii est un CMS sans base de données qui permet de créer et gérer facilement un site web sans aucune connaissance en programmation.',
|
||||||
'title' => 'Votre site en quelques clics !',
|
'title' => 'Votre site en quelques clics !',
|
||||||
'proxyUrl' => '',
|
'proxyUrl' => '',
|
||||||
@ -112,7 +112,7 @@ class init extends common {
|
|||||||
'displaySiteMap' => true,
|
'displaySiteMap' => true,
|
||||||
'displayCopyright' => false,
|
'displayCopyright' => false,
|
||||||
'displayLegal' => false,
|
'displayLegal' => false,
|
||||||
'displaySearch' => false,
|
'displaySearch' => true,
|
||||||
'displayMemberBar' => false,
|
'displayMemberBar' => false,
|
||||||
'template' => '3'
|
'template' => '3'
|
||||||
],
|
],
|
||||||
|
@ -35,7 +35,7 @@ class search extends common {
|
|||||||
|
|
||||||
public static $defaultButtonText = 'Rechercher';
|
public static $defaultButtonText = 'Rechercher';
|
||||||
|
|
||||||
public static $defaultPlaceHolder = 'Un mot clé ou une phrase entière sans guillemets';
|
public static $defaultPlaceHolder = 'Que recherchez-vous ?';
|
||||||
|
|
||||||
const SEARCH_VERSION = '1.1';
|
const SEARCH_VERSION = '1.1';
|
||||||
|
|
||||||
@ -153,17 +153,15 @@ class search extends common {
|
|||||||
}
|
}
|
||||||
// Message de synthèse de la recherche
|
// Message de synthèse de la recherche
|
||||||
if (self::$nbResults === 0) {
|
if (self::$nbResults === 0) {
|
||||||
$notification = 'Mot clef non trouvé. Avez-vous pensé aux accents ?';
|
|
||||||
$result .='Mot clef non trouvé. Avez-vous pensé aux accents ?';
|
$result .='Aucun résultat. Avez-vous pensé aux accents ?';
|
||||||
$success = false;
|
$success = false;
|
||||||
} else {
|
} else {
|
||||||
//$result .= self::$nbResults .' occurrences ont été trouvées.';
|
$r = self::$nbResults == 1 ? '' : '( ' .self::$nbResults . ' éléments découverts )';
|
||||||
$notification = 'Nombre d\'occurrences : '.self::$nbResults;
|
self::$resultTitle = ' Résultat de votre recherche ' . $r ;
|
||||||
self::$resultTitle = 'Résultat(s) : "' . self::$motclef . '" a été trouvé '. self::$nbResults . ' fois';
|
|
||||||
$success = true;
|
$success = true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$notification = 'Trop court ! Minimum 3 caractères';
|
|
||||||
$result = 'Trop court ! Minimum 3 caractères';
|
$result = 'Trop court ! Minimum 3 caractères';
|
||||||
$success = false;
|
$success = false;
|
||||||
}
|
}
|
||||||
@ -172,8 +170,6 @@ class search extends common {
|
|||||||
// Valeurs en sortie, affichage du résultat
|
// Valeurs en sortie, affichage du résultat
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'view' => 'index',
|
'view' => 'index',
|
||||||
'notification' => $notification,
|
|
||||||
'state' => $success,
|
|
||||||
'showBarEditButton' => true,
|
'showBarEditButton' => true,
|
||||||
'showPageContent' => !$this->getData(['module', $this->getUrl(0),'resultHideContent'])
|
'showPageContent' => !$this->getData(['module', $this->getUrl(0),'resultHideContent'])
|
||||||
]);
|
]);
|
||||||
@ -193,7 +189,7 @@ class search extends common {
|
|||||||
private function occurrence($url, $titre, $contenu, $motclef, $motentier)
|
private function occurrence($url, $titre, $contenu, $motclef, $motentier)
|
||||||
{
|
{
|
||||||
// Nettoyage de $contenu : on enlève tout ce qui est inclus entre < et >
|
// Nettoyage de $contenu : on enlève tout ce qui est inclus entre < et >
|
||||||
$contenu = $this->nettoyer_html($contenu);
|
$contenu = preg_replace ('/<[^>]*>/', ' ', $contenu);
|
||||||
// Accentuation
|
// Accentuation
|
||||||
$contenu = html_entity_decode($contenu);
|
$contenu = html_entity_decode($contenu);
|
||||||
// Initialisations
|
// Initialisations
|
||||||
@ -213,34 +209,25 @@ class search extends common {
|
|||||||
}
|
}
|
||||||
$dejavu = $titre;
|
$dejavu = $titre;
|
||||||
$nboccu .= count($matches[0]);
|
$nboccu .= count($matches[0]);
|
||||||
$contenu = preg_replace($motclef, '<span class="evidence">\1</span>', $contenu);
|
|
||||||
foreach ($matches[0] as $key => $value) {
|
foreach ($matches[0] as $key => $value) {
|
||||||
//$resultat .= '<p>'.$nboccu.' - "...<em>'.substr($contenu,$value[1] ,200).'</em>..."<br/></p>'; # code...
|
// Mise en évidence
|
||||||
$resultat .= '"<em>'.substr($contenu,$value[1] ,200).'</em>..."<br/></p>'; # code...
|
$d = $value[1] -50 < 0 ? 1 : $value[1] - 50;
|
||||||
|
$t = substr($contenu,(int) $d ,150);
|
||||||
|
// Nettoyage caractères invalides
|
||||||
|
$t = preg_replace('/[^[:alnum:][:space:]]/u', '', $t);
|
||||||
|
// Applique une mise en évidence
|
||||||
|
$t = preg_replace($motclef, '<span class="evidence">\1</span>',$t,1);
|
||||||
|
// Sauver résultat
|
||||||
|
$resultat .='"<em>'.$t.'</em>..."</p>';
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Pour recherche d'une autre occurrence dans le même contenu
|
// Pour recherche d'une autre occurrence dans le même contenu
|
||||||
$contenu = substr($occu,10);
|
$contenu = substr($occu,10);
|
||||||
}
|
}
|
||||||
while($occu != '');
|
while($occu != '');
|
||||||
self::$nbResults = self::$nbResults + $nboccu;
|
self::$nbResults = self::$nbResults + $nboccu; // Nombre total d'occurences
|
||||||
|
|
||||||
return $resultat;
|
return $resultat;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Déclaration de la fonction nettoyer(string $contenu) : string
|
|
||||||
// Supprime de $contenu les caractères placés entre < et >, donc les balises html comme <p> <br/> etc...
|
|
||||||
// Retourne $contenu nettoyée, le résultat est sensiblement différent de celui obtenu avec la fonction strip_tags()
|
|
||||||
private function nettoyer_html($contenu)
|
|
||||||
{
|
|
||||||
do {
|
|
||||||
$pos1=strpos($contenu,chr(60));
|
|
||||||
if($pos1!==false) {
|
|
||||||
$pos2=strpos($contenu,chr(62));
|
|
||||||
if($pos2!==false) $contenu=substr_replace($contenu," ",$pos1,($pos2 - $pos1 + 1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while($pos1!==false);
|
|
||||||
return $contenu;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
<div class="block">
|
<div class="block">
|
||||||
<h4><?php echo $module::$resultTitle; ?></h4>
|
<h4><?php echo $module::$resultTitle; ?></h4>
|
||||||
<?php if (!empty($module::$resultList)) {
|
<?php if (!empty($module::$resultList)) {
|
||||||
echo $module::$resultList;
|
echo( $module::$resultList );
|
||||||
} else {
|
} else {
|
||||||
echo "Rien à afficher";
|
echo "Rien à afficher";
|
||||||
} ?>
|
} ?>
|
||||||
|
Loading…
Reference in New Issue
Block a user