[gelöst] Views-Block nur anzeigen, wenn Inhalt?
am 14.01.2010 - 21:54 Uhr in
Hallo,
ich hab mir einen View (Block) erstellt, der Nodes anzeigt, sofern die Filter matchen. Nun möchte ich, dass der Block nur angezeigt wird, wenn der View mindestens einen Node gefunden hat & darstellt.
Gibts hierzu eine einfache Lösung?
Bisher hab ich das versucht:
Ich hab mir das SQL-Statement aus dem View kopiert:
<?php
SELECT node.nid AS nid,
node_data_field_news_showfrom.field_news_title_value AS node_data_field_news_showfrom_field_news_title_value,
node.type AS node_type,
node.vid AS node_vid,
node_revisions.body AS node_revisions_body,
node_revisions.format AS node_revisions_format,
node_data_field_news_showfrom.field_news_showfrom_value AS node_data_field_news_showfrom_field_news_showfrom_value,
node_data_field_news_showfrom.field_news_showfrom_value2 AS node_data_field_news_showfrom_field_news_showfrom_value2
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node.vid = node_revisions.vid
WHERE ((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
AND ((DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))
ORDER BY node_data_field_news_showfrom_field_news_showfrom_value DESC, node_data_field_news_showfrom_field_news_showfrom_value2 DESC
?>
und bei diesem die SELECT-Felder durch ein COUNT(*) ersetzt.
<?php
SELECT COUNT(*)
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node.vid = node_revisions.vid
WHERE ((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
AND ((DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))
?>
Lasse ich dieses neue Statement direkt auf die Datenbank los, erhalte ich das korrekte Ergebnis: 2.
Füge ich dies nun in die Sichtbarkeits-Einstellung des Blockes via PHP ein, erhalte ich als Ergebnis 0, d. h. der Block wird nicht angezeigt. :(
<?php
$query = "SELECT COUNT(*)
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node.vid = node_revisions.vid
WHERE ((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
AND ((DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))";
$erg = db_query($query);
$h = db_fetch_array($erg);
if($h['cnt'] > 0) { return TRUE; }
else { return FALSE; }
?>
Testweise hab ich das gleiche mal in ein Node im Eingabeformat PHP gesetzt und mir $h['cnt'] ausgeben lassen: 0.
Was ist hier also los?
Das selbe Statement auf der Datenbank gibt 2 aus, via Drupal jedoch 0?!
- Anmelden oder Registrieren um Kommentare zu schreiben
Ich habe mir den ganzen
am 17.01.2010 - 20:59 Uhr
Ich habe mir den ganzen Quellcode jetzt mal nicht angesehen... aber wieso diese Frage? Bei mir werden Block-Views nie angezeigt, wenn die Filter keinen Node finden. Hast Du vielleicht den Kopfbereich der Ansicht definiert oder die Fußzeile? Hier kannst Du ein Häkchen setzen bei "Auch anzeigen, wenn die Ansicht keine Ergebnisse liefert" (oder so ähnlich), dann wird der Block mit dem Kopf- bzw. Fußbereich immer angezeigt, sonst eigentlich nicht.
Präsentiert voller Stolz sein erstes Drupal-Projekt: http://www.diaet-clique.de
OH GOTT, ist das peinlich.
am 17.01.2010 - 21:12 Uhr
OH GOTT, ist das peinlich. Ja. Das hatte ich gar nicht probiert. Du hast recht. Oh weh. Dann tut mir die blöde Frage leid! :D
Aber unabhängig davon wüsst ich gern, warum ein und dieselbe Abfrage via MySQL-Administrator ein Ergebnis bringt, via Drupal jedoch nicht.
Kein Ding, manchmal sieht
am 17.01.2010 - 22:00 Uhr
Kein Ding, manchmal sieht man den Wald vor lauter Bäumen nicht :-)
Bei Deiner Frage kann ich Dir aber nicht helfen, bin kein Fachmann für SQL-Abfragen und dergleichen. Da bin ich überfragt...
Präsentiert voller Stolz sein erstes Drupal-Projekt: http://www.diaet-clique.de