function votingapi_views_handler_relationship::query in Voting API 7.3
Same name and namespace in other branches
- 6.2 views/votingapi_views_handler_relationship.inc \votingapi_views_handler_relationship::query()
- 7.2 views/votingapi_views_handler_relationship.inc \votingapi_views_handler_relationship::query()
Called to implement a relationship in a query.
Overrides views_handler_relationship::query
File
- views/
votingapi_views_handler_relationship.inc, line 103 - Provide views handler for votingapi joins.
Class
- votingapi_views_handler_relationship
- A custom join handler that connects arbitrary base tables to VotingAPI's data.
Code
function query() {
// Figure out what base table this relationship brings to the party.
$table_data = views_fetch_data($this->definition['base']);
$def = $this->definition;
$def['table'] = $this->definition['base'];
$def['field'] = 'entity_id';
$def['left_table'] = $this->table;
$def['left_field'] = $this->field;
if (!empty($this->options['required'])) {
$def['type'] = 'INNER';
}
if (!empty($def['join_handler']) && class_exists($def['join_handler'])) {
$join = new $def['join_handler']();
}
else {
$join = new views_join();
}
// use a short alias for this:
$alias = $def['table'] . '_' . $def['left_table'];
if (!empty($this->options['votingapi'])) {
foreach ($this->options['votingapi'] as $field => $value) {
if (!empty($value)) {
$def['extra'][] = array(
'field' => $field,
'value' => $value,
'numeric' => FALSE,
);
$alias .= '_' . str_replace(array(
' ',
'-',
'.',
), '_', $value);
}
}
}
if (!empty($this->options['current_user'])) {
$def['extra'][] = array(
'field' => 'uid',
'value' => '***CURRENT_USER***',
'numeric' => FALSE,
);
$alias .= '_curuser';
}
$join->definition = $def;
$join
->construct();
$this
->ensure_my_table();
$this->alias = $this->query
->add_relationship($alias, $join, $this->definition['base'], $this->relationship);
}