Newer
Older
<?php
/**
* @file
Tim Plunkett
committed
* Definition of Drupal\node\Plugin\views\field\Path.
Tim Plunkett
committed
namespace Drupal\node\Plugin\views\field;
use Drupal\views\Plugin\views\field\FieldPluginBase;
use Drupal\views\Plugin\views\display\DisplayPluginBase;
Daniel Wehner
committed
use Drupal\views\ViewExecutable;
use Drupal\Core\Annotation\Plugin;
/**
* Field handler to present the path to the node.
*
* @ingroup views_field_handlers
* id = "node_path",
* module = "node"
* )
*/
class Path extends FieldPluginBase {
Bram Goffings
committed
/**
* Overrides \Drupal\views\Plugin\views\field\FieldPluginBase::init().
Bram Goffings
committed
*/
public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) {
parent::init($view, $display, $options);
Bram Goffings
committed
$this->additional_fields['nid'] = 'nid';
}
protected function defineOptions() {
$options = parent::defineOptions();
$options['absolute'] = array('default' => FALSE, 'bool' => TRUE);
return $options;
}
public function buildOptionsForm(&$form, &$form_state) {
parent::buildOptionsForm($form, $form_state);
$form['absolute'] = array(
'#type' => 'checkbox',
'#title' => t('Use absolute link (begins with "http://")'),
'#default_value' => $this->options['absolute'],
'#description' => t('Enable this option to output an absolute link. Required if you want to use the path as a link destination (as in "output this field as a link" above).'),
'#fieldset' => 'alter',
);
}
public function query() {
$this->ensureMyTable();
$this->add_additional_fields();
}
function render($values) {
$nid = $this->get_value($values, 'nid');
return url("node/$nid", array('absolute' => $this->options['absolute']));
}