[gelöst] - Klasse aus einem Nodefield als Wrapper um Node oder einem anderen Field zuweisen
am 14.03.2014 - 17:37 Uhr in
Ich finde über die Suche nichts, weil die zu suchen Begriffe wohl zu allgemein sind :-(
Mein Problem:
Ich habe einen Inhaltstyp News, der verschiedene Themen haben kann. Dazu gibt es eine Auswahlliste eines ganz normalen Textfeldes, wo der Redaktor ein Thema auswählen kann (z.B. Sport, Wirtschaft, Politik, Gesellschaft). Die News werden in einer View ausgegeben. Je nach Kategorie erhalten die Newstitel einen unterschiedlichen Hintergrundton, den ich via CSS steuern möchte. Könnte natürlich auch mit Taxonomie arbeiten, das dürfte aber an der Aufgabe nicht viel ändern, oder doch?
Gibt es irgendwo eine Anleitung, wie ich die Bereiche aus der Auswahlliste auslesen kann und z.B. dem Title diesen Begriff als zusätzliche Klasse (oder auch dem node) mitgeben kann, dass der Titel danach als
Mein Titel
ausgegeben werden kann?
Da ich nicht der php-Dude bin, wär ich froh um Ressourcen die auch ein Dummy nachvollziehen kann ;-)
Merci
- Anmelden oder Registrieren um Kommentare zu schreiben

Du könntest deine
am 14.03.2014 - 22:29 Uhr
Du könntest deine template.php Datei durch folgenden Code erweitern (Mach vorher ein Backup):
https://drupal.org/node/1072806#comment-4502324
Hinweis: "theme_" ersetzt durch mit deinem Theme.
<?php/**
* Add a css class to the body based on the taxonomy values applied to a page.
*/
function taxonomy_node_get_terms($node, $key = 'tid') {
if(arg(0)=='node' && is_numeric(arg(1))) {
static $terms;
if (!isset($terms[$node->vid][$key])) {
$query = db_select('taxonomy_index', 'r');
$t_alias = $query->join('taxonomy_term_data', 't', 'r.tid = t.tid');
$v_alias = $query->join('taxonomy_vocabulary', 'v', 't.vid = v.vid');
$query->fields( $t_alias );
$query->condition("r.nid", $node->nid);
$result = $query->execute();
$terms[$node->vid][$key] = array();
foreach ($result as $term) {
$terms[$node->vid][$key][$term->$key] = $term;
}
}
return $terms[$node->vid][$key];
}
}
function theme_preprocess_html(&$variables) {
$node = node_load(arg(1));
$results = taxonomy_node_get_terms($node);
if(is_array($results)) {
foreach ($results as $item) {
$variables['classes_array'][] = "taxonomy-".strtolower(drupal_clean_css_identifier($item->name));
}
}
}
?>
Danke Goekmen Das
am 15.03.2014 - 13:03 Uhr
Danke Goekmen
Das funktioniert prima für die Nodeansicht, wo im body tag die Taxonomie-Klasse reingeschrieben wird, aber in der View wird der Body des nodes nicht ausgegeben. Ich möchte die Klasse gerne im Title oder auch gleich im Taxonomie-Feld, dass ich als Zwischentitel in der View ausgebe.
Du kannst die Ausgabe der
am 15.03.2014 - 14:01 Uhr
Du kannst die Ausgabe der einzelnen Felder selber ändern.
Man könnte z.B. Term-Namen aktivieren und die Ausgabe unterdrücken und dann in einem anderen Feld als Pattern benutzen.
In der Zeilenausgabe könntest du diesen Pattern als CSS Klasse mitgeben.
Ich habe dir mal ein Bild rausgesucht, damit du weiß was ich meine:

In die List-Class kannst du eigene Pattern benutzen
Ahhh... manno... Super
am 15.03.2014 - 14:35 Uhr
Ahhh... manno... Super Ansatz, hätt ich auch drauf kommen können. Werd ich gleich probieren. Danke
Herzlichen Dank Tolle Lösung,
am 15.03.2014 - 16:38 Uhr
Herzlichen Dank
Tolle Lösung, die für den PHP Dummy perfekt funktioniert.
Meine Wünsche liessen sich damit umsetzen. Musste zwar die etwas unleserliche ID als Klassennamen «vergewaltigen», aber für die vier Kategorien ist das ok. Die Luxusvariante wär natürlich noch, wenn ich aus dem Term «Geodaten allgemeine News» anstatt kat-id- eine Klasse «geodaten-allgemeine-news» erzeugen könnte. Aber eben, hier absolut unwichtig, für andere Anwendungen, wenn es dann mehrere Klassen braucht, wird das mit den ids unübersichtlich.
Du kannst auch den
am 15.03.2014 - 17:09 Uhr
Du kannst auch den Maschinennamen der Begriffe ausgeben oder auch mehrere Pattern zu einem kombineren.
Einfach rechts in Views eine Beziehung aufbauen (Inhalt: Taxonomy terms on node), dann taucht alles auf was mit Taxonomie zu tun hat. Das dürfte dich glücklich machen :-)