From 6976594a1496ae98adc87e8ffc86a5dc4cd31949 Mon Sep 17 00:00:00 2001
From: Fred Tempez
Date: Sun, 16 Aug 2020 21:02:26 +0200
Subject: [PATCH] =?UTF-8?q?Nouveau=20moteur=20de=20recherche=20bas=C3=A9?=
=?UTF-8?q?=20sur=20des=20regex=20-=20reste=20=20=C3=A0=20faire=20recherch?=
=?UTF-8?q?e=20par=20chaine?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
module/search/search.php | 75 ++++++++++++++----------------
module/search/view/index/index.css | 3 ++
module/search/view/index/index.php | 2 +-
3 files changed, 39 insertions(+), 41 deletions(-)
create mode 100644 module/search/view/index/index.css
diff --git a/module/search/search.php b/module/search/search.php
index ee06f007..540dd4c1 100755
--- a/module/search/search.php
+++ b/module/search/search.php
@@ -80,7 +80,21 @@ class search extends common {
//Pour affichage de l'entête du résultat
self::$resultTitle = 'Aucun résultat';
$result = '';
- if (self::$motclef !== "" && strlen(self::$motclef) > 2) {
+ // protection des guillemets
+ // ^((("){1}([^"])*("){1})([ ]+))+$
+ //preg_match('(?:^|(?<=\s))"([^"]+)"(?:$|(?=\s))',self::$motclef,$matches);
+ //print_r($matches);
+ // Découpage de la chaîne de mots clés
+ $keywords = '/(';
+ $a = explode(' ',self::$motclef);
+ foreach ($a as $key => $value) {
+
+ $keywords .= self::$motentier === false ? $value . '|' : '\\b' . $value . '\\b|' ;
+ }
+ $keywords = substr($keywords,0,strlen($keywords) - 1);
+ $keywords .= ')/i';
+ //echo $keywords;
+ if ($keywords !== "" && strlen($keywords) > 2) {
foreach($this->getHierarchy(null,false,null) as $parentId => $childIds) {
if ($this->getData(['page', $parentId, 'disable']) === false &&
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
@@ -89,7 +103,7 @@ class search extends common {
$titre = $this->getData(['page', $parentId, 'title']);
$contenu = $this->getData(['page', $parentId, 'content']);
// Pages sauf pages filles et articles de blog
- $result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier);
+ $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
}
foreach($childIds as $childId) {
@@ -101,7 +115,7 @@ class search extends common {
$titre = $this->getData(['page', $childId, 'title']);
$contenu = $this->getData(['page', $childId, 'content']);
//Pages filles
- $result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier);
+ $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
}
@@ -114,7 +128,7 @@ class search extends common {
$titre = $article['title'];
$contenu = $article['content'];
// Articles de sous-page de type blog
- $result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier);
+ $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
}
}
@@ -131,7 +145,7 @@ class search extends common {
$titre = $article['title'];
$contenu = $article['content'];
// Articles de Blog
- $result .= $this->occurrence($url, $titre, $contenu, self::$motclef, self::$motentier);
+ $result .= $this->occurrence($url, $titre, $contenu, $keywords, self::$motentier);
}
}
@@ -143,7 +157,7 @@ class search extends common {
$result .='Mot clef non trouvé. Avez-vous pensé aux accents ?';
$success = false;
} else {
- $result .= 'Nombre d\'occurrences : '.self::$nbResults;
+ //$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';
$success = true;
@@ -189,24 +203,24 @@ class search extends common {
$resultat= '';
// Recherche des occurrences
do {
- $occu = stristr($contenu,$motclef);
- if ($occu !== false) {
- if ($motentier === true) {
- $controle_entier=$this->test_motentier($contenu,$motclef);
- } else {
- $controle_entier=true;
+ $occu = preg_match_all($motclef,$contenu,$matches,PREG_OFFSET_CAPTURE);
+ if ($occu !== false && !empty($matches[0]) ) {
+ /*echo "";
+ print_r($matches);
+ echo "
";*/
+ if ($titre !== $dejavu) {
+ $resultat = ''.$titre.'
';
}
- if ($controle_entier) {
- if ($titre !== $dejavu) {
- $resultat = ''.$titre.'
';
- }
- $dejavu = $titre;
- $nboccu++;
- $resultat .= ''.$nboccu.' - "...'.substr($occu,0,200).'..."
';
+ $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...
}
- // Pour recherche d'une autre occurrence dans le même contenu
- $contenu = substr($occu,10);
}
+ // Pour recherche d'une autre occurrence dans le même contenu
+ $contenu = substr($occu,10);
}
while($occu != '');
self::$nbResults = self::$nbResults + $nboccu;
@@ -229,23 +243,4 @@ class search extends common {
while($pos1!==false);
return $contenu;
}
-
- // Déclaration de la fonction test_motentier(string $chaine, string $clef) : bool
- // Vérifie si dans la string $chaine, $clef est un mot entier
- // $clef ne doit pas être précédé ni suivi d'une lettre maj ou min
- private function test_motentier($chaine, $clef)
- {
- $resultat=true;
- $pos1=stripos($chaine,$clef);
- $avant=ord(substr($chaine,$pos1-1, 1));
- $apres=ord(substr($chaine,$pos1+strlen($clef),1));
- // Traitement pour le caractère qui précède et celui qui suit
- if (($avant>=65 && $avant<=90) ||
- ($avant>=97 && $avant<=122) ||
- ($apres>=65 && $apres<=90) ||
- ($apres>=97 && $apres<=122) ) {
- $resultat=false;
- }
- return $resultat;
- }
}
diff --git a/module/search/view/index/index.css b/module/search/view/index/index.css
new file mode 100644
index 00000000..906a9170
--- /dev/null
+++ b/module/search/view/index/index.css
@@ -0,0 +1,3 @@
+.evidence {
+ background: yellow;
+}
\ No newline at end of file
diff --git a/module/search/view/index/index.php b/module/search/view/index/index.php
index 336f6633..5d06a337 100755
--- a/module/search/view/index/index.php
+++ b/module/search/view/index/index.php
@@ -17,7 +17,7 @@
false
+ 'checked' => $module::$motentier
]); ?>