Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Tipps & Tricks ›

Taxonomie-Menü von beliebiger Tiefe erstellen mit sortierten Einträgen - Ersetzt Modul Taxonomy Menu

Eingetragen von montviso (2188)
am 28.01.2013 - 09:39 Uhr in
  • Tipps & Tricks
  • Drupal 7.x

Hallo,

Zwei Wünsche konnte ich mir mit dem Modul Taxonomy Menu nicht erfüllen.
a) die Einträge sollen bis ins Untermenü hinein sortierbar sein, ohne daß man im Menü Hand anlegen muß
b) Bestimmte Taxonomieeinträge sollen nicht angezeigt werden im Menü

Der aktive Zweig des Menü soll aufgeklappt sein, bzw. bei Hover aufgeklappt werden.
Dies soll per CSS funktionieren.

Außerdem kann man in meiner Version einen beliebigen Link auf eine beliebige View erstellen, was bei Taxonomy Menu unter Drupal 7 auch nicht ohne weiteres möglich ist.

Das ganze funktioniert mit einer rekursiveren Funktion.

Dieser Quelltext steht im Block :

<?php
   
//Funktion zum Sortieren eines assoziativen Arrays
    //Von hier: http://php.net/manual/de/function.sort.php
   
function array_sort($array, $on, $order=SORT_ASC)
    {
        
$new_array = array();
        
$sortable_array = array();

         if (
count($array) > 0) {
        
         foreach (
$array as $k => $v) {
        
$v = (array) $v;
             if (
is_array($v)) {
            
             foreach (
$v as $k2 => $v2) {            
                 if (
$k2 == $on) {
                
$sortable_array[$k] = $v2;
                
                 }
             }
             } else {
            
$sortable_array[$k] = $v;
             }
         }

         switch (
$order) {
             case
SORT_ASC:
                
            
asort($sortable_array);
            
             break;
             case
SORT_DESC:
            
arsort($sortable_array);
             break;
         }

         foreach (
$sortable_array as $k => $v) {
            
$new_array[$k] = $array[$k];
         }
         }

         return
$new_array;
    }   

   
// $maxdepth = Tiefe im Tax-Baum
    // $termid = Id der Taxonomie, für die auf Unterbegriffe gesucht wird
    // $class = Klasse, die per CSS entscheidet, ob der Listenteil offen oder geschlossen dargestellt wird   
     // $mytext = Text, der per Reference durch die rekursive Funktion gereicht wird
   
function ProduktKat($maxdepth, $termid,$class,&$mytext)
     {  
       
//Id des Vokabulars
       
$vid = 2;
       
       
//Taxonomie-Baum für eine bestimmte ID ermitteln
       
$tree[$maxdepth] = taxonomy_get_tree($vid,$termid,1);  
       
       
//Tabulator für bessere Lesbarkeit des Quellcodes bilden
       
$tab="";
        for(
$i=0;$i<$maxdepth;$i++)
        {
             
$tab = $tab."\t";
        }
       
       
//Wenn wir auf der obersten Ebene sind, soll der Listenbegriff auf jeden FAll angezeigt werden
       
if($maxdepth == 0){
             
//$class = "open"; 
       
}                
       
       
//Prüfen, ob es für diesen TAxonomiebegriff Unterbegriffe gibt
       
if(count($tree[$maxdepth]) >0)
        {
           
//Listenelement öffnen
           
$mytext .=  "\n$tab<ul class=\"".$class." level".$maxdepth." menu\">\n";
           
           
//Die Begriffe des jeweiligen Taxonomie-Zweigs alphabetisch sortieren mit Hilfsfunktion
           
$tree[$maxdepth] = array_sort($tree[$maxdepth], 'name', SORT_ASC); // Sort by surname
          
            //Hilfszähler, nur für Debug
           
$counter =0;
           
           
//Schleife über alle Elemente dieses TAxonomiezweigs
           
foreach ($tree[$maxdepth] as $term) {

               
//Bestimmte Begriffe ausblenden
               
if(!preg_match("^Produkt ^",$term->name))
                {
                   
$myterm = $term->tid; 

                   
//Wenn diese Taxonomie-ID oben im Parameter der URL steht, dann Klasse open vergeben
                   
if((arg(2) && arg(2)==$term->tid)   )
                    {
                       
$class="open";
                    }else
                    {
                       
$class="close";
                    }
                   
                   
//Nur für Debugzwecke
                   
$depthtext = $maxdepth.'-'.$counter;
                   
$depthtext="";   //Zum Testen auskommentieren                           
                   
                    //Listenelement bilden mit gewünschtem Link, der dann in View weiter verarbeitet werden kann
                   
$mytext.= "\n$tab\t<li class='term".$myterm." ".$class." level".$maxdepth."'>".$depthtext.l($term->name, 'taxonomy/term/' . $term->tid);
           
                   
$counter++;         
                }
               
               
//Die Funktion rekursiv aufrufen mit einer tieferen Ebene
               
$depth = ($maxdepth +1);
               
               
//Taxonomie-ID für die Unterbegriffe gesammelt werden sollen, wird übergeben
                //Bisheriger Text wird übergeben  
               
ProduktKat($depth, $term->tid,$class,$mytext);
               
               
//Listenelement wird geschlossen
               
$mytext .= "</li>"."<!-- list $term->tid -->";   
        
            }
           
           
//Liste schließen, die evt. Untermenüpunkte umschließt
           
$mytext .= "\n$tab</ul>\n"."<!-- ulcontainer $termid -->";
           
         }
       
//Der jeweilige Taxonomiebaum mit Unterverzweigung.
       
if($maxdepth == 1)
        {      
               
//Wenn irgendwo im Unterbaum ein Element aktiv ist (open); dann wird der ganze Baum aktiv
               
if(preg_match("^open level^",$mytext))
                {
                   
//Ersetze den Klassenamen close durch open
                   
$mytext = preg_replace("^close level^","open level",$mytext);
                }
               
               
//Gebe den Abschnitt an Quelltext für diesen Taxonomiezweig aus.
               
print $mytext;
               
               
//Leere die Variable, damit sie für den nächsten TAx-Zweig bereit ist
               
$mytext = "";
        }
    }
   
   
ProduktKat('0','0','close','');
?>

So sieht das zugehörige CSS aus:

#block-block-9 ul.menu li {
padding-left:10px;
}

#block-block-9 ul.menu li.level0 {
padding-left:0px;
}

#block-block-9 ul {
display:block;
}

#block-block-9 ul li ul {
display:none;
}

#block-block-9 ul.open{
display:block;
}

#block-block-9 ul li:hover ul{
display:block;
}

Wenn jemand eine elegantere oder performantere Lösung weiß, gerne her damit.

‹ [gelöst] Blog mit Profilbild Taxonomie-Menü von beliebiger Tiefe erstellen mit sortierten Einträgen - Ersetzt Modul Taxonomy Menu ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Performantere Lösung

Eingetragen von montviso (2188)
am 13.02.2013 - 19:01 Uhr

Die obige Lösung hatte ich inzwischen noch erweitert um die Ausgabe der Anzahl von Nodes / Term.
Danach war allerdings die Performance der rekursiven Funktion nicht mehr akezptabel.

Inzwischen löse ich das mit einer Tree-View.

Folgende Schritte sind nötig:

1. Modul Views Tree installieren http://drupal.org/project/views_tree
2. Taxonomy Tree-View anlegen nach dieser Anleitung: http://drupal.org/node/495960#comment-5334648
3. Zusätzlliche Beziehung anlegen Taxonomie-Begriff: Inhalt using Produkt-Kategorie (Produkt-Kategorie ist der Name meiner Taxonomie)
4. Zusätzliches Feld anlegen: Titel des Inhalts, der über Beziehungen verknüpft wurde mit Count -Aggregation hinzufügen.
5. zwei Filtergruppen anlegen:
1. Gruppe
ID des Vokabulars
UND ungewünschte Taxonomie-Begriffe ausschließen
UND 2. Guppe
Nodes muß veröffentlicht sein
ODER Node-Titel is NULL

Der aufwändige Filter ist notwendig, damit Überbegriffe des Terms angezeigt werden, auch wenn damit keine Nodes verknüpft sind, sondern nur mit deren Unter-Kategorien.
6. Sortierung: Taxonomie-Begriff: Name

Auf aufwändige Formatierung des Menüs als Aufklapp-Menü habe ich vorerst verzichtet.
Evt. mache ich das noch mit JQuery.

Mit dem Modul performance habe ich getestet, daß diese Version um Faktor 10 performanter ist, als die Lösung mit rekursivem Aufruf in der Funktion, wo ich dann noch zu jedem Term die Anzahl der Nodes ermittelt hatte.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Die Lösung mit Views Tree

Eingetragen von degunino (109)
am 06.09.2014 - 14:24 Uhr

Die Lösung mit Views Tree funktioniert prima.
Eines habe ich noch nicht lösen können: Count-Aggregation auf Ebene der Parent-Terms. Hier wird immer "0" angezeigt. Jemand eine Idee?

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 1 Tag 3 Stunden
  • Hey danke
    vor 1 Tag 22 Stunden
  • Update: jetzt gibt's ein
    vor 2 Tagen 16 Stunden
  • Hallo, im Prinzip habe ich
    vor 1 Woche 2 Stunden
  • Da scheint die Terminologie
    vor 1 Woche 5 Stunden
  • Kannst doch auch alles direkt
    vor 1 Woche 4 Tagen
  • In der entsprechenden View
    vor 1 Woche 4 Tagen
  • Dazu müsstest Du vermutlich
    vor 1 Woche 4 Tagen
  • gelöst
    vor 4 Wochen 1 Tag
  • Ja natürlich. Dass ist etwas,
    vor 4 Wochen 1 Tag

Statistik

Beiträge im Forum: 250233
Registrierte User: 20449

Neue User:

  • Mroppoofpaync
  • 4aficiona2
  • AppBuilder

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 16 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association