ProcessWire - Page Object
Links
https://processwire.com/api/ref/page/
Einführung
Das Page Objekt enthält alle Daten einer Seite. Normalerweise kann man bei der Arbeit mit Templates direkt
$page
Das $pages Objekt liefert Funktionen mit denen man Seiten durchsuchen kann. schreiben um auf die aktuelle Seite zuzugreifen. Wenn man das Feld einer aktuellen Seite abrufen möchte kann man das dann z.B. so machen echo $page->title
Wichtige Funktionen
find()
https://processwire.com/api/ref/pages/find/
Findet Seiten und gibt diese als PageArray zurück. Mit den Optionen kann man aber auch nur die Seitenids zurückgeben
findOne
https://processwire.com/api/ref/pages/find-one/
$blogPost = $pages->findOne("template=blog-post, sort=-created");
Im Gegensatz zu $pages->find() liefert findeOne kein Array sondern direkt ein Seitenobjekt. Spart arbeit wenn man nur ein Ergebnis braucht.
Seiten holen
Im einfachsten Fall kann man Seitenobjekte über Get abrufen
// Get a page by ID
$p = $pages->get(1234);
// Get a page by path
$p = $pages->get('/about/contact/');
// Get a random 'skyscraper' page by selector string
$p = $pages->get('template=skyscraper, sort=random');
Über einen Selektor, wie im letzten Beispiel, kann man schnell Seiten abfragen (siehe ProcessWire - Selectors)
Aktuelle Seite
Innerhalb der normalen Templates hat man über $page Zugriff auf die aktuelle Seite
$meineSeite = $page;
Wenn $page für die aktuelle Seite nicht zur Verfügung steht (z.B. in Modulen) kann man sich über das wire Objekt die aktuelle Seite eines Nutzers holen:
$page = wire("page");
$t = $page->title;
Seiten modifizieren oder erstellen
Wenn die Seite noch nicht vorhanden ist wird sie mit save() automatisch erstellt. Wenn Sie existiert upgedatet.
Man kann auch nur ein spezifisches Feld einer Seite speichern.
// Modify a page and save it
$p = $pages->get('/festivals/decatur/beer/');
$p->of(false); // turn off output formatting, if it's on
$p->title = "Decatur Beer Festival";
$p->summary = "Come and enjoy fine beer and good company at the Decatur Beer Festival.";
$pages->save($p); // Same as $p->save();
$page->save($fieldName); // save a specific Field
Neue Seiten erzeugen
$fields = array('title', 'vorname', 'plz', [...]);
$values = array("Mein Titel","Max","D72810");
// fill fieldnames i.e. from database query...
list($oe_id, $oe_nl_name, $oe_plz, [...]) = $row;
$p = new Page();
$p->template = "templatename";
$p->parent = $parentId;// Elternseite
$p->title = "Titel der Seite";
$p->of(false);
if(!$p->save()) echo "Seite konnte nicht gespeichert werden";
// populate fields
$p->vorname = "Max";
$p->[feldname] = "Inhalt des Feldes";
$p->save();
wire('pages') und $pages
Innerhalb von Templates kann man in der Regel auf $pages für alle Seiten und auf $page für die aktuelle Seite zugreifen.
Anderswo geht das nicht, aber innerhalb von ProcessWire kann man denoch über
wire()->pages
oder
wire('pages')
auf das Seitenobjekt zugreifen.
NullPage
Viele Funktionen geben ein NullPage Objekt zurück wenn keine Seite gefunden wurde.
if(!$item->id) {
// this is a NullPage
}
if($item instanceof NullPage) {
// this is a NullPage
}
Seitenstatus
The page statuses are a bitmask so it's possible for there to be multiple statuses on a page, like unpublished and hidden. So it's best to add and remove statuses with the addStatus and removeStatus functions, i.e.
$page->addStatus(Page::statusUnpublished);
// same as:
$page->status = $page->status | Page::statusUnpublished;
$page->removeStatus(Page::statusHidden);
// same as:
$page->status = $page->status & ~Page::statusHidden;
You can also check the status of a page by using the is() function:
if($page->is(Page::statusUnpublished)) { ... }
// same as
if($page->status & Page::statusUnpublished) { ... }