class media_browser_plus_views_handler_area_navigation in Media Browser Plus 7.3
MBP navigation handler.
@todo Review / refactor to meet the proper views coding style.
Hierarchy
- class \views_object
- class \views_handler
Expanded class hierarchy of media_browser_plus_views_handler_area_navigation
2 string references to 'media_browser_plus_views_handler_area_navigation'
- media_browser_plus_views_data_alter in views/
media_browser_plus.views.inc - Implements hook_views_data_alter().
- media_browser_plus_views_management in views/
media_browser_plus.views_default.inc - View to display the folders in the library.
File
- views/
media_browser_plus_views_handler_area_navigation.inc, line 15 - Definition of media_browser_plus_views_handler_area_navigation.
View source
class media_browser_plus_views_handler_area_navigation extends views_handler_area_view {
/**
* Initialize the handler.
*
* This is kind of hackish, how is this done properly?
*
* @todo Review / refactor to meet the proper views coding style.
*/
public function init(&$view, &$options) {
parent::init($view, $options);
// @todo Review / refactor to meet the proper views coding style.
$this->table = 'field_data_field_folder';
}
/**
* Define options.
*
* @todo Review / refactor to meet the proper views coding style.
*/
public function option_definition() {
$options = parent::option_definition();
$this->definition['field'] = 'field_folder_tid';
$options['table'] = array(
'default' => 'field_data_field_folder',
);
$options['field'] = array(
'default' => 'field_folder_tid',
);
return $options;
}
/**
* Remove label from options form.
*/
public function options_form(&$form, &$form_state) {
$options = parent::options_form($form, $form_state);
unset($form['label']);
return $options;
}
/**
* Add folder filter to the query.
*/
public function query() {
$root_folder = media_browser_plus_get_media_root_folder();
if (!empty($this->view->exposed_data['mbp_current_folder'])) {
$this->value = (int) $this->view->exposed_data['mbp_current_folder'];
user_cookie_save(array(
'mbp.current_folder' => $this->value,
));
}
elseif (!empty($_COOKIE['Drupal_visitor_mbp_current_folder']) && (int) $_COOKIE['Drupal_visitor_mbp_current_folder'] > 0) {
$this->value = (int) $_COOKIE['Drupal_visitor_mbp_current_folder'];
}
else {
$this->value = $root_folder->tid;
}
$this
->ensure_my_table();
$where_group = 1;
// Ensure folders is always an array.
$folders = array(
$this->value,
);
// If including subfolders is enabled fetch all child terms of the current
// folder.
if (isset($this->view->exposed_data['mbp_current_folder_include_subfolders']) && $this->view->exposed_data['mbp_current_folder_include_subfolders'] !== 0) {
$taxonomy_tree = taxonomy_get_tree(taxonomy_vocabulary_machine_name_load('media_folders')->vid, $this->value);
if (is_array($taxonomy_tree)) {
foreach ($taxonomy_tree as $term) {
$folders[] = (int) $term->tid;
}
}
}
// If this is the root folder also show files without a folder.
if ($this->value == $root_folder->tid) {
// Add new where group to use OR condition.
$where_group = $this->query
->set_where_group('OR');
$this->query
->add_where($where_group, "{$this->table_alias}.{$this->real_field}", $this->value, 'IS NULL');
}
$this->query
->add_where($where_group, "{$this->table_alias}.{$this->real_field}", $folders, 'IN');
}
/**
* Always exposed.
*/
public function can_expose() {
return TRUE;
}
/**
* Always expose.
*/
public function is_exposed() {
return TRUE;
}
/**
* Doesn't output anything because it's hijacked by the MBP.
*
* @see template_preprocess_media_browser_plus_views_view_media_browser()
* @see media_browser_plus_views_handler_area_navigation::render_custom()
*/
public function render($empty = FALSE) {
}
/**
* Called to embed the view into the sidebar of the media browser plus style.
*
* @see template_preprocess_media_browser_plus_views_view_media_browser()
* @see media_browser_plus_views_handler_area_navigation::render_custom()
*/
public function render_custom($empty = FALSE) {
return parent::render($empty);
}
/**
* Form element to track the media basket.
*/
public function exposed_form(&$form, &$form_state) {
$root_folder = media_browser_plus_get_media_root_folder();
$folders = taxonomy_get_tree($root_folder->vid, $root_folder->tid);
$folder_options = array(
$root_folder->tid => $root_folder->name,
);
foreach ($folders as $folder) {
$folder_options[$folder->tid] = str_repeat('-', $folder->depth + 1) . $folder->name;
}
$default_folder = $root_folder->tid;
if (!empty($_COOKIE['Drupal_visitor_mbp_current_folder']) && (int) $_COOKIE['Drupal_visitor_mbp_current_folder'] > 0) {
$default_folder = (int) $_COOKIE['Drupal_visitor_mbp_current_folder'];
}
$form['mbp_current_folder'] = array(
'#type' => 'select',
'#title' => t('Folder'),
'#default_value' => $default_folder,
'#options' => $folder_options,
'#attributes' => array(
'class' => array(
'mbp-selected-folder',
),
),
);
// Add a checkbox to include subfolders in the view results.
$form['mbp_current_folder_include_subfolders'] = array(
'#type' => 'checkbox',
'#title' => t('Include subfolders in results'),
'#default_value' => 0,
);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Always exposed. Overrides views_handler:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Form element to track the media basket. Overrides views_handler:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Initialize the handler. Overrides views_handler_area:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Always expose. Overrides views_handler:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Remove label from options form. Overrides views_handler_area_view:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Define options. Overrides views_handler_area_view:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Add folder filter to the query. Overrides views_handler_area:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function |
Doesn't output anything because it's hijacked by the MBP. Overrides views_handler_area_view:: |
|
media_browser_plus_views_handler_area_navigation:: |
public | function | Called to embed the view into the sidebar of the media browser plus style. | |
views_handler:: |
public | property | The type of the handler, for example filter/footer/field. | |
views_handler:: |
public | property | Where the $query object will reside:. | 1 |
views_handler:: |
public | property | The actual field in the database table, maybe different on other kind of query plugins/special handlers. | |
views_handler:: |
public | property | The relationship used for this field. | |
views_handler:: |
public | property | The alias of the table of this handler which is used in the query. | |
views_handler:: |
public | property |
The top object of a view. Overrides views_object:: |
|
views_handler:: |
public | function | Take input from exposed handlers and assign to this handler, if necessary. | 1 |
views_handler:: |
public | function | Check whether current user has access to this handler. | 10 |
views_handler:: |
public | function | Determine if the handler is considered 'broken'. | 6 |
views_handler:: |
public | function | Transform a string by a certain method. | |
views_handler:: |
public | function | Ensure the main table for this handler is in the query. This is used a lot. | 8 |
views_handler:: |
public | function | Get information about the exposed form for the form renderer. | 1 |
views_handler:: |
public | function | Submit the exposed handler form. | |
views_handler:: |
public | function | Validate the exposed handler form. | 4 |
views_handler:: |
public | function | Form for exposed handler options. | 2 |
views_handler:: |
public | function | Set new exposed option defaults when exposed setting is flipped on. | 2 |
views_handler:: |
public | function | Perform any necessary changes to the form exposes prior to storage. There is no need for this function to actually store the data. | |
views_handler:: |
public | function | Validate the options form. | 1 |
views_handler:: |
public | function | Provide defaults for the handler. | |
views_handler:: |
public | function | Provide a form for setting options. | 1 |
views_handler:: |
public | function | Perform any necessary changes to the form values prior to storage. There is no need for this function to actually store the data. | |
views_handler:: |
public | function | Validate the options form. | |
views_handler:: |
public | function | Shortcut to get a handler's raw field value. | |
views_handler:: |
public | function | Get the join object that should be used for this handler. | |
views_handler:: |
public | function | Provide a form for aggregation settings. | 1 |
views_handler:: |
public | function | Perform any necessary changes to the form values prior to storage. There is no need for this function to actually store the data. | 1 |
views_handler:: |
public | function | If a handler has 'extra options' it will get a little settings widget and another form called extra_options. | 1 |
views_handler:: |
public | function | Returns TRUE if the exposed filter works like a grouped filter. | 1 |
views_handler:: |
public | function | Define if the exposed input has to be submitted multiple times. This is TRUE when exposed filters grouped are using checkboxes as widgets. | 1 |
views_handler:: |
public | function | Determine if the argument needs a style plugin. | 1 |
views_handler:: |
public | function | Perform any necessary changes to the form values prior to storage. There is no need for this function to actually store the data. | 5 |
views_handler:: |
public | function | Validate the options form. | 4 |
views_handler:: |
public | function | Provides a unique placeholders for handlers. | |
views_handler:: |
public | function | Run after the view is executed, before the result is cached. | 1 |
views_handler:: |
public | function | Run before the view is built. | 1 |
views_handler:: |
public | function | Sanitize the value for output. | |
views_handler:: |
public | function | Called just prior to query(), this lets a handler set up any relationship it needs. | |
views_handler:: |
public | function | Shortcut to display the expose/hide button. | 2 |
views_handler:: |
public | function | Shortcut to display the exposed options form. | |
views_handler:: |
public | function | If set to remember exposed input in the session, store it there. | 1 |
views_handler:: |
public | function | Return a string representing this handler's name in the UI. | 9 |
views_handler:: |
public | function | Validates the handler against the complete View. | 1 |
views_handler_area:: |
public | function |
Provide extra data to the administration form. Overrides views_handler:: |
|
views_handler_area:: |
public | function | ||
views_handler_area:: |
public | function |
Area handlers shouldn't have groupby. Overrides views_handler:: |
|
views_handler_area_view:: |
protected | function | Loads the used view for rendering. | |
views_object:: |
public | property | Handler's definition. | |
views_object:: |
public | property | Except for displays, options for the object will be held here. | 1 |
views_object:: |
function | Collect this handler's option definition and alter them, ready for use. | ||
views_object:: |
public | function | Views handlers use a special construct function. | 4 |
views_object:: |
public | function | Destructor. | 2 |
views_object:: |
public | function | 1 | |
views_object:: |
public | function | ||
views_object:: |
public | function | Always exports the option, regardless of the default value. | |
views_object:: |
public | function | Set default options on this object. | 1 |
views_object:: |
public | function | Set default options. | |
views_object:: |
public | function | Let the handler know what its full definition is. | |
views_object:: |
public | function | Unpack options over our existing defaults, drilling down into arrays so that defaults don't get totally blown away. | |
views_object:: |
public | function | Unpack a single option definition. | |
views_object:: |
public | function | Unpacks each handler to store translatable texts. | |
views_object:: |
public | function |