Search 3.3 une seule lecture de module
This commit is contained in:
parent
c244651b62
commit
f7cf0f94fc
@ -51,7 +51,7 @@ class common
|
|||||||
const ACCESS_TIMER = 1800;
|
const ACCESS_TIMER = 1800;
|
||||||
|
|
||||||
// Numéro de version
|
// Numéro de version
|
||||||
const ZWII_VERSION = '1.12.01';
|
const ZWII_VERSION = '1.12.02';
|
||||||
|
|
||||||
// URL autoupdate
|
// URL autoupdate
|
||||||
const ZWII_UPDATE_URL = 'https://forge.chapril.org/ZwiiCMS-Team/campus-update/raw/branch/master/';
|
const ZWII_UPDATE_URL = 'https://forge.chapril.org/ZwiiCMS-Team/campus-update/raw/branch/master/';
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
# Version 3.3
|
||||||
|
- Une seule lecture du fichier module.json
|
||||||
# Version 3.2
|
# Version 3.2
|
||||||
- Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts.
|
- Contrôle de la variable de session liée au contenu. Evite des erreurs lorsque plusieurs onglets sont ouverts.
|
||||||
# Version 3.1
|
# Version 3.1
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
class search extends common
|
class search extends common
|
||||||
{
|
{
|
||||||
|
|
||||||
const VERSION = '3.2';
|
const VERSION = '3.3';
|
||||||
const REALNAME = 'Recherche';
|
const REALNAME = 'Recherche';
|
||||||
const DATADIRECTORY = self::DATA_DIR . 'search/';
|
const DATADIRECTORY = self::DATA_DIR . 'search/';
|
||||||
|
|
||||||
@ -172,40 +172,43 @@ class search extends common
|
|||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
|
|
||||||
// Initialise un module non configuré
|
// Initialise un module non configuré
|
||||||
$this->init();
|
$this->init();
|
||||||
|
|
||||||
if (
|
if ($this->isPost()) {
|
||||||
$this->isPost()
|
|
||||||
) {
|
|
||||||
//Initialisations variables
|
//Initialisations variables
|
||||||
$success = true;
|
$success = true;
|
||||||
$result = [];
|
$result = [];
|
||||||
$notification = '';
|
$notification = '';
|
||||||
$total = '';
|
$total = '';
|
||||||
|
|
||||||
// Récupération du mot clef passé par le formulaire de ...view/index.php, avec caractères accentués
|
// Récupération du mot clef passé par le formulaire de ...view/index.php, avec caractères accentués
|
||||||
self::$motclef = $this->getInput('searchMotphraseclef');
|
self::$motclef = $this->getInput('searchMotphraseclef');
|
||||||
// Variable de travail, on conserve la variable globale pour l'affichage du résultat
|
// Variable de travail, on conserve la variable globale pour l'affichage du résultat
|
||||||
$motclef = self::$motclef;
|
$motclef = self::$motclef;
|
||||||
|
|
||||||
// Suppression des mots < 3 caractères et des articles > 2 caractères de la chaîne $motclef
|
// Suppression des mots < 3 caractères et des articles > 2 caractères de la chaîne $motclef
|
||||||
$arraymotclef = explode(' ', $motclef);
|
$arraymotclef = explode(' ', $motclef);
|
||||||
$motclef = '';
|
$motclef = '';
|
||||||
foreach ($arraymotclef as $key => $value) {
|
foreach ($arraymotclef as $key => $value) {
|
||||||
if (strlen($value) > 2 && $value !== 'les' && $value !== 'des' && $value !== 'une' && $value !== 'aux')
|
if (strlen($value) > 2 && $value !== 'les' && $value !== 'des' && $value !== 'une' && $value !== 'aux') {
|
||||||
$motclef .= $value . ' ';
|
$motclef .= $value . ' ';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Suppression du dernier ' '
|
// Suppression du dernier ' '
|
||||||
if ($motclef !== '')
|
if ($motclef !== '') {
|
||||||
$motclef = substr($motclef, 0, strlen($motclef) - 1);
|
$motclef = substr($motclef, 0, strlen($motclef) - 1);
|
||||||
|
}
|
||||||
|
|
||||||
// Récupération de l'état de l'option mot entier passé par le même formulaire
|
// Récupération de l'état de l'option mot entier passé par le même formulaire
|
||||||
self::$motentier = $this->getInput('searchMotentier', helper::FILTER_BOOLEAN);
|
self::$motentier = $this->getInput('searchMotentier', helper::FILTER_BOOLEAN);
|
||||||
|
|
||||||
|
// Lecture unique des données du module
|
||||||
|
$moduleData = $this->getData(['module']);
|
||||||
|
|
||||||
if ($motclef !== '') {
|
if ($motclef !== '') {
|
||||||
foreach ($this->getHierarchy(null, false, null) as $parentId => $childIds) {
|
foreach ($this->getHierarchy(null, false, null) as $parentId => $childIds) {
|
||||||
|
// Vérification des conditions pour la page parente
|
||||||
if (
|
if (
|
||||||
$this->getData(['page', $parentId, 'disable']) === false &&
|
$this->getData(['page', $parentId, 'disable']) === false &&
|
||||||
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
|
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
|
||||||
@ -213,7 +216,6 @@ class search extends common
|
|||||||
) {
|
) {
|
||||||
$url = $parentId;
|
$url = $parentId;
|
||||||
$titre = $this->getData(['page', $parentId, 'title']);
|
$titre = $this->getData(['page', $parentId, 'title']);
|
||||||
//$content = file_get_contents(self::DATA_DIR . self::$siteContent . '/content/' . $this->getData(['page', $parentId, 'content']));
|
|
||||||
$content = $this->getPage($parentId, self::$siteContent);
|
$content = $this->getPage($parentId, self::$siteContent);
|
||||||
$content = $titre . ' ' . $content;
|
$content = $titre . ' ' . $content;
|
||||||
// Pages sauf pages filles et articles de blog
|
// Pages sauf pages filles et articles de blog
|
||||||
@ -222,9 +224,9 @@ class search extends common
|
|||||||
$result[] = $tempData;
|
$result[] = $tempData;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Vérification des sous-pages et articles de sous-pages
|
||||||
foreach ($childIds as $childId) {
|
foreach ($childIds as $childId) {
|
||||||
// Sous page
|
|
||||||
if (
|
if (
|
||||||
$this->getData(['page', $childId, 'disable']) === false &&
|
$this->getData(['page', $childId, 'disable']) === false &&
|
||||||
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
|
$this->getUser('group') >= $this->getData(['page', $parentId, 'group']) &&
|
||||||
@ -232,24 +234,21 @@ class search extends common
|
|||||||
) {
|
) {
|
||||||
$url = $childId;
|
$url = $childId;
|
||||||
$titre = $this->getData(['page', $childId, 'title']);
|
$titre = $this->getData(['page', $childId, 'title']);
|
||||||
//$content = file_get_contents(self::DATA_DIR . self::$siteContent . '/content/' . $this->getData(['page', $childId, 'content']));
|
|
||||||
$content = $this->getPage($childId, self::$siteContent);
|
$content = $this->getPage($childId, self::$siteContent);
|
||||||
$content = $titre . ' ' . $content;
|
$content = $titre . ' ' . $content;
|
||||||
//Pages filles
|
|
||||||
$tempData = $this->occurrence($url, $titre, $content, $motclef, self::$motentier);
|
$tempData = $this->occurrence($url, $titre, $content, $motclef, self::$motentier);
|
||||||
if (is_array($tempData)) {
|
if (is_array($tempData)) {
|
||||||
$result[] = $tempData;
|
$result[] = $tempData;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Articles d'une sous-page blog ou de news
|
// Articles d'une sous-page blog ou de news
|
||||||
if ($this->getData(['module', $childId, 'posts'])) {
|
if (isset($moduleData[$childId]['posts'])) {
|
||||||
foreach ($this->getData(['module', $childId, 'posts']) as $articleId => $article) {
|
foreach ($moduleData[$childId]['posts'] as $articleId => $article) {
|
||||||
if ($this->getData(['module', $childId, 'posts', $articleId, 'state']) === true) {
|
if ($article['state'] === true) {
|
||||||
$url = $childId . '/' . $articleId;
|
$url = $childId . '/' . $articleId;
|
||||||
$titre = $article['title'];
|
$titre = $article['title'];
|
||||||
$contenu = ' ' . $titre . ' ' . $article['content'];
|
$contenu = ' ' . $titre . ' ' . $article['content'];
|
||||||
// Articles de sous-page de type blog
|
|
||||||
$tempData = $this->occurrence($url, $titre, $contenu, $motclef, self::$motentier);
|
$tempData = $this->occurrence($url, $titre, $contenu, $motclef, self::$motentier);
|
||||||
if (is_array($tempData)) {
|
if (is_array($tempData)) {
|
||||||
$result[] = $tempData;
|
$result[] = $tempData;
|
||||||
@ -258,12 +257,11 @@ class search extends common
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Articles d'un blog ou de news
|
// Articles d'un blog ou de news
|
||||||
if ($this->getData(['module', $parentId, 'posts'])) {
|
if (isset($moduleData[$parentId]['posts'])) {
|
||||||
|
foreach ($moduleData[$parentId]['posts'] as $articleId => $article) {
|
||||||
foreach ($this->getData(['module', $parentId, 'posts']) as $articleId => $article) {
|
if ($article['state'] === true) {
|
||||||
if ($this->getData(['module', $parentId, 'posts', $articleId, 'state']) === true) {
|
|
||||||
$url = $parentId . '/' . $articleId;
|
$url = $parentId . '/' . $articleId;
|
||||||
$titre = $article['title'];
|
$titre = $article['title'];
|
||||||
$contenu = ' ' . $titre . ' ' . $article['content'];
|
$contenu = ' ' . $titre . ' ' . $article['content'];
|
||||||
@ -275,22 +273,21 @@ class search extends common
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Message de synthèse de la recherche
|
// Message de synthèse de la recherche
|
||||||
if (count($result) === 0) {
|
if (count($result) === 0) {
|
||||||
self::$resultTitle = helper::translate('Aucun résultat');
|
self::$resultTitle = helper::translate('Aucun résultat');
|
||||||
self::$resultError = helper::translate('Avez-vous pensé aux accents ?');
|
self::$resultError = helper::translate('Avez-vous pensé aux accents ?');
|
||||||
} else {
|
} else {
|
||||||
self::$resultError = '';
|
self::$resultError = '';
|
||||||
//self::$resultTitle = sprintf(' %s',helper::translate('Résultat de votre recherche'));
|
|
||||||
rsort($result);
|
rsort($result);
|
||||||
foreach ($result as $key => $value) {
|
foreach ($result as $key => $value) {
|
||||||
$r[] = $value['preview'];
|
$r[] = $value['preview'];
|
||||||
}
|
}
|
||||||
// Générer une chaine de caractères
|
|
||||||
self::$resultList = implode("", $r);
|
self::$resultList = implode("", $r);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Valeurs en sortie, affichage du résultat
|
// Valeurs en sortie, affichage du résultat
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'view' => 'index',
|
'view' => 'index',
|
||||||
@ -309,6 +306,8 @@ class search extends common
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Fonction de recherche des occurrences dans $contenu
|
// Fonction de recherche des occurrences dans $contenu
|
||||||
|
Loading…
x
Reference in New Issue
Block a user