Wie Result-Count einer Search-Api View anzeigen?
am 18.06.2019 - 12:38 Uhr in
Hallo zusammen,
in einer Drupal 8 Installation werden die Module Search-Api und Facets mit einer View (url: /meinesuche) als Suchseite genutzt. Im Kopf der View wird mit @total die Anzahl der Ergebnisse angezeigt.
Das funktioniert aber leider nicht zuverlässig.
Beispiel: Ich habe 10 Nodes, 5 mit View-Berechtigung nur für Admin, 5 mit View-Berechtigung für Admin, Authenticated und Anonymous. Rufe ich "meinesuche" als Admin auf, wird als Anzahl der Suchergebnisse "10" angezeigt. Rufe ich "meinesuche" als Anonymous auf, wird als Anzahl der Suchergebnisse ebenfalls "10" angezeigt. In diesem Fall wären aber 5 richtig.
Ich habe mal gegoogelt. Scheinbar ist das tatsächlich ein Bug. Welche Möglichkeiten habe ich denn sonst noch die Anzahl der Suchergebnisse zu bestimmen? Geht das eventuell über einen Hook in einem eigenen Module? Aber wie bekomme ich dann diese Anzahl in den Header der View? Wichtig: die View aktualisiert mit AJAX, da mein Kunde anstatt einer normalen Paginierung einen "Load more" Button nutzt.
Danke & Grüße
rhodes
- Anmelden oder Registrieren um Kommentare zu schreiben
Hi. Ich denke nicht das es
am 18.06.2019 - 15:13 Uhr
Hi.
Ich denke nicht das es ein Bug ist sondern vermutlich eher normal.
Das SQL Statement der View wird bei beiden wohl das gleiche sein und 10 Resultate holen (COUNT(*)).
Erst danach werden die Berechtigungen entschieden und die nicht berechtigten Nodes entfernt.
Du bekommst dann von der View ein Resultset (Array) entsprechender Grösse.
Du könntest im Theme das Grösse(sizeof oder length) von diesem Array als Counter ausgeben.
Dann sollte es stimmen.
MfG
Robert
https://awri.ch
Ich habe eine Schweizer Tastatur und daher kein scharfes ß ;-)
Hi,
am 18.06.2019 - 18:11 Uhr
danke, das klingt plausibel. In welcher Funktion/hook im Theme würde ich sowas denn tun?
Das Theme jeweilige View oder
am 18.06.2019 - 18:49 Uhr
Das Theme jeweilige View oder Twig Template der View überschreiben(List,Table,Unformatted,...?)
https://awri.ch
Ich habe eine Schweizer Tastatur und daher kein scharfes ß ;-)
Preprocess_views
am 19.06.2019 - 09:25 Uhr
Ich habe es jetzt so versucht:
function mytheme_preprocess_views_view_unformatted(&$variables) {
$view = $variables['view'];
$view_id = $view->storage->id();
if($view_id == "myview") {
$view = $variables['view'];
$rows = $variables['rows'];
$total_rows = count($rows);
ksm("Total rows ".$total_rows);
}
}
$total_rows gibt für Admin und Anonymous 3 zurück. Das ist die Anzahl der nach Aufruf der View sichtbaren Items, definiert im Pager (Views Infinite Scroll). Irgendwie komme ich nicht an die Gesamtlänge des Ergebnisses, unabhängig vom Pager.
Hi. Das was ich oben gesagt
am 19.06.2019 - 12:43 Uhr
Hi.
Das was ich oben gesagt habe funktioniert nur ohne Pager wenn man alle Elemente ausgiebt.
Ich weiss nicht ob Infinite Scroll dir die Anzahl der Pages mitgibt.
Sonst könntest Du "Anzahl der Pages * Pagesize" rechnen um
wenigstens auf die ungefähre Anzahl zu kommen(+-3).
https://awri.ch
Ich habe eine Schweizer Tastatur und daher kein scharfes ß ;-)