MediaWiki REL1_35
|
Represents a filter group with multiple string options. 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.
| ||||||||||||||||||||||||||||
getDefault () | ||||||||||||||||||||||||||||
Gets default of filter group. | ||||||||||||||||||||||||||||
getJsData () | ||||||||||||||||||||||||||||
Gets the JS data in the format required by the front-end of the structured UI.
| ||||||||||||||||||||||||||||
modifyQuery (IDatabase $dbr, ChangesListSpecialPage $specialPage, &$tables, &$fields, &$conds, &$query_options, &$join_conds, FormOptions $opts, $isStructuredFiltersEnabled) | ||||||||||||||||||||||||||||
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.
| ||||||||||||||||||||||||||||
registerFilter (ChangesListStringOptionsFilter $filter) | ||||||||||||||||||||||||||||
Registers a filter in this group. | ||||||||||||||||||||||||||||
setDefault ( $defaultValue) | ||||||||||||||||||||||||||||
Sets default of filter group. | ||||||||||||||||||||||||||||
Public Member Functions inherited from ChangesListFilterGroup | ||||||||||||||||||||||||||||
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 () | ||||||||||||||||||||||||||||
getName () | ||||||||||||||||||||||||||||
getPriority () | ||||||||||||||||||||||||||||
getTitle () | ||||||||||||||||||||||||||||
getType () | ||||||||||||||||||||||||||||
setUnidirectionalConflict ( $other, $globalDescription, $contextDescription) | ||||||||||||||||||||||||||||
Marks that the given ChangesListFilterGroup or ChangesListFilter conflicts with this object. | ||||||||||||||||||||||||||||
Public Attributes | |
const | ALL = 'all' |
Signifies that all options in the group are selected. | |
const | NONE = '' |
Signifies that no options in the group are selected, meaning the group has no effect. | |
const | SEPARATOR = ';' |
Delimiter. | |
const | TYPE = 'string_options' |
Type marker, used by JavaScript. | |
Protected Member Functions | ||||
createFilter (array $filterDefinition) | ||||
Creates a filter of the appropriate type for this group, from the definition.
| ||||
Protected Attributes | |
string | $defaultValue |
Defaul parameter value. | |
callable | $queryCallable |
Callable used to do the actual query modification; see constructor. | |
Protected Attributes inherited from ChangesListFilterGroup | |
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 Member Functions | |
isActive ( $isStructuredUI) | |
Check if this filter group is currently active. | |
Represents a filter group with multiple string options.
They are passed to the server as a single form parameter separated by a delimiter. The parameter name is the group name. E.g. groupname=opt1;opt2 .
If all options are selected they are replaced by the term "all".
There is also a single DB query modification for the whole group.
Definition at line 37 of file ChangesListStringOptionsFilterGroup.php.
ChangesListStringOptionsFilterGroup::__construct | ( | array | $groupDefinition | ) |
Create a new filter group with the specified configuration.
array | $groupDefinition | Configuration of group
|
Reimplemented from ChangesListFilterGroup.
Definition at line 111 of file ChangesListStringOptionsFilterGroup.php.
References setDefault(), and TYPE.
ChangesListStringOptionsFilterGroup::addOptions | ( | FormOptions | $opts, |
$allowDefaults, | |||
$isStructuredFiltersEnabled | |||
) |
All the options represented by this filter group to $opts.
FormOptions | $opts | |
bool | $allowDefaults | |
bool | $isStructuredFiltersEnabled |
Reimplemented from ChangesListFilterGroup.
Definition at line 232 of file ChangesListStringOptionsFilterGroup.php.
References FormOptions\add(), getDefault(), and ChangesListFilterGroup\getName().
|
protected |
Creates a filter of the appropriate type for this group, from the definition.
array | $filterDefinition | Filter definition |
Reimplemented from ChangesListFilterGroup.
Definition at line 150 of file ChangesListStringOptionsFilterGroup.php.
ChangesListStringOptionsFilterGroup::getDefault | ( | ) |
Gets default of filter group.
Definition at line 143 of file ChangesListStringOptionsFilterGroup.php.
References $defaultValue.
Referenced by addOptions(), and getJsData().
ChangesListStringOptionsFilterGroup::getJsData | ( | ) |
Gets the JS data in the format required by the front-end of the structured UI.
Reimplemented from ChangesListFilterGroup.
Definition at line 220 of file ChangesListStringOptionsFilterGroup.php.
References getDefault(), and SEPARATOR.
|
private |
Check if this filter group is currently active.
bool | $isStructuredUI | Is structured filters UI current enabled |
Definition at line 242 of file ChangesListStringOptionsFilterGroup.php.
Referenced by modifyQuery().
ChangesListStringOptionsFilterGroup::modifyQuery | ( | IDatabase | $dbr, |
ChangesListSpecialPage | $specialPage, | ||
& | $tables, | ||
& | $fields, | ||
& | $conds, | ||
& | $query_options, | ||
& | $join_conds, | ||
FormOptions | $opts, | ||
$isStructuredFiltersEnabled | |||
) |
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 from ChangesListFilterGroup.
Definition at line 167 of file ChangesListStringOptionsFilterGroup.php.
References $dbr, $queryCallable, SpecialPage\getContext(), ChangesListFilterGroup\getName(), and isActive().
ChangesListStringOptionsFilterGroup::registerFilter | ( | ChangesListStringOptionsFilter | $filter | ) |
Registers a filter in this group.
ChangesListStringOptionsFilter | $filter | PhanParamSignaturePHPDocMismatchHasParamType,PhanParamSignatureMismatch |
Definition at line 160 of file ChangesListStringOptionsFilterGroup.php.
References ChangesListFilter\getName().
ChangesListStringOptionsFilterGroup::setDefault | ( | $defaultValue | ) |
Sets default of filter group.
string | $defaultValue |
Definition at line 134 of file ChangesListStringOptionsFilterGroup.php.
References $defaultValue.
Referenced by __construct().
|
protected |
Defaul parameter value.
Definition at line 66 of file ChangesListStringOptionsFilterGroup.php.
Referenced by getDefault(), and setDefault().
|
protected |
Callable used to do the actual query modification; see constructor.
Definition at line 73 of file ChangesListStringOptionsFilterGroup.php.
Referenced by modifyQuery().
const ChangesListStringOptionsFilterGroup::ALL = 'all' |
Signifies that all options in the group are selected.
Definition at line 51 of file ChangesListStringOptionsFilterGroup.php.
Referenced by ChangesListStringOptionsFilter\isSelected().
const ChangesListStringOptionsFilterGroup::NONE = '' |
Signifies that no options in the group are selected, meaning the group has no effect.
For full-coverage groups, this is the same as ALL if all filters are allowed. For others, it is not.
Definition at line 59 of file ChangesListStringOptionsFilterGroup.php.
Referenced by ChangesListSpecialPage\__construct(), SpecialRecentChanges\__construct(), and SpecialWatchlist\registerFilters().
const ChangesListStringOptionsFilterGroup::SEPARATOR = ';' |
Delimiter.
Definition at line 46 of file ChangesListStringOptionsFilterGroup.php.
Referenced by getJsData(), ChangesListStringOptionsFilter\isSelected(), and ChangesListSpecialPage\replaceOldOptions().
const ChangesListStringOptionsFilterGroup::TYPE = 'string_options' |
Type marker, used by JavaScript.
Definition at line 41 of file ChangesListStringOptionsFilterGroup.php.
Referenced by __construct().