Processwire - API: Unterschied zwischen den Versionen

Aus Wikizone
Wechseln zu: Navigation, Suche
Zeile 14: Zeile 14:
 
== Seiten via API erstellen ==
 
== Seiten via API erstellen ==
 
  https://processwire.com/talk/topic/352-creating-pages-via-api/
 
  https://processwire.com/talk/topic/352-creating-pages-via-api/
=== Allgemein ===
+
=== In Modulen ===
 +
Siehe auch: https://processwire.com/blog/posts/processwire-2.6.21-upgrades-comments-more-on-pw-3.x/#more-updates-on-processwire-3.0
 
<syntaxhighlight lang="php">
 
<syntaxhighlight lang="php">
include(./index.php) // bootstrap PW
+
include(./index.php) // bootstrap PW (not needed when creating pages and your already in bootstraped mode (i.e. on a page template)
  
 
$p = new Page(); // create new page object
 
$p = new Page(); // create new page object
Zeile 24: Zeile 25:
 
$p->title = 'My New Page'; // set page title (not neccessary but recommended)
 
$p->title = 'My New Page'; // set page title (not neccessary but recommended)
  
$p->of(false); // needed in page context otherwise it would not save
 
 
// added by Ryan: save page in preparation for adding files (#1)
 
// added by Ryan: save page in preparation for adding files (#1)
 
$p->save();
 
$p->save();

Version vom 29. Oktober 2018, 15:41 Uhr

Allgemeine Tipps

  • Wenn kein Zugriff auf das Pages Objekt möglich ist kann man über wire()->pages auf die Funktionen zugreifen.

ProcessWire - Seiten löschen

https://processwire.com/api/ref/page/delete/g/

// Delete pages named "delete-me" that don't have children
$items = $pages->find("name=delete-me, numChildren=0");
foreach($items as $item) {
  $item->delete();
}

Seiten via API erstellen

https://processwire.com/talk/topic/352-creating-pages-via-api/

In Modulen

Siehe auch: https://processwire.com/blog/posts/processwire-2.6.21-upgrades-comments-more-on-pw-3.x/#more-updates-on-processwire-3.0

include(./index.php) // bootstrap PW (not needed when creating pages and your already in bootstraped mode (i.e. on a page template)

$p = new Page(); // create new page object
$p->template = 'page'; // set template
$p->parent = wire('pages')->get('/about/'); // set the parent
$p->name = 'mynewpage_url'; // give it a name used in the url for the page
$p->title = 'My New Page'; // set page title (not neccessary but recommended)

// added by Ryan: save page in preparation for adding files (#1)
$p->save();

// populate fields

$p->image = 'path/to/image.jpg'; // populate a single image field (#2)
$p->images->add('path/to/image1.jpg'); // add multiple to images field

$p->save();

// testing

echo 'id: '.$p->id.'<br/>';
echo 'path: '.$p->path;

Tipps

  • save a page before adding files to it
  • To add a single image', you'd need to do $p->image = 'path/to/image.jpg; rather than $p->image('path/to/image.jpg'). This is because there is no Page::image() function
  • may need to add a $page->setOutputFormatting(false)
  • if your module creates new objects, like $page = new Page();, you'll want to wire those new objects to the current ProcessWire instance, which makes it a "wired" object. You do it like this: $page = $this->wire(new Page());