From 784a4935fdb129270086841be1b2c3e9d0d92f47 Mon Sep 17 00:00:00 2001
From: Fred Tempez
Date: Mon, 17 Aug 2020 10:39:44 +0200
Subject: [PATCH] =?UTF-8?q?Regex=20de=20nettoyage=20+=20mise=20en=20=C3=A9?=
=?UTF-8?q?vidence?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
core/module/install/ressource/defaultdata.php | 4 +-
module/search/search.php | 47 +++++++------------
module/search/view/index/index.php | 2 +-
3 files changed, 20 insertions(+), 33 deletions(-)
diff --git a/core/module/install/ressource/defaultdata.php b/core/module/install/ressource/defaultdata.php
index 7947f2b0..b2ac445e 100755
--- a/core/module/install/ressource/defaultdata.php
+++ b/core/module/install/ressource/defaultdata.php
@@ -25,7 +25,7 @@ class init extends common {
'timezone' => 'Europe/Paris',
'itemsperPage' => 10,
'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.',
'title' => 'Votre site en quelques clics !',
'proxyUrl' => '',
@@ -112,7 +112,7 @@ class init extends common {
'displaySiteMap' => true,
'displayCopyright' => false,
'displayLegal' => false,
- 'displaySearch' => false,
+ 'displaySearch' => true,
'displayMemberBar' => false,
'template' => '3'
],
diff --git a/module/search/search.php b/module/search/search.php
index 540dd4c1..fd19d10f 100755
--- a/module/search/search.php
+++ b/module/search/search.php
@@ -35,7 +35,7 @@ class search extends common {
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';
@@ -153,17 +153,15 @@ class search extends common {
}
// Message de synthèse de la recherche
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;
} else {
- //$result .= self::$nbResults .' occurrences ont été trouvées.';
- $notification = 'Nombre d\'occurrences : '.self::$nbResults;
- self::$resultTitle = 'Résultat(s) : "' . self::$motclef . '" a été trouvé '. self::$nbResults . ' fois';
+ $r = self::$nbResults == 1 ? '' : '( ' .self::$nbResults . ' éléments découverts )';
+ self::$resultTitle = ' Résultat de votre recherche ' . $r ;
$success = true;
}
} else {
- $notification = 'Trop court ! Minimum 3 caractères';
$result = 'Trop court ! Minimum 3 caractères';
$success = false;
}
@@ -172,8 +170,6 @@ class search extends common {
// Valeurs en sortie, affichage du résultat
$this->addOutput([
'view' => 'index',
- 'notification' => $notification,
- 'state' => $success,
'showBarEditButton' => true,
'showPageContent' => !$this->getData(['module', $this->getUrl(0),'resultHideContent'])
]);
@@ -193,7 +189,7 @@ class search extends common {
private function occurrence($url, $titre, $contenu, $motclef, $motentier)
{
// Nettoyage de $contenu : on enlève tout ce qui est inclus entre < et >
- $contenu = $this->nettoyer_html($contenu);
+ $contenu = preg_replace ('/<[^>]*>/', ' ', $contenu);
// Accentuation
$contenu = html_entity_decode($contenu);
// Initialisations
@@ -213,34 +209,25 @@ class search extends common {
}
$dejavu = $titre;
$nboccu .= count($matches[0]);
- $contenu = preg_replace($motclef, '\1', $contenu);
foreach ($matches[0] as $key => $value) {
- //$resultat .= ''.$nboccu.' - "...'.substr($contenu,$value[1] ,200).'..."
'; # code...
- $resultat .= '"'.substr($contenu,$value[1] ,200).'..."
'; # code...
+ // Mise en évidence
+ $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, '\1',$t,1);
+ // Sauver résultat
+ $resultat .='"'.$t.'..."';
+
}
}
// Pour recherche d'une autre occurrence dans le même contenu
$contenu = substr($occu,10);
}
while($occu != '');
- self::$nbResults = self::$nbResults + $nboccu;
+ self::$nbResults = self::$nbResults + $nboccu; // Nombre total d'occurences
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
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;
- }
}
diff --git a/module/search/view/index/index.php b/module/search/view/index/index.php
index 5d06a337..8e42cb34 100755
--- a/module/search/view/index/index.php
+++ b/module/search/view/index/index.php
@@ -28,7 +28,7 @@