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 #551
    In the 551st issue of ProcessWire Weekly we'll check out what's new in the core this week, share a new weekly poll, and more. Read on!
    Weekly.pw / 1 December 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

“To Drupal, or to ProcessWire? The million dollar choice. We decided to make an early switch to PW. And in retrospect, ProcessWire was probably the best decision we made. Thanks are due to ProcessWire and the amazing system and set of modules that are in place.” —Unni Krishnan, Founder of PigtailPundits