Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Themes & Theming ›

Hinzufügen von font awesome i class in Drupal Links System

Eingetragen von tom909 (44)
am 30.07.2014 - 13:17 Uhr in
  • Themes & Theming
  • Drupal 7.x

Hi Drupalfreunde,

Ich habe ein Problem, dass mich etwas verwirrt.

Es gibt die Möglichkeit mit font awesome simpel einfach einzufügen wo auch immer man ein Icon benutzen will.

Nach etwas längerer Suche habe ich auch einen netten Hook gefunden für mein theme welches mit Bootstrap 3.x erstellt habe und nutze folgenden Code:

<?php
function my_bootstrap_link($variables) {
$variables['options']['html'] = TRUE;
dpm($variables);
  return
'<a href="' . check_plain(url($variables['path'], $variables['options'])) . '"' . drupal_attributes($variables['options']['attributes']) . '>' . ($variables['options']['html'] ? $variables['text'] : check_plain($variables['text'])) . '</a>';
}

?>

Dieser Code ermöglicht mir ganz einfach Titel von Links entsprechend HTML Code hinzuzufügen der auch ausgegeben wird.

Für alle normalen Menus klappt das auch sehr gut.

Doch wo es Probleme gibt sind Tab Menus z.B. beim User-Profil

Wir der Tab nicht angeglickt(also "active" gesetzt) dann kann man auch das Icon sehen. Klicke auf den Tab z.B. Edit, dann verschwindet das schöne Icon und ich sehe wieder den HTML Code als reinen Text vor Edit, also z.B. " edit"

Das passiert immer nur dann wenn ich den Tab Menü Punkt klicke und somit active setze.

Kann es sein, dass Drupal bei Menu Tabs noch einer andere Funktion hat, denn komischerweise funktionieren die Icons in allen normalen Menü reitern ohne diesen Fehler.

Vielleicht stand auch jemand vor diesem Problem, denn ansonsten werde ich wohl die Tabs komplett deaktivieren und nur mit Menus arbeiten wenn das nicht funktionieren sollte. Es scheint mir so dass bei dem active status die span class invisible dazu kommt und ich glaube fast, dass mein Hook an der Stelle den Titel wieder in normalen Text wandelt(nur weiß ich aktuell nicht wo menu Tab reiter anders aufgerufen werden, denn eigentlich wirkt ja mein hook auch drauf, wird aber dann beim active state wieder ignoriert.

Um den Fehler mit Bootstrap auszuschliessen habe ich das ganze auch mal mit dem Drupal Standard Theme versucht und habe den gleichen Fehler.

Beim User Profil tauchen die Icons nur dann auf wenn man nicht aktiv auf einen Tab ist. Klickt man den Tab an und wechselt somit auf dessen Inhalt, dann taucht wieder der textschriftzug des Icons auf, quasi html code als text ohne die umsetzung des html.

Vielen Dank schon mal!

UPDATE:

Ich habe das Problem noch nicht gelöst vermute aber das genau hier der Fehler zu finden ist:

<?php
function theme_menu_local_task($variables) {
 
$link = $variables['element']['#link'];
 
$link_text = $link['title'];

  if (!empty(
$variables['element']['#active'])) {
   
// Add text to indicate active tab for non-visual users.
   
$active = '<span class="element-invisible">' . t('(active tab)') . '</span>';

   
// If the link does not contain HTML already, check_plain() it now.
    // After we set 'html'=TRUE the link will not be sanitized by l().
   
if (empty($link['localized_options']['html'])) {
     
$link['title'] = check_plain($link['title']);
    }
   
$link['localized_options']['html'] = TRUE;
   
$link_text = t('!local-task-title!active', array('!local-task-title' => $link['title'], '!active' => $active));
  }

  return
'<li' . (!empty($variables['element']['#active']) ? ' class="active"' : '') . '>' . l($link_text, $link['href'], $link['localized_options']) . "</li>\n";
}
?>

Ich vermute dass diese Funktion laut API Übersicht nochmal meinen Link bearbeitet und wieder den HTML in Text wandelt. Werde den Code entsprechend bearbeiten&einfügen&testen.

So, genau da lag auch der Fehler wie vermutet, einfach die Zeilen

<?php

   
if (empty($link['localized_options']['html'])) {
     
$link['title'] = check_plain($link['title']);
    }
?>

ausklammern und der genannte Fehler ist weg.

Also wer unbedingt wie ich icons in titles per html drin haben will, kann diesen Code einfach in sein Template packen und sich freuen.

‹ Tipps für "Themen-Sucher" Hinzufügen von font awesome i class in Drupal Links System ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • fbsmp\plugins Hilfe
  • Migration über feeds von D6 auf D8
  • Wie in hook_views_query_alter() einen join auf Tabelle url_alias durchführen?
  • Theme Classy sei installiert, ist aber nicht bei Themes
  • Composer 1 zu Composer 2
  • Bitte um Einschätzung: Upgrade von Drupal 7 auf 9
  • Scroll zu View-Ergebnissen nachdem Filter angewendet ist
  • SQL-Injection? User hat sich Zugriff aufs Admin-Konto geholt und Änderungen vorgenommen.
  • [gelöst] Persönliches Kontaktformular, oder interne User Nachrichten
  • Webform Progress Symbol (Loading icon)?
  • Mehrere freie Mitarbeiter:innen gesucht für Kooperation
  • Webform Submission Eingaben über Views ausgeben?
Weiter

Neue Kommentare

  • Da wirst Du den Bug wohl selbst beheben müssen
    vor 21 Stunden 2 Minuten
  • Gleiches Problem: bootstrap 4
    vor 2 Tagen 22 Stunden
  • Da wirst Du den Bug wohl
    vor 3 Tagen 1 Stunde
  • Immer noch composer 1 zu 2
    vor 3 Tagen 16 Stunden
  • Beziehung Branche Adresse!
    vor 2 Tagen 2 Stunden
  • Sorry, dann gab es das bei
    vor 3 Tagen 18 Stunden
  • Beziehung Branche Adresse!
    vor 3 Tagen 18 Stunden
  • Auf Englisch heißt das
    vor 3 Tagen 21 Stunden
  • Composer Upgrade bei bestehendem Projekt
    vor 4 Tagen 1 Stunde
  • Du meinst Argument?
    vor 4 Tagen 1 Stunde

Statistik

Beiträge im Forum: 248393
Registrierte User: 19752

Neue User:

  • Aman_Musani
  • Dustinjex
  • Rickywap

» Alle User anzeigen

User nach Punkten sortiert:
wla9288
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3845
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 4 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