class views_pdf_plugin_style_table in Views PDF 7.2
Same name and namespace in other branches
- 6 views_pdf_plugin_style_table.inc \views_pdf_plugin_style_table
- 7.3 views_pdf_plugin_style_table.inc \views_pdf_plugin_style_table
- 7 views_pdf_plugin_style_table.inc \views_pdf_plugin_style_table
Style plugin to render each item as a row in a table.
Hierarchy
- class \views_object
- class \views_plugin
- class \views_plugin_style
- class \views_pdf_plugin_style_table
- class \views_plugin_style
- class \views_plugin
Expanded class hierarchy of views_pdf_plugin_style_table
2 string references to 'views_pdf_plugin_style_table'
- views_pdf_plugin_style_table::options_form in plugins/
views_pdf_plugin_style_table.inc - Options form
- views_pdf_views_plugins in ./
views_pdf.views.inc - Implements hook_views_plugins().
File
- plugins/
views_pdf_plugin_style_table.inc, line 14 - Table PDF style plugin
View source
class views_pdf_plugin_style_table extends views_plugin_style {
/**
* Render the style
*/
function render() {
$output = '';
$this->view->numberOfRecords = count($this->view->result);
$this->view->pdf
->drawTable($this->view, $this->options);
return $output;
}
/**
* Option definitions
*/
function option_definition() {
$options = parent::option_definition();
$options['info'] = array(
'default' => array(),
);
$options['position'] = array(
'default' => array(),
);
return $options;
}
/**
* Options form
*/
function options_form(&$form, &$form_state) {
parent::options_form($form, $form_state);
$handlers = $this->display->handler
->get_handlers('field');
if (empty($handlers)) {
$form['error_markup'] = array(
'#markup' => '<div class="error messages">' . t('You need at least one field before you can configure your table settings') . '</div>',
);
return;
}
$attached = array(
'css' => array(
drupal_get_path('module', 'views_pdf') . '/theme/admin.css',
),
);
$form['#theme'] = 'views_pdf_plugin_style_table';
$form['#attached'] = $attached;
$columns = $this->display->handler
->get_field_labels();
$fields = $this->display->handler
->get_option('fields');
$fonts = array_merge(array(
'default' => t('-- Default --'),
), views_pdf_get_font_list());
$font_styles = array(
'b' => t('Bold'),
'i' => t('Italic'),
'u' => t('Underline'),
'd' => t('Line through'),
'o' => t('Overline'),
);
$align = array(
'L' => t('Left'),
'C' => t('Center'),
'R' => t('Right'),
'J' => t('Justify'),
);
$hyphenate = array(
'none' => t('None'),
'auto' => t('Detect automatically'),
);
$hyphenate = array_merge($hyphenate, views_pdf_get_hyphenations());
foreach ($columns as $field => $column) {
if ($fields[$field]['exclude'] == 1) {
continue;
}
$safe = str_replace(array(
'][',
'_',
' ',
), '-', $field);
// the $id of the column for dependency checking.
$id = 'edit-style-options-columns-' . $safe;
// markup for the field name
$form['info'][$field]['name'] = array(
'#markup' => $column,
);
$form['info'][$field]['header_style']['text'] = array(
'#type' => 'fieldset',
'#title' => t('Text Settings'),
'#collapsed' => FALSE,
'#collapsible' => TRUE,
);
$form['info'][$field]['header_style']['text']['font_size'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Font Size'),
'#default_value' => isset($this->options['info'][$field]['header_style']['text']['font_size']) ? $this->options['info'][$field]['header_style']['text']['font_size'] : '',
);
$form['info'][$field]['header_style']['text']['font_family'] = array(
'#type' => 'select',
'#title' => t('Font Family'),
'#required' => TRUE,
'#options' => $fonts,
'#size' => 5,
'#default_value' => !empty($this->options['info'][$field]['header_style']['text']['font_family']) ? $this->options['info'][$field]['header_style']['text']['font_family'] : 'default',
);
$form['info'][$field]['header_style']['text']['font_style'] = array(
'#type' => 'checkboxes',
'#title' => t('Font Style'),
'#options' => $font_styles,
'#size' => 10,
'#default_value' => $this->options['info'][$field]['header_style']['text']['font_style'] == NULL ? $this->display->handler
->get_option('default_font_style') : $this->options['info'][$field]['header_style']['text']['font_style'],
);
$form['info'][$field]['header_style']['text']['align'] = array(
'#type' => 'radios',
'#title' => t('Alignment'),
'#options' => $align,
'#default_value' => $this->options['info'][$field]['header_style']['text']['align'] == NULL ? $this->display->handler
->get_option('default_text_align') : $this->options['info'][$field]['header_style']['text']['align'],
);
$form['info'][$field]['header_style']['text']['hyphenate'] = array(
'#type' => 'select',
'#title' => t('Text Hyphenation'),
'#options' => $hyphenate,
'#description' => t('upload patterns from <a href="@url">ctan.org</a> to <br />sites/libraries/tcpdf/hyphenate_patterns', array(
'@url' => 'http://www.ctan.org/tex-archive/language/hyph-utf8/tex/generic/hyph-utf8/patterns/tex',
)),
'#default_value' => $this->options['info'][$field]['header_style']['text']['hyphenate'] == NULL ? $this->display->handler
->get_option('default_text_hyphenate') : $this->options['info'][$field]['header_style']['text']['hyphenate'],
);
$form['info'][$field]['header_style']['text']['color'] = array(
'#type' => 'textfield',
'#title' => t('Text Color'),
'#description' => t('Enter Any format: <br />000000 (HexRGB) - 000,000,000 (RGB) - 000,000,000,000 (CMYK)'),
'#size' => 10,
'#default_value' => $this->options['info'][$field]['header_style']['text']['color'] == NULL ? $this->display->handler
->get_option('default_text_color') : $this->options['info'][$field]['header_style']['text']['color'],
);
$form['info'][$field]['header_style']['render'] = array(
'#type' => 'fieldset',
'#title' => t('Render Settings'),
'#collapsed' => FALSE,
'#collapsible' => TRUE,
);
$form['info'][$field]['header_style']['render']['is_html'] = array(
'#type' => 'checkbox',
'#title' => t('Render As HTML'),
'#default_value' => isset($this->options['info'][$field]['header_style']['render']['is_html']) ? $this->options['info'][$field]['header_style']['render']['is_html'] : 1,
);
$form['info'][$field]['header_style']['render']['eval_before'] = array(
'#type' => 'textarea',
'#title' => t('PHP Code Before Output'),
'#default_value' => isset($this->options['info'][$field]['header_style']['render']['eval_before']) ? $this->options['info'][$field]['header_style']['render']['eval_before'] : '',
);
$form['info'][$field]['header_style']['render']['eval_after'] = array(
'#type' => 'textarea',
'#title' => t('PHP Code After Output'),
'#default_value' => isset($this->options['info'][$field]['header_style']['render']['eval_after']) ? $this->options['info'][$field]['header_style']['render']['eval_after'] : '',
);
$form['info'][$field]['body_style']['text'] = array(
'#type' => 'fieldset',
'#title' => t('Text Settings'),
'#collapsed' => FALSE,
'#collapsible' => TRUE,
);
$form['info'][$field]['body_style']['text']['font_size'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Font Size'),
'#default_value' => isset($this->options['info'][$field]['body_style']['text']['font_size']) ? $this->options['info'][$field]['body_style']['text']['font_size'] : '',
);
$form['info'][$field]['body_style']['text']['font_family'] = array(
'#type' => 'select',
'#title' => t('Font Family'),
'#required' => TRUE,
'#options' => $fonts,
'#size' => 5,
'#default_value' => !empty($this->options['info'][$field]['body_style']['text']['font_family']) ? $this->options['info'][$field]['body_style']['text']['font_family'] : 'default',
);
$form['info'][$field]['body_style']['text']['font_style'] = array(
'#type' => 'checkboxes',
'#title' => t('Font Style'),
'#options' => $font_styles,
'#size' => 10,
'#default_value' => $this->options['info'][$field]['body_style']['text']['font_style'] == NULL ? $this->display->handler
->get_option('default_font_style') : $this->options['info'][$field]['body_style']['text']['font_style'],
);
$form['info'][$field]['body_style']['text']['align'] = array(
'#type' => 'radios',
'#title' => t('Alignment'),
'#options' => $align,
'#default_value' => $this->options['info'][$field]['body_style']['text']['align'] == NULL ? $this->display->handler
->get_option('default_text_align') : $this->options['info'][$field]['body_style']['text']['align'],
);
$form['info'][$field]['body_style']['text']['hyphenate'] = array(
'#type' => 'select',
'#title' => t('Text Hyphenation'),
'#options' => $hyphenate,
'#description' => t('upload patterns from <a href="@url">ctan.org</a> to <br />sites/libraries/tcpdf/hyphenate_patterns', array(
'@url' => 'http://www.ctan.org/tex-archive/language/hyph-utf8/tex/generic/hyph-utf8/patterns/tex',
)),
'#default_value' => $this->options['info'][$field]['body_style']['text']['hyphenate'] == NULL ? $this->display->handler
->get_option('default_text_hyphenate') : $this->options['info'][$field]['body_style']['text']['hyphenate'],
);
$form['info'][$field]['body_style']['text']['color'] = array(
'#type' => 'textfield',
'#title' => t('Text Color'),
'#description' => t('Enter Any format: <br />000000 (HexRGB) - 000,000,000 (RGB) - 000,000,000,000 (CMYK)'),
'#size' => 20,
'#default_value' => $this->options['info'][$field]['body_style']['text']['color'] == NULL ? $this->display->handler
->get_option('default_text_color') : $this->options['info'][$field]['body_style']['text']['color'],
);
$form['info'][$field]['body_style']['render'] = array(
'#type' => 'fieldset',
'#title' => t('Render Settings'),
'#collapsed' => FALSE,
'#collapsible' => TRUE,
);
$form['info'][$field]['body_style']['render']['is_html'] = array(
'#type' => 'checkbox',
'#title' => t('Render As HTML'),
'#default_value' => isset($this->options['info'][$field]['body_style']['render']['is_html']) ? $this->options['info'][$field]['body_style']['render']['is_html'] : 1,
);
$form['info'][$field]['body_style']['render']['eval_before'] = array(
'#type' => 'textarea',
'#title' => t('PHP Code Before Output'),
'#default_value' => isset($this->options['info'][$field]['body_style']['render']['eval_before']) ? $this->options['info'][$field]['body_style']['render']['eval_before'] : '',
);
$form['info'][$field]['body_style']['render']['eval_after'] = array(
'#type' => 'textarea',
'#title' => t('PHP Code After Output'),
'#default_value' => isset($this->options['info'][$field]['body_style']['render']['eval_after']) ? $this->options['info'][$field]['body_style']['render']['eval_after'] : '',
);
$form['info'][$field]['position']['width'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Width'),
'#default_value' => isset($this->options['info'][$field]['position']['width']) ? $this->options['info'][$field]['position']['width'] : '',
);
}
// Some general options
$form['position'] = array(
'#type' => 'fieldset',
'#title' => t('Table Position'),
'#collapsed' => FALSE,
'#collapsible' => TRUE,
);
$form['position']['last_writing_position'] = array(
'#type' => 'checkbox',
'#title' => t('Relative to last writing position'),
'#default_value' => isset($this->options['position']['last_writing_position']) ? $this->options['position']['last_writing_position'] : 1,
);
$form['position']['x'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('X'),
'#description' => t('X Coordinate (relative to page with margins)'),
'#default_value' => isset($this->options['position']['x']) ? $this->options['position']['x'] : '',
);
$form['position']['y'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Y'),
'#description' => t('Y Coordinate (relative to page with margins)'),
'#default_value' => isset($this->options['position']['y']) ? $this->options['position']['y'] : '',
);
$form['position']['width'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Table Width'),
'#default_value' => isset($this->options['position']['width']) ? $this->options['position']['width'] : '',
);
$form['position']['row_height'] = array(
'#type' => 'textfield',
'#size' => 10,
'#title' => t('Row Height'),
'#default_value' => isset($this->options['position']['row_height']) ? $this->options['position']['row_height'] : '',
);
parent::options_form($form, $form_state);
}
/**
* Options form storage
*/
function options_submit(&$form, &$form_state) {
$default_font_style = $this->display->handler
->get_option('default_font_style');
foreach ($form_state['values']['style_options']['info'] as $id => $field) {
// Reset to default, if the elements are equal to the default settings
if (count(array_diff($default_font_style, $field['header_style']['text']['font_style'])) == 0 && count(array_diff($field['header_style']['text']['font_style'], $default_font_style)) == 0) {
$form_state['values']['style_options']['info'][$id]['header_style']['text']['font_style'] = NULL;
}
if ($field['header_style']['text']['align'] == $this->display->handler
->get_option('default_text_align')) {
$form_state['values']['style_options']['info'][$id]['header_style']['text']['align'] = NULL;
}
if ($field['header_style']['text']['hyphenate'] == $this->display->handler
->get_option('default_text_hyphenate')) {
$form_state['values']['style_options']['info'][$id]['header_style']['text']['hyphenate'] = NULL;
}
// Reset to default, if the elements are equal to the default settings
if (count(array_diff($default_font_style, $field['body_style']['text']['font_style'])) == 0 && count(array_diff($field['body_style']['text']['font_style'], $default_font_style)) == 0) {
$form_state['values']['style_options']['info'][$id]['body_style']['text']['font_style'] = NULL;
}
if ($field['body_style']['text']['align'] == $this->display->handler
->get_option('default_text_align')) {
$form_state['values']['style_options']['info'][$id]['body_style']['text']['align'] = NULL;
}
if ($field['body_style']['text']['hyphenate'] == $this->display->handler
->get_option('default_text_hyphenate')) {
$form_state['values']['style_options']['info'][$id]['body_style']['text']['hyphenate'] = NULL;
}
}
}
/**
* Attach this view to another display as a feed.
*
* Provide basic functionality for all export style views like attaching a
* feed image link.
*/
function attach_to($display_id, $path, $title) {
$display = $this->view->display[$display_id]->handler;
$url_options = array();
$input = $this->view
->get_exposed_input();
if ($input) {
$url_options['query'] = $input;
}
if (empty($this->view->feed_icon)) {
$this->view->feed_icon = '';
}
$this->view->feed_icon .= theme('views_pdf_icon', array(
'path' => $this->view
->get_url(NULL, $path),
'title' => $title,
'options' => $url_options,
));
}
}
Members
Name![]() |
Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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 | 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 | ||
views_pdf_plugin_style_table:: |
function | Attach this view to another display as a feed. | ||
views_pdf_plugin_style_table:: |
function |
Options form Overrides views_plugin_style:: |
||
views_pdf_plugin_style_table:: |
function |
Options form storage Overrides views_plugin:: |
||
views_pdf_plugin_style_table:: |
function |
Option definitions Overrides views_plugin_style:: |
||
views_pdf_plugin_style_table:: |
function |
Render the style Overrides views_plugin_style:: |
||
views_plugin:: |
public | property | The current used views display. | |
views_plugin:: |
public | property | The plugin name of this plugin, for example table or full. | |
views_plugin:: |
public | property | The plugin type of this plugin, for example style or query. | |
views_plugin:: |
public | property |
The top object of a view. Overrides views_object:: |
1 |
views_plugin:: |
public | function | Provide a list of additional theme functions for the theme info page. | |
views_plugin:: |
public | function | Return the human readable name of the display. | |
views_plugin:: |
public | function | Returns the summary of the settings in the display. | 8 |
views_plugin:: |
public | function | Provide a full list of possible theme templates used by this style. | |
views_plugin_style:: |
public | property | The row plugin, if it's initialized and the style itself supports it. | |
views_plugin_style:: |
public | property | Store all available tokens row rows. | |
views_plugin_style:: |
public | function | Called by the view builder to see if this style handler wants to interfere with the sorts. If so it should build; if it returns any non-TRUE value, normal sorting will NOT be added to the query. | 1 |
views_plugin_style:: |
public | function | Called by the view builder to let the style build a second set of sorts that will come after any other sorts in the view. | 1 |
views_plugin_style:: |
public | function |
Destructor. Overrides views_object:: |
|
views_plugin_style:: |
public | function | Should the output of the style plugin be rendered even if it's empty. | 1 |
views_plugin_style:: |
public | function | Get a rendered field. | |
views_plugin_style:: |
public | function | Get the raw field value. | |
views_plugin_style:: |
public | function | Return the token replaced row class for the specified row. | |
views_plugin_style:: |
public | function | Initialize a style plugin. | |
views_plugin_style:: |
public | function |
Validate the options form. Overrides views_plugin:: |
|
views_plugin_style:: |
public | function | Allow the style to do stuff before each row is rendered. | |
views_plugin_style:: |
public | function |
Add anything to the query that we might need to. Overrides views_plugin:: |
2 |
views_plugin_style:: |
public | function | Render all of the fields for a given style and store them on the object. | |
views_plugin_style:: |
public | function | Group records as needed for rendering. | |
views_plugin_style:: |
public | function | Render the grouping sets. | |
views_plugin_style:: |
public | function | Take a value and apply token replacement logic to it. | |
views_plugin_style:: |
public | function | Return TRUE if this style also uses fields. | |
views_plugin_style:: |
public | function | Return TRUE if this style also uses a row plugin. | |
views_plugin_style:: |
public | function | Return TRUE if this style also uses a row plugin. | |
views_plugin_style:: |
public | function | Return TRUE if this style uses tokens. | |
views_plugin_style:: |
public | function |
Validate that the plugin is correct and can be saved. Overrides views_plugin:: |