Mit Panels und einem generischen View Taxonomieübersichten erzeugen
Drupalversion
5.x
Aufgabe
Die Nodes aus verschiedenen Terms eines einzelnen Vocabulary sollen als Übersichtsseite angezeigt werden. Von jedem Term sollen in der Übersicht der Terms 3 Teaser und in der Übersicht eines einzelnen Term 12 Teaser angezeigt werden.
Die Übersichtseite der Terms soll unabhängig von der Anzahl der aktuell definierten Terms erfolgen. D. h., es sollen immer automatisch die Terms angezeigt werden die definiert sind.
Verwendete Module
Generischen View erstellen
Um mit einem einzigen View die Nodeteaser aller Terms eines Vocabulary anzuzeigen wird ein einzelner generischer View erstellt.
Basisinformation
Name: taxonomy_terms
View als Seitenansicht
URL des View: taxonomy/term
Ansichtstyp: Liste der Anrisstexte
Beiträge pro Seite: 12
Argumente
Taxonomie: Begriff ID
Standardwert: Die Seite wurde nicht gefunden zurückgeben
Titel: %1
Option: 0
Node: Feedauswahl: Alle Werte anzeigen
Filter
Node: Veröffentlicht
Operator: Gleich
Wert: Ja
Sortierkriterium
Optional selbst festlegen. Wenn dann
Node: am Anfang von Listen
Node: Erstellungszeitpunkt
Panel erstellen, Vorbereitung
Zusätzliches Panels-Layout
Da die verfügbaren Panels-Layouts (in /panels/layouts) beim Erstellen eines neuen Panel keine Möglichkeit bieten ein Layout ohne Spalten zu wählen hier der Code der 3 Dateien für ein zusätzliches Layout mit 2 Zeilen.
Die 3 Dateien des zusätzlichen Panel-Layout sind:
two_stacked.inc
two_stacked.css
two_stacked.png
Die 3 Dateien werden im Modulordner des Panels-Modul in /panels/layouts gespeichert.
two_stacked.inc
<?php
// $Id: two_stacked.inc,v 1.5 2008/05/21 14:35:20 quiptime Exp $
/**
* implementation of hook_panels_layouts
*/
function panels_two_stacked_panels_layouts() {
$items['two_stacked'] = array(
'module' => 'panels',
'title' => t('Two lines stacked'),
'icon' => 'layouts/two_stacked.png',
'theme' => 'panels_two_stacked',
'css' => 'layouts/two_stacked.css',
'content areas' => array('top' => t('Top'), 'bottom' => t('Bottom')),
);
return $items;
}
/**
* This function uses heredoc notation to make it easier to convert
* to a template.
*/
function theme_panels_two_stacked($id, $content) {
if ($id) {
$idstr = " id='$id'";
}
$output = <<<EOT
<div class="panel-2-stacked" $idstr>
<div class="panel-col-top">
<div>$content[top]</div>
</div>
<div class="panel-col-bottom">
<div>$content[bottom]</div>
</div>
</div>
<br class="panel-clearer" />
EOT;
return $output;
}
two_stacked.css
/* $Id: two_stacked.css,v 1.4.4.1 2007/03/15 20:16:53 quiptime Exp $ */
.panel-2-stacked {
/* border: 1px solid red; */
overflow: hidden;
}
.panel-2-stacked .panel-col-top,
.panel-2-stacked .panel-col-bottom {
width: 99.9%;
clear: both;
}
.panel-clearer {
clear: both;
}
Das Panel für die Terms anlegen
Nachdem die 3 Dateien des zusätzlichen Panels-Layouts in den entsprechenden Ordner des Panels-Modules gespeichert sind wird ein neues Panel mit dem Layout "two_stacked" angelegt.
Soll dieses Panel die Startseite präsentieren nennt man den Pfad des Panel einfach "home". Dieser Pfad muss in der Administration unter admin/settings/site-information noch als Standard Startseite eingetragen werden.
Das Panel(layout) hat 2 Bereiche. Einen oben und einen unten. Man muss nur einen belegen wenn es für den anderen (noch) keine Inhalte gibt.
Ich nehme den unteren Panelbereich um eventuell später im oberen Panelbereich wichtige Inhalte anzeigen zu können.
Eingefügt wird mit dem Button "Add custom".
Wenn der Custom-Bereich hinzugefügt ist wird das Eingabeformat im Textbereich auf PHP-Code gesetzt.
Nun wird das generische View verwendet um die Teaser der Terms des gewünschten Vocabulary anzuzeigen. Dazu wird im Textbereich entsprechender PHP-Code eingefügt. Hier der Code:
<?php
$output = '';
$vid = 7;
$terms = taxonomy_get_tree($vid);
foreach ( $terms as $term ) {
$view = views_get_view('taxonomy_terms');
$view_html = views_build_view('embed', $view, array($term->tid), false, 3);
$output .= '<h2 class="title">'.l($term->name, 'taxonomy/term/'.$term->tid, array('title' => 'alle Artikel aus "'.$term->name.'" ansehen')).'</h2>';
$output .= $view_html;
}
print $output;
?>
Wichtig in
views_get_view('taxonomy_terms')
ist die Verwendung des korrekten Namens des View - so wie in der Basisinformation als Name definiert.Mit der 3 in
views_build_view('embed', $view, array($term->tid), false, 3)
wird die Anzahl der Nodes auf 3 beschraenkt.Das Vocabulary hat die ID 7 und ist anzupassen. Die ID eines Vocabulary ist sichtbar in der Administration: admin/content/taxonomy.
Terms des Vocabulary normal aufrufen
Dieser Aufruf erfolgt bereits beim Klick auf die Überschriften der einzelnen Terms in der Panelansicht. Dabei wird der generische View angesprochen. Im View ist definiert das 12 Nodes angezeigt werden.
Da der generische View die URL taxonomy/term hat kann man innerhalb einer Menükonfiguration die einzelnen Terms des Vocabularys auch mit der jeweiligen Term-URL taxonomy/term/x verlinken. Dabei wird der generische View angesprochen. Im View ist definiert das 12 Nodes angezeigt werden.
Nachtrag generischer View
Das sich die Definition des generischen View auf kein einzelnes Vocabulary sondern nur auf veöffentlichte Node bezieht können beliebige Panel-Ansichten (beliebige Vocabularys auswertend) erstellt werden.
- Anmelden oder Registrieren um Kommentare zu schreiben
Neue Kommentare
vor 21 Stunden 19 Minuten
vor 23 Stunden 47 Minuten
vor 1 Tag 20 Minuten
vor 1 Tag 1 Stunde
vor 1 Tag 1 Stunde
vor 1 Tag 1 Stunde
vor 1 Tag 15 Stunden
vor 3 Tagen 2 Minuten
vor 3 Tagen 23 Stunden
vor 4 Tagen 6 Stunden