abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter (View source)

Base class for filtering the subtree for certain node statuses.

The simplest way of building a CMSSiteTreeFilter is to create a pagesToBeShown() method that returns an Iterator of maps, each entry containing the 'ID' and 'ParentID' of the pages to be included in the tree. The result of a DB::query() can then be returned directly.

If you wish to make a more complex tree, you can overload includeInTree($page) to return true/ false depending on whether the given page should be included. Note that you will need to include parent helper pages yourself.

Traits

A class that can be instantiated or replaced via DI

Properties

protected array $params

Search parameters, mostly properties on SiteTree.

protected array $_cache_ids

List of filtered items and all their parents

protected array $_cache_highlight_ids

Subset of $_cache_ids which include only items that appear directly in search results.

protected array $_cache_expanded
protected string $childrenMethod
protected string $numChildrenMethod

Methods

public static 
create(mixed ...$args)

An implementation of the factory method, allows you to create an instance of a class

public static 
singleton(string $class = null)

Creates a class instance by the "singleton" design pattern.

public static 
array
get_all_filters()

Returns a sorted array of all implementators of CMSSiteTreeFilter, suitable for use in a dropdown.

public
__construct($params = null)

No description

public
string
getChildrenMethod()

Method on Hierarchy objects which is used to traverse into children relationships.

public
string
getNumChildrenMethod()

Method on Hierarchy objects which is used find the number of children for a parent page

public
array|string
getPageClasses(DataObject $page) deprecated

No description

public
getFilteredPages()

Gets the list of filtered pages

public
array
pagesIncluded()

No description

protected
populateIDs()

Populate the IDs of the pages returned by pagesIncluded(), also including the necessary parent helper pages.

public
bool
isPageIncluded(DataObject $page) deprecated

No description

protected
applyDefaultFilters(DataList $query)

Applies the default filters to a specified DataList of pages

protected
array
mapIDs(SS_List $pages)

Maps a list of pages to an array of associative arrays with ID and ParentID keys

Details

static Injectable create(mixed ...$args)

An implementation of the factory method, allows you to create an instance of a class

This method will defer class substitution to the Injector API, which can be customised via the Config API to declare substitution classes.

This can be called in one of two ways - either calling via the class directly, or calling on Object and passing the class name as the first parameter. The following are equivalent: $list = DataList::create(SiteTree::class); $list = SiteTree::get();

Parameters

mixed ...$args

Return Value

Injectable

static Injectable singleton(string $class = null)

Creates a class instance by the "singleton" design pattern.

It will always return the same instance for this class, which can be used for performance reasons and as a simple way to access instance methods which don't rely on instance data (e.g. the custom SilverStripe static handling).

Parameters

string $class

Optional classname to create, if the called class should not be used

Return Value

Injectable

The singleton instance

static array get_all_filters()

Returns a sorted array of all implementators of CMSSiteTreeFilter, suitable for use in a dropdown.

Return Value

array

__construct($params = null)

No description

Parameters

$params

string getChildrenMethod()

Method on Hierarchy objects which is used to traverse into children relationships.

Return Value

string

string getNumChildrenMethod()

Method on Hierarchy objects which is used find the number of children for a parent page

Return Value

string

array|string getPageClasses(DataObject $page) deprecated

deprecated 5.4.0 Will be renamed to getRecordClasses()

No description

Parameters

DataObject $page

Return Value

array|string

abstract SS_List getFilteredPages()

Gets the list of filtered pages

Return Value

SS_List

See also

{@link SiteTree::getStatusFlags()}

array pagesIncluded()

No description

Return Value

array

Map of Page IDs to their respective ParentID values.

protected populateIDs()

Populate the IDs of the pages returned by pagesIncluded(), also including the necessary parent helper pages.

bool isPageIncluded(DataObject $page) deprecated

deprecated 5.4.0 Will be renamed to isRecordIncluded()

No description

Parameters

DataObject $page

Return Value

bool

protected DataList applyDefaultFilters(DataList $query)

Applies the default filters to a specified DataList of pages

Parameters

DataList $query

Unfiltered query

Return Value

DataList

Filtered query

protected array mapIDs(SS_List $pages)

Maps a list of pages to an array of associative arrays with ID and ParentID keys

Parameters

SS_List $pages

Return Value

array