A criterion that matches Content based on the relations in relation field.
This includes Relation and RelationList field types in standard installation, but also any other field type storing Relation::FIELD type relation.
Supported operators:
- IN: will match if Content relates to one or more of the given ids through given relation field
- CONTAINS: will match if Content relates to all of the given ids through given relation field
Properties¶
$operator¶
The operator used by the Criterion.
|
|
$target¶
The target used by the criteria (field, metadata...).
|
|
$value¶
The value(s) matched by the criteria.
|
|
$valueData¶
Additional value data, required by some criterions, MapLocationDistance for instance.
|
|
Methods¶
__construct() ¶
Performs operator validation based on the Criterion specifications returned by {@see getSpecifications()}.
|
|
Parameters
Name | Type | Default value | Description |
---|---|---|---|
$target | string|null | - |
The target the Criterion applies to: metadata identifier, field identifier... |
$operator | string|null | - |
The operator the Criterion uses. If null is given, will default to Operator::IN if $value is an array, Operator::EQ if it is not. |
$value | array<string|int, scalar>|scalar | - | - |
$valueData | Value|null | null | - |
Tags
getSpecifications() ¶
Criterion description function.
|
|
Returns the combination of the Criterion's supported operator/value, as an array of Specifications objects
- Operator is one supported Operator, as an Operator::* constant
- ValueType is the type of input value this operator requires, either array or single
- SupportedTypes is an array of types the operator will accept
- ValueCountLimitation is an integer saying how many values are expected.
// IN and EQ are supported
return [
// The EQ operator expects a single value, either as an integer or a string
new Specifications(
Operator::EQ,
Specifications::FORMAT_SINGLE,
Specifications::TYPE_INTEGER | Specifications::TYPE_STRING
),
// The IN operator expects an array of values, of either integers or strings
new Specifications(
Operator::IN,
Specifications::FORMAT_ARRAY,
Specifications::TYPE_INTEGER | Specifications::TYPE_STRING
)
]
Return values
array<string|int, Specifications>