Ist PAX im GUI aktiviert, wird das Template vor der Übergabe an phpCMS an PAX übergeben um diverse
Erweiterungen schon im Vorfeld auszufiltern. So kommt phpCMS nicht durcheinander und PAX kann
auch weiterentwickelt werden, ohne weitere grössere Eingriffe im Parser von phpCMS vornehmen zu müssen.
Wie von phpCMS bekannt, werden Scripte, die über das Feld {SCRIPT} eingebunden sind, dynamisch zur Laufzeit in die Ausgabe eingebunden. Sollte Servercache aktiviert sein, wird die Seite jedoch auch im Cache abgelegt (obwohl dynamisch). Im Cache wird aber eben nur jener Teil abgelegt, welcher statisch ist, sich also zur Laufzeit nicht verändert.
Von dieser Funktionalität macht auch PAX gebrauch.
PAX benötigt man, wenn PHP in Templates eingebunden werden soll.
Weiters gibt es mit PAX verschiedene TAGS (PAXTAGS), welche bestimmte Eigenschaften haben.
Bisher war es in phpCMS nicht möglich PHP in Templates einzubinden. Es bestand nur die Möglichkeit, wie schon oben angeführt, über {SCRIPT} externe Scripte in einer Contentseite einzubinden. Da ich aber zum Zeitpunt der PAX-Idee Bedarf hatte, ein Umfragescript auf jeder Seite einzubinden, musste ich mir Gedanken machen wie das funktionieren könnte, ohne in jeder Contentdatei das Feld {SCRIPT} anführen zu müssen. Und so entstand eben PAX *g*
Primär gilt es zu beachten, daß man mit PAX keine Debugging-Funktionalität für PHP hat!
Die Einbindung von PHP im Template geschieht auf sehr einfache Weise und auf eigene Gefahr:
Beispiel:
<!-- PAXPHP Blockbezeichnung
echo 'Hello World!';
PAXPHP Blockbezeichnung -->
Ist die Unterstützung von PHP im Template aktiviert, so müsste man jetzt ein "Hello World!" sehen:
Hello World!
Wie man am Beispiel sieht, ist es sehr einfach PHP einzubinden.
Mit PAXTAGS wird die Funktionalität von phpCMS um einige interessante Features erweitert.
Mit PAXINC können weitere Templates oder Dateien an beliebiger Stelle im Template eingebunden werden.
Vorhandene Links werden NICHT überprüft!
TAG:
PAXINC
SYNTAX:
<!-- PAXINC /pfad/vom_docroot/zu/template/oder/datei.html -->
oder
<!-- PAXINC http://www.domain.net/daten.html -->
Beispiel:
<!-- PAXINC http://phpcms.de/phpcms/doku/paxtest_de.html -->
ergibt bei aktivierten PAXTAGS:
Es können natürlich in den extern einzubindenden Templates oder Dateien weitere PAXTAGS geschrieben werden.
PAXHIGHLIGHT bietet eine farbliche Syntaxhervorhebung für PHP Quellcode.
PAXHIGHLIGHT eignet sich in erster Linie für auf dem eigenen Server befindliche PHP-Dateien. Wird hingegen per HTTP auf Dateien zugegriffen, kann sich die Syntaxhervorhebung naturgemäss nur auf den vom Server zurück gegebenen Code beziehen - nicht auf den Quellcode der jeweiligen Datei.
Zur syntaktischen Hervorhebung werden die im eingebauten Syntax Highlighter Ihrer PHP-Installation definierten Farben verwendet.
TAG:
PAXHIGHLIGHT
SYNTAX:
<!-- PAXHIGHLIGHT /pfad/von_root/zu/template/oder/datei.php -->
oder
<!-- PAXHIGHLIGHT http://www.domain.net/data.php -->
Beispiel:
steht PAXTAGS im GUI auf "On", sehen Sie hier den syntaktisch hervorgehobenen Quellcode der Datei "/demo/user.php".
PHP:
Mit PAXMENU ist die Möglichkeit gegeben, auf jedes Menüfeld zugreifen zu können.
TAG:
PAXMENU
SYNTAX:
<!-- PAXMENU FIELDNAME,CLASS -->
einfaches Beispiel:
Nehmen wir an, ich möchte einen Link zu einem Menüeintrag auf einer Seite oder in einem Template haben, dann wird dies wie folgt erreicht:
<a href="<!-- PAXMENU LINK,00.08.06.12 -->"><!-- PAXMENU MNAME,00.08.06.12 --></a>
Dies würde einen Link auf einen Menüpunkt mit seinem Feldwert ergeben.
Ausgabe bei aktivierter PAXTAGS Unterstützung:
Beispiel mit Titel (für IE), Zielframe/fenster und Statustextanzeige beim Mouseover:
<A HREF="<!-- PAXMENU LINK,00.08.06.12 -->" TARGET="<!-- PAXMENU TARGET,00.08.06.12 -->" onMouseOver="window.status='<!-- PAXMENU TEXT,00.08.06.12 -->';return true;" title="<!-- PAXMENU TEXT,00.08.06.12 -->"><!-- PAXMENU MNAME,00.08.06.12 --></a>
Ausgabe bei aktivierter PAXTAGS Unterstützung:
Meine MenüFelder sehen wie folgt aus:
LINK und CLASS sind ja Pfilchtfelder von phpCMS, also gibt es
hierbei auch keine Unterschiede in der Schreibweise!
TARGET: Zielfenster oder -frame für LINK
TEXT: Soll in der Statuszeile dargestellt weden.
MNAME: Feldname für Menübezeichnung
Zusammengefasst kann man auf jedes Menüfeld zugreifen, welches man in der .mnu-Datei auch definiert hat.
PAXCOMBO kann verwendet werden, um ein Drop-Down Menü für ein einzelnes in der Menü-Datei definiertes Menü zu erzeugen.
PAXCOMBO funktioniert möglicherweise nur im non-Stealth-Mode einwandfrei!
Das angegebene Menü muss einen eindeutigen Namen tragen!
Wenn ein Menü doppelt vorkommt (zb. SUB1), kommt es zu Fehlern bei der Darstellung!
Die Links werden grundsätzlich ausgehend von $home gesetzt!
TAG:
PAXCOMBO
SYNTAX:
<!-- PAXCOMBO MENUNAME,FIELDNAME,VALUES,SELECTED,SIZE,MULTI,ONCHANGE,FIRSTENTRY -->
MENUNAME | MENU:MAIN > hier wäre MAIN richtig. Darf in der Menüdatei nur ein mal vorkommen! |
FIELDNAME | Welcher Feldinhalt soll angezeigt werden? LINK, TEXT, NAME, usw... |
VALUES | optional - welcher Feldinhalt soll als Wert eingefügt werden. Ganz brauchbar für zb. automischen Linklisten. Wenn nichts angegeben, wird der Wert von FIELDNAME eingetragen. |
SELECTED | optional - welche Zeile des angezeigten Menüs soll den Focus erhalten |
SIZE | optional - Wie gross soll die Liste sein (in Zeilen) |
MULTI | (on/off) optional - Soll Multiselect erlaubt werden? |
ONCHANGE | (on/off) optional - Soll ein automatischer onselect bei eintragsaktivierung eingetragen werden? Praktisch für Linklisten |
FIRSTENTRY | optional - Text der als erster Eintrag angezeigt werden soll. zb: ~ select an entry ~ |
Beispiel:
<!-- PAXCOMBO SUB1, TEXT, LINK,, 1, off, on, ~ select your favorite ~ -->
ergibt bei aktivierten PAXTAGS:
PAXCOMBOALL kann verwendet werden, um ein automatisches Drop-Down Menü aller in der Menü-Datei definierten Menüs zu erzeugen.
TAG:
PAXCOMBOALL
SYNTAX:
<!-- PAXCOMBOALL FIELDNAME,SIZE,MULTI,ONCHANGE,FIRSTENTRY -->
FIELDNAME | Welcher Feldinhalt soll angezeigt werden? LINK, TEXT, NAME, usw... |
SIZE | optional - Wie gross soll die Liste sein (in Zeilen) |
MULTI | (on/off) optional - Soll Multiselect erlaubt werden? |
ONCHANGE | (on/off) optional - Soll ein automatischer onselect bei eintragsaktivierung eingetragen werden? Praktisch für Linklisten |
FIRSTENTRY | optional - Text der als erster Eintrag angezeigt werden soll. zb: ~ select an entry ~ |
Beispiel:
<!-- PAXCOMBOALL TEXT, 1, off, on, phpCMS Dokumentation -->
ergibt bei aktivierten PAXTAGS:
TAG:
PAXLASTMOD
SYNTAX:
<!-- PAXLASTMOD d.m.Y - H:m:s -->
Beispiel:
<!-- PAXLASTMOD d.m.Y - H:m:s -->
ergibt bei aktivierten PAXTAGS:
11.06.2003 - 04:06:06
zur Formatierung der Ausgabe werden die Werte, die für den PHP Befehl date verwendet werden, herangezogen.
Grundsätzlich stehen im PHP-Code alle globalen Werte zur Verfügung, die vor dem
Einlesen der Seite in phpCMS vorhanden sind. Welche das sind, entnimmt man am
besten der Dokumentation für phpCMS.
Nicht alle für Plug-ins beschriebenen
Variablen stehen bereit. Hier heisst es experimentieren. Eine genaue Aufstellung
werde ich laufend auf
http://lemon.ac bekanntgeben.
Übergabe von Parametern ist natürlich ebenso möglich: http://domain.net/index.htm?&var=red
Auch $PHP_SELF steht in unveränderter Form bereit. So könnte man eine Ausführung
oder Anzeige von bestimmten Teilen im Code von der dargestellten Seite abhängig machen.
Derzeit sind keine bekannt. Wenn man sich an die Richtlinien von phpCMS, PAX und PHP hält, dürfte nichts schief gehen.
Tips&Tricks&FAQ zu PAX unter
lemon.ac - BBS
Viel Spass
... Wernhard