WireSitemapXML class

Turn-key ProcessWire module for easily configuring and rendering sitemap.xml output.

Part of the ProDevTools series of modules. See documentation.

Usage example (/site/templates/sitemap-xml.php):

$sitemap = $modules->get('WireSitemapXML');
$sitemap->addPage('/some/hidden/page/');
$sitemap->setPriorityByTemplate('home', 1.0);
$sitemap->setChangefreqByTemplate('blog', 'weekly');
$sitemap->setUrlSegmentsByTemplate('blog-post', [ 'foo', 'bar', 'baz' ]);
$sitemap->execute();
return $this->halt();

Click any linked item for full usage details and examples. Hookable methods are indicated with the icon. In addition to those shown below, the WireSitemapXML class also inherits all the methods and properties of: WireData and Wire.

Show $var?             Show args?        

Pages

NameReturnSummary 
$sitemap->addChildrenSelector($parent, string $selectorString)
$thisAdd selector for finding children of given $parent page 
$sitemap->addPage($page)
selfAdd additional page to include in sitemap (including its children, if any) 
$sitemap->addParent($page)
selfAdd hidden or removed page that you still want to be used as a parent (i.e. have children included) 
$sitemap->allowPage(Page $page)
boolAllow page to be rendered in sitemap? (hookable)
$sitemap->allowParent(Page $page)
boolAllow children to be rendered for given page? (hookable)
$sitemap->getRemovedTemplates()
arrayGet names of removed templates 
$sitemap->getRootPage()
PageGet the root/starting page for the sitemap (typically homepage) 
$sitemap->removePage($page)
(nothing)Set a page to remove from the sitemap 
$sitemap->removeParent($page)
selfAdd page that should have its children excluded from render, even if $page itself is included 
$sitemap->removeTemplate($template)
selfRemove all pages using given template from the sitemap 
$sitemap->setRootPage($page)
$thisSet the root (starting) page for sitemap 

Additional methods and properties

In addition to the methods and properties above, WireSitemapXML also inherits the methods and properties of these classes:

API reference based on ProcessWire core version 3.0.236

Latest news

  • ProcessWire Weekly #543
    In the 543rd issue of ProcessWire Weekly we'll check out the latest weekly update from Ryan, introduce a couple of new third party modules — both authored by Bernhard Baumrock — and more. Read on!
    Weekly.pw / 5 October 2024
  • Custom Fields Module
    This week we look at a new ProFields module named Custom Fields. This module provides a way to rapidly build out ProcessWire fields that contain any number of subfields/properties within them.
    Blog / 30 August 2024
  • Subscribe to weekly ProcessWire news

I just love the easy and intuitive ProcessWire API. ProcessWire rocks!” —Jens Martsch, Web developer