addthis_handler_field.inc in AddThis 6.3
A handler to provide an AddThis button for a particular node.
File
addthis_handler_field.incView source
<?php
/**
* @file
* A handler to provide an AddThis button for a particular node.
*
* @ingroup views_field_handlers
*/
class addthis_handler_field_button extends views_handler_field {
function construct() {
parent::construct();
$this->additional_fields['nid'] = 'nid';
$this->additional_fields['title'] = 'title';
}
function query() {
$this
->ensure_my_table();
$this
->add_additional_fields();
}
function option_definition() {
$options = parent::option_definition();
return $options;
}
function options_form(&$form, &$form_state) {
parent::options_form($form, $form_state);
// Alter options form defaults.
unset($form['alter']);
unset($form['empty']);
unset($form['empty_zero']);
unset($form['hide_empty']);
}
function render($values) {
$nid = $values->{$this->aliases['nid']};
$title = $values->{$this->aliases['title']};
return theme('addthis_button', NULL, array(
'url' => url('node/' . $nid, array(
'absolute' => TRUE,
)),
'title' => check_plain($title),
));
}
}
/**
* A handler to provide an AddThis toolbox for a particular node.
*
* @ingroup views_field_handlers
*/
class addthis_handler_field_toolbox extends views_handler_field {
function construct() {
parent::construct();
$this->additional_fields['nid'] = 'nid';
$this->additional_fields['title'] = 'title';
}
function query() {
$this
->ensure_my_table();
$this
->add_additional_fields();
}
function option_definition() {
$options = parent::option_definition();
return $options;
}
function options_form(&$form, &$form_state) {
parent::options_form($form, $form_state);
// Allow for custom toolbox services.
$form['services'] = array(
'#type' => 'textarea',
'#rows' => 3,
'#title' => t('Toolbox services'),
'#description' => t('A comma-separated list of AddThis service codes to use in the Toolbox field. Leave blank to use your configured defaults.'),
'#default_value' => $this->options['services'],
);
// Alter options form defaults.
unset($form['alter']);
unset($form['empty']);
unset($form['empty_zero']);
unset($form['hide_empty']);
}
function render($values) {
$nid = $values->{$this->aliases['nid']};
$title = $values->{$this->aliases['title']};
$services = !empty($this->options['services']) ? $this->options['services'] : NULL;
return theme('addthis_toolbox', $services, array(
'url' => url('node/' . $nid, array(
'absolute' => TRUE,
)),
'title' => check_plain($title),
));
}
}
Classes
Name | Description |
---|---|
addthis_handler_field_button | @file A handler to provide an AddThis button for a particular node. |
addthis_handler_field_toolbox | A handler to provide an AddThis toolbox for a particular node. |