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 @@