You are here

webform.export.inc in Webform 7.4

Same filename and directory in other branches
  1. 6.3 includes/webform.export.inc
  2. 7.3 includes/webform.export.inc

Provides several different handlers for exporting webform results.

File

includes/webform.export.inc
View source
<?php

/**
 * @file
 * Provides several different handlers for exporting webform results.
 */

/**
 * Implements hook_webform_exporters().
 */
function webform_webform_exporters() {
  $exporters = array(
    'delimited' => array(
      'title' => t('Delimited text'),
      'description' => t('A plain text file delimited by commas, tabs, or other characters.'),
      'handler' => 'webform_exporter_delimited',
      'file' => drupal_get_path('module', 'webform') . '/includes/exporters/webform_exporter_delimited.inc',
      'weight' => 10,
    ),
    'excel' => array(
      'title' => t('Microsoft Excel'),
      'description' => t('A file readable by Microsoft Excel.'),
      'handler' => 'webform_exporter_excel_xlsx',
      'file' => drupal_get_path('module', 'webform') . '/includes/exporters/webform_exporter_excel_xlsx.inc',
      'weight' => -1,
      // Tells the options to use consistent dates instead of user-defined
      // formats.
      'options' => array(
        'iso8601_time' => TRUE,
        'iso8601_date' => TRUE,
      ),
    ),
    'excel_legacy' => array(
      'title' => t('Microsoft Excel (older versions)'),
      'description' => t('A file readable by older versions of Microsoft Excel.'),
      'handler' => 'webform_exporter_excel_delimited',
      'file' => drupal_get_path('module', 'webform') . '/includes/exporters/webform_exporter_excel_delimited.inc',
      'weight' => 0,
    ),
  );

  // The new Excel exporter is only available if ZipArchive is available.
  if (!class_exists('ZipArchive')) {
    drupal_set_message(t('@format downloads are not available because this install of PHP lacks Zip archive support.', array(
      '@format' => $exporters['excel']['title'],
    )), 'warning');
    unset($exporters['excel']);
  }

  // By default the legacy Excel exporter is disabled.
  if (!webform_variable_get('webform_excel_legacy_exporter')) {
    unset($exporters['excel_legacy']);
  }
  return $exporters;
}

/**
 * Return a list of exporters suitable for display in a select list.
 */
function webform_export_list() {
  $exporters = webform_export_fetch_definition();
  $list = array();
  foreach ($exporters as $name => $exporter) {
    $list[$name] = $exporter['title'];
  }
  return $list;
}

/**
 * Returns a Webform exporter definition.
 */
function webform_export_fetch_definition($format = NULL) {
  static $cache;
  if (!isset($cache)) {
    $cache = module_invoke_all('webform_exporters');
    drupal_alter('webform_exporters', $cache);
    foreach ($cache as $key => $exporter) {
      $cache[$key] += array(
        'weight' => 0,
      );

      // Used in sorting.
      $cache[$key]['name'] = $key;
    }
    uasort($cache, '_webform_components_sort');
  }
  if (isset($format)) {
    if (isset($cache[$format])) {
      return $cache[$format];
    }
  }
  else {
    return $cache;
  }
}

/**
 * Instantiates a new Webform handler based on the format.
 */
function webform_export_create_handler($format, $options) {
  $definition = webform_export_fetch_definition($format);
  if (isset($definition['file'])) {
    include_once $definition['file'];
  }
  if (isset($definition)) {
    $handler = new $definition['handler']($options);
  }
  else {

    // @todo Create a default broken exporter.
    $handler = new webform_exporter_broken($options);
  }
  return $handler;
}

Functions

Namesort descending Description
webform_export_create_handler Instantiates a new Webform handler based on the format.
webform_export_fetch_definition Returns a Webform exporter definition.
webform_export_list Return a list of exporters suitable for display in a select list.
webform_webform_exporters Implements hook_webform_exporters().