class flag_handler_relationship_content in Flag 6
Same name and namespace in other branches
- 6.2 includes/flag_handler_relationships.inc \flag_handler_relationship_content
- 7.3 includes/views/flag_handler_relationships.inc \flag_handler_relationship_content
- 7.2 includes/flag_handler_relationships.inc \flag_handler_relationship_content
Specialized relationship handler associating flags and content.
Hierarchy
- class \flag_handler_relationship_content extends \views_handler_relationship
Expanded class hierarchy of flag_handler_relationship_content
1 string reference to 'flag_handler_relationship_content'
- flag_views_data_alter in includes/
flag.views.inc - Implementation of hook_views_data_alter().
File
- includes/
flag_handler_relationships.inc, line 13 - Contains various relationship handlers.
View source
class flag_handler_relationship_content extends views_handler_relationship {
function option_definition() {
$options = parent::option_definition();
$content_type = $this->definition['flag type'];
$options['flag'] = array(
'default' => flag_views_flag_default($content_type),
);
$options['user_scope'] = array(
'default' => 'current',
);
$options['required'] = array(
'default' => 1,
);
return $options;
}
function options_form(&$form, &$form_state) {
parent::options_form($form, $form_state);
$content_type = $this->definition['flag type'];
$form['label']['#description'] .= ' ' . t('The name of the selected flag makes a good label.');
$form['flag'] = flag_views_flag_config_form('radios', $content_type, $this->options['flag']);
$form['user_scope'] = array(
'#type' => 'radios',
'#title' => t('By'),
'#options' => array(
'current' => t('Current user'),
'any' => t('Any user'),
),
'#default_value' => $this->options['user_scope'],
);
$form['required']['#title'] = t('Include only flagged content');
$form['required']['#description'] = t('If checked, only content that has this flag will be included. Leave unchecked to include all content; or, in combination with the <em>Flagged</em> filter, <a href="@unflagged-url">to limit the results to specifically unflagged content</a>.', array(
'@unflagged-url' => 'http://drupal.org/node/299335',
));
if (!$form['flag']['#options']) {
$form = array(
'error' => array(
'#value' => '<p class="error">' . t('No %type flags exist. You must first <a href="@create-url">create a %type flag</a> before being able to use this relationship type.', array(
'%type' => $content_type,
'@create-url' => url('admin/build/flags'),
)) . '</p>',
),
);
$form_state['no flags exist'] = TRUE;
}
}
function options_validate($form, &$form_state) {
if (!empty($form_state['no flags exist'])) {
form_error($form, t('You must first create a flag'));
}
}
function admin_summary() {
return $this->options['user_scope'] == 'current' ? t('by current user') : t('by any user');
}
function ui_name() {
// We put the bookmark name in the UI string to save space.
return t('!group: !title', array(
'!group' => $this->definition['group'],
'!title' => $this->options['flag'],
));
}
/**
* Called to implement a relationship in a query.
*/
function query() {
$flag = flag_get_flag($this->options['flag']);
$this->definition['extra'][] = array(
'field' => 'fid',
'value' => $flag->fid,
'numeric' => TRUE,
);
if ($this->options['user_scope'] == 'current' && !$flag->global) {
$this->definition['extra'][] = array(
'field' => 'uid',
'value' => '***CURRENT_USER***',
'numeric' => TRUE,
);
}
parent::query();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
flag_handler_relationship_content:: |
function | |||
flag_handler_relationship_content:: |
function | |||
flag_handler_relationship_content:: |
function | |||
flag_handler_relationship_content:: |
function | |||
flag_handler_relationship_content:: |
function | Called to implement a relationship in a query. | ||
flag_handler_relationship_content:: |
function |