This commit is contained in:
Jürgen Mummert
2025-12-23 11:13:56 +01:00
parent faaa6fdcac
commit 86bb2d8e8d
2 changed files with 22 additions and 42 deletions
+22 -37
View File
@@ -2,11 +2,15 @@
namespace MummertMedia\ContaoMeilisearchBundle\EventListener; namespace MummertMedia\ContaoMeilisearchBundle\EventListener;
use Contao\CoreBundle\ServiceAnnotation\Hook;
class IndexPageListener class IndexPageListener
{ {
/**
* @Hook("indexPage")
*/
public function onIndexPage(string $content, array &$data, array &$set): void public function onIndexPage(string $content, array &$data, array &$set): void
{ {
// Schneller Exit, wenn kein Marker existiert
if (!str_contains($content, 'MEILISEARCH')) { if (!str_contains($content, 'MEILISEARCH')) {
return; return;
} }
@@ -17,67 +21,55 @@ class IndexPageListener
} }
/* /*
* =====================
* PRIORITY * PRIORITY
* event/news > page
* =====================
*/ */
if (isset($markers['event.priority'])) { if (isset($markers['event.priority'])) {
$data['priority'] = (int) $markers['event.priority']; $set['priority'] = (int) $markers['event.priority'];
$set['priority'] = true;
} elseif (isset($markers['news.priority'])) { } elseif (isset($markers['news.priority'])) {
$data['priority'] = (int) $markers['news.priority']; $set['priority'] = (int) $markers['news.priority'];
$set['priority'] = true;
} elseif (isset($markers['page.priority'])) { } elseif (isset($markers['page.priority'])) {
$data['priority'] = (int) $markers['page.priority']; $set['priority'] = (int) $markers['page.priority'];
$set['priority'] = true;
} }
/* /*
* =====================
* KEYWORDS (kombiniert) * KEYWORDS (kombiniert)
* =====================
*/ */
$keywords = []; $keywords = [];
foreach (['event.keywords', 'news.keywords', 'page.keywords'] as $key) { foreach (['event.keywords', 'news.keywords', 'page.keywords'] as $key) {
if (!empty($markers[$key])) { if (!empty($markers[$key])) {
$parts = preg_split('/\s+/', trim($markers[$key])) ?: []; $keywords = array_merge(
$keywords = array_merge($keywords, $parts); $keywords,
preg_split('/\s+/', trim($markers[$key]))
);
} }
} }
if ($keywords !== []) { if ($keywords !== []) {
$keywords = array_values(array_unique(array_filter($keywords))); $set['keywords'] = implode(' ', array_unique($keywords));
$data['keywords'] = implode(' ', $keywords);
$set['keywords'] = true;
} }
/* /*
* =====================
* SEARCH IMAGE (UUID) * SEARCH IMAGE (UUID)
* event/news > page > custom
* =====================
*/ */
foreach (['event.searchimage', 'news.searchimage', 'page.searchimage', 'custom.searchimage'] as $key) { foreach (
['event.searchimage', 'news.searchimage', 'page.searchimage', 'custom.searchimage']
as $key
) {
if (!empty($markers[$key])) { if (!empty($markers[$key])) {
$data['imagepath'] = trim($markers[$key]); // vorerst nur UUID $set['imagepath'] = trim($markers[$key]);
$set['imagepath'] = true;
break; break;
} }
} }
/* /*
* =====================
* START DATE (Timestamp) * START DATE (Timestamp)
* =====================
*/ */
foreach (['event.date', 'news.date'] as $key) { foreach (['event.date', 'news.date'] as $key) {
if (!empty($markers[$key])) { if (!empty($markers[$key])) {
$ts = strtotime(trim($markers[$key])); $ts = strtotime($markers[$key]);
if ($ts !== false) { if ($ts !== false) {
$data['startDate'] = $ts; $set['startDate'] = $ts;
$set['startDate'] = true;
} }
break; break;
} }
@@ -86,22 +78,15 @@ class IndexPageListener
private function extractMarkers(string $content): array private function extractMarkers(string $content): array
{ {
// Kommentarblock isolieren
if (!preg_match('/<!--\s*MEILISEARCH(.*?)-->/s', $content, $m)) { if (!preg_match('/<!--\s*MEILISEARCH(.*?)-->/s', $content, $m)) {
return []; return [];
} }
$block = trim($m[1]);
$lines = preg_split('/\R/', $block) ?: [];
$markers = []; $markers = [];
foreach ($lines as $line) { foreach (preg_split('/\R/', trim($m[1])) as $line) {
$line = trim($line); if (!str_contains($line, '=')) {
if ($line === '' || !str_contains($line, '=')) {
continue; continue;
} }
[$k, $v] = explode('=', $line, 2); [$k, $v] = explode('=', $line, 2);
$markers[trim($k)] = trim($v); $markers[trim($k)] = trim($v);
} }
-5
View File
@@ -1,6 +1,5 @@
<?php <?php
use MummertMedia\ContaoMeilisearchBundle\EventListener\IndexPageListener;
use MummertMedia\ContaoMeilisearchBundle\EventListener\MeilisearchPageMarkerListener; use MummertMedia\ContaoMeilisearchBundle\EventListener\MeilisearchPageMarkerListener;
@@ -9,10 +8,6 @@ $GLOBALS['TL_HOOKS']['outputFrontendTemplate'][] = [
'onOutputFrontendTemplate', 'onOutputFrontendTemplate',
]; ];
$GLOBALS['TL_HOOKS']['indexPage'][] = [
IndexPageListener::class,
'onIndexPage'
];