MediaWiki REL1_35
|
Represents a filter group (used on ChangesListSpecialPage and descendants) More...
Public Member Functions | |
__construct (array $groupDefinition) | |
Create a new filter group with the specified configuration. | |
addOptions (FormOptions $opts, $allowDefaults, $isStructuredFiltersEnabled) | |
All the options represented by this filter group to $opts. | |
anySelected (FormOptions $opts) | |
Check if any filter in this group is selected. | |
conflictsWith ( $other, $globalKey, $forwardKey, $backwardKey) | |
Marks that the given ChangesListFilterGroup or ChangesListFilter conflicts with this object. | |
getConflictingFilters () | |
Get filters conflicting with this filter group. | |
getConflictingGroups () | |
Get groups conflicting with this filter group. | |
getFilter ( $name) | |
Get filter by name. | |
getFilters () | |
getJsData () | |
Gets the JS data in the format required by the front-end of the structured UI. | |
getName () | |
getPriority () | |
getTitle () | |
getType () | |
modifyQuery (IDatabase $dbr, ChangesListSpecialPage $specialPage, &$tables, &$fields, &$conds, &$query_options, &$join_conds, FormOptions $opts, $isStructuredFiltersEnabled) | |
Modifies the query to include the filter group. | |
setUnidirectionalConflict ( $other, $globalDescription, $contextDescription) | |
Marks that the given ChangesListFilterGroup or ChangesListFilter conflicts with this object. | |
Protected Member Functions | |
createFilter (array $filterDefinition) | |
Creates a filter of the appropriate type for this group, from the definition. | |
Protected Attributes | |
array | $conflictingFilters = [] |
Array of associative arrays with conflict information. | |
array | $conflictingGroups = [] |
Array of associative arrays with conflict information. | |
array | $filters |
Associative array of filters, as ChangesListFilter objects, with filter name as key. | |
bool | $isFullCoverage |
Whether this group is full coverage. | |
string | $name |
Name (internal identifier) | |
string | $priority |
Priority integer. | |
string | $title |
i18n key for title | |
string | $type |
Type, from a TYPE constant of a subclass. | |
string null | $whatsThisBody |
i18n key for body of What's This? | |
string null | $whatsThisHeader |
i18n key for header of What's This? | |
string null | $whatsThisLinkText |
i18n key for What's This? link | |
string null | $whatsThisUrl |
URL of What's This? link. | |
Private Attributes | |
const | DEFAULT_PRIORITY = -100 |
const | RESERVED_NAME_CHAR = '_' |
Represents a filter group (used on ChangesListSpecialPage and descendants)
Definition at line 37 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::__construct | ( | array | $groupDefinition | ) |
Create a new filter group with the specified configuration.
array | $groupDefinition | Configuration of group
|
Reimplemented in ChangesListBooleanFilterGroup, and ChangesListStringOptionsFilterGroup.
Definition at line 156 of file ChangesListFilterGroup.php.
References createFilter().
|
abstract |
All the options represented by this filter group to $opts.
FormOptions | $opts | |
bool | $allowDefaults | |
bool | $isStructuredFiltersEnabled |
Reimplemented in ChangesListBooleanFilterGroup, and ChangesListStringOptionsFilterGroup.
ChangesListFilterGroup::anySelected | ( | FormOptions | $opts | ) |
Check if any filter in this group is selected.
FormOptions | $opts |
Definition at line 432 of file ChangesListFilterGroup.php.
References getFilters(), and ChangesListFilter\isSelected().
Referenced by ChangesListFilter\activelyInConflictWithGroup().
ChangesListFilterGroup::conflictsWith | ( | $other, | |
$globalKey, | |||
$forwardKey, | |||
$backwardKey | |||
) |
Marks that the given ChangesListFilterGroup or ChangesListFilter conflicts with this object.
WARNING: This means there is a conflict when both things are shown (not filtered out), even for the hide-based filters. So e.g. conflicting with 'hideanons' means there is a conflict if only anonymous users are shown.
ChangesListFilterGroup | ChangesListFilter | $other | |
string | $globalKey | i18n key for top-level conflict message |
string | $forwardKey | i18n key for conflict message in this direction (when in UI context of $this object) |
string | $backwardKey | i18n key for conflict message in reverse direction (when in UI context of $other object) |
Definition at line 229 of file ChangesListFilterGroup.php.
References setUnidirectionalConflict().
|
abstractprotected |
Creates a filter of the appropriate type for this group, from the definition.
array | $filterDefinition | Filter definition |
Reimplemented in ChangesListBooleanFilterGroup, and ChangesListStringOptionsFilterGroup.
Referenced by __construct().
ChangesListFilterGroup::getConflictingFilters | ( | ) |
Get filters conflicting with this filter group.
Definition at line 417 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::getConflictingGroups | ( | ) |
Get groups conflicting with this filter group.
Definition at line 403 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::getFilter | ( | $name | ) |
Get filter by name.
string | $name | Filter name |
Definition at line 321 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::getFilters | ( | ) |
Definition at line 311 of file ChangesListFilterGroup.php.
Referenced by ChangesListBooleanFilterGroup\addOptions(), anySelected(), and ChangesListBooleanFilterGroup\modifyQuery().
ChangesListFilterGroup::getJsData | ( | ) |
Gets the JS data in the format required by the front-end of the structured UI.
Reimplemented in ChangesListStringOptionsFilterGroup.
Definition at line 332 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::getName | ( | ) |
Definition at line 282 of file ChangesListFilterGroup.php.
Referenced by ChangesListStringOptionsFilterGroup\addOptions(), ChangesListStringOptionsFilterGroup\modifyQuery(), and ChangesListSpecialPage\registerFilterGroup().
ChangesListFilterGroup::getPriority | ( | ) |
Definition at line 303 of file ChangesListFilterGroup.php.
ChangesListFilterGroup::getTitle | ( | ) |
Definition at line 289 of file ChangesListFilterGroup.php.
References $title.
ChangesListFilterGroup::getType | ( | ) |
Definition at line 296 of file ChangesListFilterGroup.php.
References $type.
|
abstract |
Modifies the query to include the filter group.
The modification is only done if the filter group is in effect. This means that one or more valid and allowed filters were selected.
IDatabase | $dbr | Database, for addQuotes, makeList, and similar |
ChangesListSpecialPage | $specialPage | Current special page |
array | &$tables | Array of tables; see IDatabase::select $table |
array | &$fields | Array of fields; see IDatabase::select $vars |
array | &$conds | Array of conditions; see IDatabase::select $conds |
array | &$query_options | Array of query options; see IDatabase::select $options |
array | &$join_conds | Array of join conditions; see IDatabase::select $join_conds |
FormOptions | $opts | Wrapper for the current request options and their defaults |
bool | $isStructuredFiltersEnabled | True if the Structured UI is currently enabled |
Reimplemented in ChangesListBooleanFilterGroup, and ChangesListStringOptionsFilterGroup.
ChangesListFilterGroup::setUnidirectionalConflict | ( | $other, | |
$globalDescription, | |||
$contextDescription | |||
) |
Marks that the given ChangesListFilterGroup or ChangesListFilter conflicts with this object.
Internal use ONLY.
ChangesListFilterGroup | ChangesListFilter | $other | |
string | $globalDescription | i18n key for top-level conflict message |
string | $contextDescription | i18n key for conflict message in this direction (when in UI context of $this object) |
Definition at line 258 of file ChangesListFilterGroup.php.
Referenced by conflictsWith().
|
protected |
Array of associative arrays with conflict information.
See setUnidirectionalConflict
Definition at line 124 of file ChangesListFilterGroup.php.
|
protected |
Array of associative arrays with conflict information.
See setUnidirectionalConflict
Definition at line 116 of file ChangesListFilterGroup.php.
|
protected |
Associative array of filters, as ChangesListFilter objects, with filter name as key.
Definition at line 100 of file ChangesListFilterGroup.php.
|
protected |
Whether this group is full coverage.
This means that checking every item in the group means no changes list (e.g. RecentChanges) entries are filtered out.
Definition at line 108 of file ChangesListFilterGroup.php.
|
protected |
Name (internal identifier)
Definition at line 43 of file ChangesListFilterGroup.php.
|
protected |
Priority integer.
Higher values means higher up in the group list.
Definition at line 93 of file ChangesListFilterGroup.php.
|
protected |
i18n key for title
Definition at line 50 of file ChangesListFilterGroup.php.
|
protected |
Type, from a TYPE constant of a subclass.
Definition at line 85 of file ChangesListFilterGroup.php.
|
protected |
i18n key for body of What's This?
Definition at line 64 of file ChangesListFilterGroup.php.
|
protected |
i18n key for header of What's This?
Definition at line 57 of file ChangesListFilterGroup.php.
|
protected |
i18n key for What's This? link
Definition at line 78 of file ChangesListFilterGroup.php.
|
protected |
URL of What's This? link.
Definition at line 71 of file ChangesListFilterGroup.php.
|
private |
Definition at line 126 of file ChangesListFilterGroup.php.
|
private |
Definition at line 128 of file ChangesListFilterGroup.php.