• Apfeltalk ändert einen Teil seiner Allgemeinen Geschäftsbedingungen (AGB), das Löschen von Useraccounts betreffend.
    Näheres könnt Ihr hier nachlesen: AGB-Änderung
  • Ein Blick aus dem Fenster verrät es: Der Lenz ist da. Passenderweise wird auch der Frühling unser Thema für das Foto des Monats. Hier geht es lang --> Klick

[TYPO3] Bestimmten Wert mittels Typoscript aus Datenbank auslesen

ffleige

Auralia
Registriert
10.05.05
Beiträge
203
Hallo,

ich stehe mal wieder vor einem kleinen, aber lästigen Problem bei Typo3.

Ich möchte aus einer Datenbanktabelle einen bestimmten Wert durch Typoscript auslesen lassen, z. B. durch folgendes Konstrukt:

Code:
page.10.marks.PAGETITLE = TEXT
page.10.marks.PAGETITLE {
  data = DB : tx_pisprojectlist_project : 1 : projecttitle
}

Das funktioniert auch wunderbar! Aber jetzt möchte ich Dynamik in die ganze Sache hereinbringen. Die statische UID soll durch einen dynamischen Wert eines Parameters (P) ersetzt werden. Also in etwa so:

Code:
page.10.marks.PAGETITLE = TEXT
page.10.marks.PAGETITLE {
  data = DB : tx_pisprojectlist_project : {GPvar:P} : projecttitle
  insertData = 1
}

Das funktioniert jetzt leider nicht mehr. :(
Der Zugriff auf den Parameter klappt eingentlich (habe ihn mir mittels "value" einmal ausgeben lassen), aber halt nicht im Kontext mit der "data"-Anweisung.

Kenn jemand eine Lösung für dieses Problem oder eine Alternative?
Vielen Dank schon mal für eure Hilfe! :)

Viele Grüße
Frank
 

ffleige

Auralia
Registriert
10.05.05
Beiträge
203
Gelöst durch User-Function

Hallo,

habe das Problem mit Hilfe einer User-Function gelöst:

TypoScript-Code (Auszug):
Code:
# Binde die benötigte Klasse ein
includeLibs.tx_pisprojectlist_pi1 = EXT:pisprojectlist/pi1/class.tx_pisprojectlist_pi1.php

page.10.marks.PAGETITLE = USER_INT
page.10.marks.PAGETITLE {
  userFunc = tx_pisprojectlist_pi1->getProjecttitle
}

PHP-Code (Auszug aus class.tx_pisprojectlist_pi1.php):
Code:
function getProjecttitle($content,$conf)
{
  if (!isset($_GET["P"])) return $content; 
  return $content . current($GLOBALS['TYPO3_DB']->sql_fetch_row($GLOBALS['TYPO3_DB']->exec_SELECTquery("pisprojecttitle","tx_pisprojectlist_project","uid=" . $_GET["P"])));
}


Aber vielleicht hat jemand trotzdem eine Idee, wie man so etwas "eleganter" lösen kann. :)

Viele Grüße
Frank