[gelöst] Exposed Filter: Textfeld als DropDown ausgeben
am 22.09.2010 - 13:26 Uhr in
Hallo zusammen,
ich habe ein View welches Nodes nach Ihrer Herkunft gefiltert anzeigt. Bei jeder Node ist ein "Location"-Feld in dem u.a. die Stadt angegeben werden kann. Dieses lasse ich als Exposed Filter durch den Website-Benutzer eingeben. Das klappt auch wunderbar, allerdings bekomme ich ein Textfeld in welchem ich den Stadtnamen eintippen muss. Stattdessen möchte ich dort aber ein DropDown Feld haben mit allen verfügbaren Locations.
Meine erste spontane Idee war "Rules" zu bemühen und nach Erstellen einer neuen Node das entsprechende Location Feld in eine Taxonomy-Liste einzutragen und dann via Taxonomy den Filter für den View bestimmen.
Ist das eine gängige Lösungsmöglichkeit, oder totaler Murks? :) Wie kann man das am elegantesten lösen? Über Vorschläge/Ideen würd ich mich freuen.
Beste Grüße,
Milchbar
- Anmelden oder Registrieren um Kommentare zu schreiben
Gelöst
am 15.11.2010 - 18:11 Uhr
Via Rules habe ich nun beim erstellen/updaten eines Node-Types das gewünschte Feld zu einem Taxonomy Vokabular hinzugefügt. Die gewünschten Suchmaske (Exposed Filter) modifiziere ich via hook_form_alter um ein dropdown aus allen Terms eines Vokabulars zu erstellen.
edit: Hierzu ist ein eigenes Modul nötig!
<?php
function mymodule_form_alter(&$form, $form_state, $form_id) {
switch ($form_id) {
case 'views_exposed_form':
if (isset($form['city'])) {
$form['city']['#pre_render'][] = 'select_cities';
}
break;
default: break;
}
}
?>
Wenn also auf der Seite ein "views_exposed_form" mit einem Formular-Element namens "City" auftaucht, dann wird dieses durch die Funktion select_cities neu geschrieben.
<?php
function select_cities($element) {
$vid = 7; // Taxonomy ID
$sql = "SELECT * FROM {term_data} WHERE vid = %d";
$result = db_query(db_rewrite_sql($sql), $vid);
$matches[''] = '<Alle>'; // Wildcard für alle Ergebnisse zufügen
while ($data = db_fetch_object($result)){
$matches[$data->name] = $data->name;
}
$clean = array_unique($matches); // alle Duplikate rausschmeißen
$element['#multiple'] = FALSE;
$element['#type'] = 'select';
$element['#options'] = $matches;
unset($element['#size']);
return $element;
}
?>
Vielleicht hilft das jemandem in Zukunft :)
Beste Grüße,
Milchbar
funktioniert das wirklich
am 15.11.2010 - 17:52 Uhr
hi,
auf der suche nach einer lösung für eine ähnliche aufgabenstellung bin ich auf deinen thread gestossen, danke dafür, hat mir weiter geholfen.
jedoch musste ich dafür ein eigenes modul schreiben, hook_form_alter funktioniert doch gar nicht bei theme?
also statt mythemename_form_alter mymodule_form_alter, nur so hat es bei mir geklappt.
würde mich trotzdem interessieren, wie du das genauer gemacht hast.
danke & lg
iwasnet
---
computer & communication
http://www.com-and-com.com
In der Tat...
am 15.11.2010 - 18:14 Uhr
Hi iwasnet,
vielen Dank für den Hinweis. Das war in der Tat Blödsinn. Ich habe die Korrektur in meinen Beitrag eingebaut. :)
Beste Grüße,
Milchbar