Skip to content
forena.module 38.9 KiB
Newer Older
David Metzler's avatar
David Metzler committed
<?php

require_once 'Frx.inc';

David Metzler's avatar
David Metzler committed
 * Implementation of hook_menu.
David Metzler's avatar
David Metzler committed
function forena_menu() {
  $items = array();

  // First build menu items.
  Frx::Menu()->addMenuItems($items);
  $items['admin/structure/forena'] = array(
    'type' => MENU_NORMAL_ITEM,
    'title' => 'Forena Reports',
    'description' => 'Build reports based on data in your sites databases.',
    'page callback' => 'forena_admin_reports',
    'access arguments' => array('design any report'),
    'file' => 'forena.admin.inc',
  );

  $items['admin/structure/forena/reports'] = array(
    'type' => MENU_DEFAULT_LOCAL_TASK,
    'title' => 'Reports',
    'description' => 'Build reports based on data in your sites databases.',
    'page callback' => 'forena_admin_reports',
    'access arguments' => array('design any report'),
    'file' => 'forena.admin.inc',
  );

David Metzler's avatar
David Metzler committed
  $items['admin/config/content/forena'] = array(
David Metzler's avatar
David Metzler committed
    'page callback' => 'drupal_get_form',
David Metzler's avatar
David Metzler committed
    'page arguments' => array('forena_settings'),
    'title' => 'Forena Reports',
    'description' => 'Tell Forena where to store report files and how users should access them.',
David Metzler's avatar
David Metzler committed
    'access arguments' => array('administer forena reports'),
David Metzler's avatar
David Metzler committed
    'type' => MENU_NORMAL_ITEM,
    'file' => 'forena.admin.inc',
David Metzler's avatar
David Metzler committed

  $items['admin/config/content/forena/general'] = array(
David Metzler's avatar
David Metzler committed
    'title' => 'General',
    'type' => MENU_DEFAULT_LOCAL_TASK,
    'file' => 'forena.admin.inc',
    'weight' => -10,
David Metzler's avatar
David Metzler committed

  $items['admin/config/content/forena/data/configure'] = array(
    'title' => 'Configure data source',
    'page callback' => 'drupal_get_form',
    'page arguments' => array('forena_data_settings_edit'),
    'type' => MENU_CALLBACK,
    'file' => 'forena.admin.inc',
    'access arguments' => array('administer forena reports'),
  );

  $items['admin/config/content/forena/data/add'] = array(
    'title' => 'Add data source',
    'type' => MENU_CALLBACK,
    'page callback' => 'drupal_get_form',
    'page arguments' => array('forena_data_settings_edit'),
    'file' => 'forena.admin.inc',
    'access arguments' => array('administer forena reports'),
  );

  $items['admin/config/content/forena/data'] = array(
    'title' => 'Data',
    'page callback' => 'forena_data_settings',
    'type' => MENU_LOCAL_TASK,
    'file' => 'forena.admin.inc',
    'access arguments' => array('administer forena reports'),
  );

David Metzler's avatar
David Metzler committed
  $items['admin/config/content/forena/formats']  = array(
    'page callback' => 'drupal_get_form',
David Metzler's avatar
David Metzler committed
    'page arguments' => array('forena_doc_formats_settings'),
    'title' => 'Document Types',
    'access arguments' => array('administer forena reports'),
David Metzler's avatar
David Metzler committed
    'type' => MENU_LOCAL_TASK,
    'file' => 'forena.admin.inc',
David Metzler's avatar
David Metzler committed

  $items['reports/%'] = array(
David Metzler's avatar
David Metzler committed
    'page callback' => 'forena_report',
David Metzler's avatar
David Metzler committed
    'page arguments' => array(1),
    'title' => 'Reports',
    'access arguments' => array('access content'),
    'type' => MENU_CALLBACK,
    'file' => 'forena.common.inc',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

  $items['report_doc/%'] = array(
    'page callback' => 'forena_report',
    'page arguments' => array(1),
    'access arguments' => array('access content'),
    'type' => MENU_CALLBACK,
    'file' => 'forena.common.inc',
David Metzler's avatar
David Metzler committed
  );
  $items['reports/%/view'] = array(
David Metzler's avatar
David Metzler committed
    'title' => 'View',
    'type' => MENU_DEFAULT_LOCAL_TASK,
    'weight' => -10,
    'file' => 'forena.common.inc',
    'access arguments' => array('design any report'),
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['reports/%/edit'] = array(
     'page callback' => 'drupal_get_form',
     'page arguments' => array( 'forena_layout_form',1),
     'access arguments' => array('design any report'),
     'description' => 'Edit the layout of your report',
     'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  if (module_exists('locale')) {
    $items['reports/%/translations'] = array(
       'page callback' => 'forena_report_translations',
       'page arguments' => array(1),
       'file' => 'forena.admin.inc',
       'access arguments' => array('design any report'),
       'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
    );
  }
  $items['reports/%/edit/params'] = array(
    'page callback' => 'drupal_get_form',
    'page arguments' => array('forena_admin_params_form', 1),
    'title' => 'Parameters',
    'access arguments' => array('design any report'),
    'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
  $items['reports/%/edit/params/add'] = array(
    'page callback' => 'drupal_get_form',
    'page arguments' => array('forena_add_param_form', 1),
    'file' => 'forena.admin.inc',
    'title' => 'Parameters',
    'access arguments' => array('design any report'),
    'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $items['reports/%/edit/layout'] = array(
     'title' => 'Layout',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_layout_form',1),
David Metzler's avatar
David Metzler committed
     'access arguments' => array('design any report'),
     'description' => 'Edit the layout of your report',
     'type' => MENU_DEFAULT_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['reports/%/edit/data'] = array(
     'title' => 'Data',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_data_block_form', 1),
David Metzler's avatar
David Metzler committed
     'access arguments' => array('design any report'),
     'description' => 'Add a data block to your report',
David Metzler's avatar
David Metzler committed
     'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['reports/%/edit/data/add'] = array(
     'title' => 'Data',
     'file' => 'forena.admin.inc',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_add_data_block_form', 1),
     'access arguments' => array('design any report'),
     'description' => 'Add a data block to your report',
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  );
  $items['reports/%/edit/fields'] = array(
     'title' => 'Fields',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_fields_form',1),
David Metzler's avatar
David Metzler committed
     'access arguments' => array('design any report'),
     'description' => 'Edit the fields of your report',
David Metzler's avatar
David Metzler committed
     'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['reports/%/edit/format'] = array(
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_format_form', 1),
     'access arguments' => array('design any report'),
     'description' => 'Style and document options',
     'type' => MENU_LOCAL_TASK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $items['reports/%/delete'] = array(
David Metzler's avatar
David Metzler committed
     'title' => 'Delete Report',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_delete_form', 1),
     'access arguments' => array('delete report'),
     'type' => MENU_NORMAL_ITEM,
David Metzler's avatar
David Metzler committed
     'file' => 'forena.admin.inc',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['reports/add'] = array(
     'title' => 'Create Report',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_add_report_form'),
David Metzler's avatar
David Metzler committed
     'access arguments' => array('create any report'),
     'description' => 'Create a new report',
David Metzler's avatar
David Metzler committed
     'type' => MENU_NORMAL_ITEM,
David Metzler's avatar
David Metzler committed
  );
  $items['reports/%/add'] = array(
     'title' => 'Create Report',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_add_report_form', 1),
     'access arguments' => array('create any report'),
     'description' => 'Create a new report from a template',
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $items['reports/%/translate'] = array(
     'title' => 'Translate Report',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('forena_create_trans_form',1),
     'access arguments' => array('create any report'),
     'description' => 'Create a new report translation',
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

  $items['forena'] = array(
    'page callback' => 'forena_user_reports',
David Metzler's avatar
David Metzler committed
    'page arguments' => array(),
    'title' => 'My Reports',
    'access arguments' => array('list reports'),
    'type' => MENU_NORMAL_ITEM,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['forena/xml/%'] = array(
   	'page callback' => 'forena_block_xml',
    'page arguments' => array(2),
   	'access callback' => TRUE,
    'file' => 'forena.common.inc',
   	'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $items['forena/fields/format/autocomplete'] = array(
David Metzler's avatar
David Metzler committed
     'page callback' => 'forena_fields_format_autocomplete',
     'access callback' => TRUE,
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['forena/data_block/autocomplete'] = array(
David Metzler's avatar
David Metzler committed
     'page callback' => 'forena_data_block_autocomplete',
     'access callback' => TRUE,
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  $items['forena/reports/autocomplete'] = array(
     'page callback' => 'forena_reports_autocomplete',
     'access callback' => TRUE,
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $items['forena/categories/autocomplete'] = array(
David Metzler's avatar
David Metzler committed
     'page callback' => 'forena_categories_autocomplete',
     'access callback' => TRUE,
     'type' => MENU_CALLBACK,
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed

  return $items;
David Metzler's avatar
David Metzler committed
}
/**
 * Implements hook_admin_paths_alter().
 */
function forena_admin_paths_alter(&$paths) {
David Metzler's avatar
David Metzler committed
  $paths['reports/*/*'] = TRUE;
  $paths['reports/*/view'] = FALSE;
  $paths['reports/add'] = TRUE;
David Metzler's avatar
David Metzler committed

/**
David Metzler's avatar
David Metzler committed
 * Implementation of hook_block_info
David Metzler's avatar
David Metzler committed
 */
David Metzler's avatar
David Metzler committed
function forena_block_info() {
David Metzler's avatar
David Metzler committed
  $blocks['forena_reports'] = array('info' => t('My reports'),
David Metzler's avatar
David Metzler committed
      'status' => 1,
      'region' => 'sidebar_first',
David Metzler's avatar
David Metzler committed
      'visibility' => 1,
      'pages' => 'forena',
David Metzler's avatar
David Metzler committed
  );
  return $blocks;
David Metzler's avatar
David Metzler committed
}
/**
 * Implementation of hook_block_view
 */
function forena_block_view($delta = 0) {
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  // Inlcude the base library
  require_once('forena.common.inc');
  switch ($delta) {
    case 'forena_reports':
      $block = array('subject' => 'My Reports',
David Metzler's avatar
David Metzler committed
            'content' => forena_my_reports_block());
David Metzler's avatar
David Metzler committed
      break;
  }
  return $block;
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
/**
 * Auto complete for categories
David Metzler's avatar
David Metzler committed
 *
David Metzler's avatar
David Metzler committed
 */

function forena_categories_autocomplete($string='') {
  require_once('forena.admin.inc');
  $categories = @forena_get_categories($string);
David Metzler's avatar
David Metzler committed
  print drupal_json_output($categories);
/**
 * Auto complete for data blocks
 * @param $string
 * @return unknown_type
 */
function forena_data_block_autocomplete($string='') {
David Metzler's avatar
David Metzler committed
  require_once('forena.admin.inc');
  $data_blocks = forena_user_data_blocks($string);
David Metzler's avatar
David Metzler committed

  if ($data_blocks) {
David Metzler's avatar
David Metzler committed
    $temp = array_values($data_blocks);
    $data_blocks = array_combine($temp, $temp);
David Metzler's avatar
David Metzler committed
    $data_blocks = array();
David Metzler's avatar
David Metzler committed

David Metzler's avatar
David Metzler committed
  print drupal_json_output($data_blocks);
function forena_reports_autocomplete($string='', $string2='') {
David Metzler's avatar
David Metzler committed
  GLOBAL $language;
  $link = '';
  // If we have two parameters.
  if ($string2) {
David Metzler's avatar
David Metzler committed
    $mode = $string;
    $string = $string2;
David Metzler's avatar
David Metzler committed
  $string = '%' .$string .'%';
  $result = db_query('SELECT * FROM {forena_reports} where language=:language
	  AND report_name like :string
	  ORDER BY category,title', array(':language' => $language->language, ':string' => $string));
  foreach ($result as $row) {
    $access = TRUE;
    $cache = $row->cache;

    if ($cache) {
      $cache = unserialize($cache);

      // Check each callback function to see if we have an error.
      if ($cache['access']) foreach ($cache['access'] as $callback => $args) {
        if ($callback) foreach ($args as $arg) {
          $access = FALSE;
          if (function_exists($callback)) {
            $a = @$callback($arg);
          }
          if ($a) $access = TRUE;
        }
        else {
          $access = TRUE;
        }
      }
    }
    if ($access) {
David Metzler's avatar
David Metzler committed
      $key = $row->report_name;
      if ($mode == 'link') {
        $key = 'reports/' . str_replace('/', '.', $key);
      }
      $reports[$key] = $key . ' - ' . $row->title;
David Metzler's avatar
David Metzler committed
  return drupal_json_output($reports);

function forena_xml($block_name, $parms=array()) {
David Metzler's avatar
David Metzler committed
  include_once('forena.common.inc');
  drupal_alter('forena_parameters', $block_name, $parms );
  //now invoke the data provider with the correct params
  Frx::Data()->push($parms, 'parm');
  return Frx::RepoMan()->data($block_name);
/**
 * Auto complete for formats
 * @param $string
 * @return unknown_type
 */
function forena_fields_format_autocomplete($string='') {
David Metzler's avatar
David Metzler committed
  require_once('forena.common.inc');
  $matches = array();
  $formats = @FrxReportGenerator::instance()->supported_formats();
David Metzler's avatar
David Metzler committed

  if ($string == "*") {
    $matches = $formats;
David Metzler's avatar
David Metzler committed
    print drupal_json_output($matches);
David Metzler's avatar
David Metzler committed
    return;
  }

  if ($formats && $string) foreach ($formats as $name => $value) {
    if (strpos(strtolower($name), strtolower($string)) !== FALSE || strpos(strtolower($value), strtolower($string))!==FALSE) {
      $matches[$name] = $value;
    }
  }
David Metzler's avatar
David Metzler committed
  print drupal_json_output($matches);
/**
 *  Calls forena_parameter_form
 *  in forena.common.inc
 */
David Metzler's avatar
David Metzler committed
function forena_parameters_report() {
  require_once('forena.admin.inc');
  $m = Frx::Menu();
  $name = $m->name;
  $filename = $m->filename;
  $format = $m->format;
David Metzler's avatar
David Metzler committed
  $report = forena_get_report($name);
  if ($report) {
    $r = forena_report_object();
    $o = drupal_get_form('forena_parameters_form');
    return $o;
David Metzler's avatar
David Metzler committed
  }
  else {
    drupal_not_found();
function forena_parameter_form($formid, &$form_state, $parameters, $attributes= array()) {
  $parms = $_GET;
  $menu_parms = Frx::Data()->getContext('menu-parms');
  if ($menu_parms) {
    $form_state['storage']['menu-parms'] = $menu_parms;
  }
  if (isset($form_state['values'])) {
    $collapse=FALSE;
    $parms = array_merge($parms, $form_state['values']['params']);
    // In the case of ahah, we need to restore menu parameters from the form state.
    if (isset($form_state['storage']['menu-parms'])) {
      $menu_parms = $form_state['storage']['menu-parms'];
      $parms = array_merge($menu_parms,$parms);

    }
    Frx::Data()->push($parms, 'parm');
  }
  $collapse = isset($attributes['collapse']) ? $attributes['collapse'] : FALSE;
  $template = @$attributes['template'];
  $collapsible = isset($attributes['collapsible']) ? $attributes['collapsible'] : TRUE;
  $title = isset($attributes['title']) ? $attributes['title'] : t('Parameters');
  $submit_value = isset($attributes['submit']) ? $attributes['submit'] : t('Submit');
  unset($parms['q']);
  $form = array();
  if ($parameters) {
David Metzler's avatar
David Metzler committed
    $report_name = '';
    drupal_alter('forena_parameters', $report_name,  $parms);
    if ($parameters) {
David Metzler's avatar
David Metzler committed
      $form['params'] = array(
          '#tree' => TRUE,
          '#type' => 'fieldset',
          '#collapsible' => $collapsible,
          '#collapsed' => $collapse,
          '#prefix' => '<div id="parameters-wrapper">',
          '#suffix' => '</div>',
David Metzler's avatar
David Metzler committed
      );

      foreach ($parameters as $node) {
        $add_null = FALSE;
        $list=array();
David Metzler's avatar
David Metzler committed
        $disabled = FALSE;
        $label = @(string)$node['label'];
        $id = @(string)$node['id'];
        $data_source = @(string)$node['data_source'];
        $data_field = @(string)$node['data_field'];
        $class = @(string)$node['class'];
        $type = @(string)$node['type'];
        $option_str = @(string)$node['options'];
        $options = array();
        if ($option_str) {
          parse_str($option_str, $options);
        }
David Metzler's avatar
David Metzler committed
        if (isset($parms[$id])) {
          $value = $parms[$id];
          $multi_value=(array)$parms[$id];
        }
        else {
          $value = @(string)$node['default'];
          $multi_value = array();
          if (strpos($value, '|')!==FALSE) $multi_value = explode('|', $value);
        }
        $desc =  @(string)$node['desc'];
        $label_field = @(string)$node['label_field'];

        @(strcmp((string)$node['require'], "1") == 0) ? $required = TRUE : $required = FALSE;
        $ctl_attrs = array();

        //returned values filtered against data_field attr.
        if ($data_source) {
          $list = Frx::RepoMan()->dataBlockParams($data_source, $data_field, $label_field);
          if (!$required && $add_null) $list = array('' => '') + $list;
        }

David Metzler's avatar
David Metzler committed
        //Determine the form element type to be displayed
        //If select or radios is chosen then begin a $list array for display values.
        $multiselect = FALSE;
        $ajax = FALSE;
        $add_null = FALSE;
        switch ($type) {
          case 'multiselect':
            $type = 'select';
            $multiselect = TRUE;
            $value = $multi_value;
            break;
          case 'multiselectajax':
            $type = 'select';
            $multiselect = TRUE;
            $value = $multi_value;
            $ajax = TRUE;
            break;
          case 'checkboxes':
            $value = $multi_value;
            break;
          case 'selectajax':
            $ajax = TRUE;
            $type = 'select';
            $add_null = TRUE;
            break;
          case 'select':
            $add_null = TRUE;
            break;
          case 'date_text':
          case 'date_select':
          case 'date_popup':
            $options['date_format'] = @$options['date_format'] ? $options['date_format'] : 'Y-m-d';
            $ctl_attrs['#date_format'] = $options['date_format'];
            if ($value){
              $datetime = @strtotime($value);
              if ($datetime) {
                $value = date('Y-m-d h:i', $datetime);
David Metzler's avatar
David Metzler committed
            }
            $ctl_attrs['#forena_date_format'] = @$options['date_parm_format'] ? $options['date_parm_format'] : 'Y-m-d';
David Metzler's avatar
David Metzler committed
            if (@$options['date_year_range']) {
              $ctl_attrs['#date_year_range'] = $options['date_year_range'];
            }
            if (@$options['date_label_position']) {
              $ctl_attrs['#date_label_position'] = $options['date_label_position'];
            }
            $list=array();
David Metzler's avatar
David Metzler committed
            break;
          case 'checkbox':
            if (@$option_str['return_value']) {
              $ctl_attrs['#return_value'] = $options['return_value'];
            }
            $list=array();
David Metzler's avatar
David Metzler committed
            break;
          case 'radios':
            break;
          case 'hidden':
            $list=array();
David Metzler's avatar
David Metzler committed
            break;
          default:
            $type = 'textfield';
David Metzler's avatar
David Metzler committed
        }
David Metzler's avatar
David Metzler committed
        if (isset($menu_parms[$id]) && $type=='textfield') {
          $disabled = TRUE;
        }
David Metzler's avatar
David Metzler committed
        //If a data_source attr was found then create an array of
        $form['params'][$id] = array(
            '#type' => $type,
            '#title' => ($label) ? t($label) : t($id),
            '#default_value' => $value,
            '#required' => $required,
            '#description' => t($desc),
David Metzler's avatar
David Metzler committed
        );
David Metzler's avatar
David Metzler committed
        $form['params'][$id] = array_merge($form['params'][$id], $ctl_attrs);
David Metzler's avatar
David Metzler committed
        if ($type == 'item') {
          $form['params'][$id]['#markup'] = $value;
David Metzler's avatar
David Metzler committed
        }
David Metzler's avatar
David Metzler committed
        if ($type == 'hidden') {
          $form['params'][$id]['#value'] = $value;
David Metzler's avatar
David Metzler committed
        }
David Metzler's avatar
David Metzler committed
        // Add class to parmeter form.
        if ($class) {
          $form['params'][$id]['#attributes'] = array(
              'class' => @explode(' ', $class),
David Metzler's avatar
David Metzler committed
          );
        }
David Metzler's avatar
David Metzler committed
        //if $list is not empty then push options
        //onto the array. options will cause an error for
        //textfield elements.
        if ($list || $type == 'select' || $type =='radios') {
          if ($add_null) {
            $prompt = @$options['prompt'];
            if (!$prompt) $prompt = $required ? '-select-' : '-none-';
            $form['params'][$id]['#empty_option'] = $prompt ;
          }
David Metzler's avatar
David Metzler committed
          $form['params'][$id]['#options'] = $list;
          $form['params'][$id]['#multiple'] = $multiselect;
        }
David Metzler's avatar
David Metzler committed
        if ($ajax) {
          $form['params'][$id]['#ajax'] = array('callback' => 'forena_parameters_callback',
              'wrapper' => 'parameters-wrapper');
David Metzler's avatar
David Metzler committed
      }

      if ($template) {
        $form['params']['#forena-template'] = $template;
        $form['params']['#theme'] = 'forena_fieldset_template';
        _forena_set_inline_theme($form['params']);
      }
David Metzler's avatar
David Metzler committed
      $form['params']['submit'] = array(
          '#type' => 'submit',
          '#value' => $submit_value,
David Metzler's avatar
David Metzler committed
      );
David Metzler's avatar
David Metzler committed
    return $form;
  }


}


/**
 *
 * gets the values from the params form
 * redirects to the report page with the values in
 * the querystring.
 */
function forena_parameter_form_submit($form, &$form_state) {
  $values = $form_state['values'];
  unset($values['params']['submit']);
  if (isset($values['params'])) foreach ($values['params'] as $key => $value) {
    $ctl = $form['params'][$key];
    switch($ctl['#type']) {
      case 'date_popup':
      case 'date_select':
      case 'date_text':
        $datetime = @strtotime($value);
        if ($datetime) {
          $value = $values['params'][$key] = date($ctl['#forena_date_format'], $datetime);
    if (is_array($value)) {
      $values['params'][$key] = array();
      foreach ($value as $k => $val) {
        if ($val) {
          $values['params'][$key][] = $val;
        }
      }
    }
    else {
      if (strpos($value, '|')!==FALSE) {
        $values['params'][$key] = explode('|', $value);
      }
      elseif ($value==='' || $value===NULL) {
        unset($values['params'][$key]);
      }
    }
  }
  $form_state['redirect']= array($_GET['q'], array('query' => @$values['params']));
}

/**
 * Ajax form callback function
 * Enter description here ...
 * @param unknown_type $form
 * @param unknown_type $form_state
 */
function forena_parameters_callback($form, &$form_state) {
  return $form['params'];
}

David Metzler's avatar
David Metzler committed
function forena_permission() {
David Metzler's avatar
David Metzler committed
    'administer forena reports' => array('title' => t('Administer Forena Reports')),
    'access demo reports' => array('title' => t('Access Demo Reports')),
David Metzler's avatar
David Metzler committed
    'list reports' => array('title' => t('List reports')),
    'create any report' => array('title' => t('Create a report')),
    'design any report' => array('title' => t('Design reports')),
    'delete report' => array('title' => t('Delete reports')),
    'perform email merge' => array('title' => t('Peform email merge')),
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  return $perms;
David Metzler's avatar
David Metzler committed

function forena_user_reports() {
  require_once('forena.common.inc');
David Metzler's avatar
David Metzler committed
  $output='';
  $reports = forena_get_user_reports();
  $report_repos = variable_get('forena_path', 'reports');
  if (!$reports) {
    $output = 'No Reports Found';
  }
David Metzler's avatar
David Metzler committed
  $links = '';
David Metzler's avatar
David Metzler committed
  foreach ($reports as $category => $reports) {
David Metzler's avatar
David Metzler committed
    $links .= '<li><a href="#' . urlencode($category) . '">' . $category . '</a></li> ';
    $output .= '<h3><a name="' . urlencode($category) . '"/>' . $category . '</h3>';
    $output .= '<ul>';
    foreach ($reports as $r) {
      $output .= '<li>' . l($r['title'], $report_repos . '/' . str_replace('/', '.', $r['report_name'])) . '</li>';
David Metzler's avatar
David Metzler committed
    $output .= '</ul       >';
David Metzler's avatar
David Metzler committed
  return $output;
David Metzler's avatar
David Metzler committed
}

function forena_include_data_tables() {
David Metzler's avatar
David Metzler committed
  static $init = FALSE;
  if (!$init) {
    $init = TRUE;
    $lib = 'sites/all/libraries/dataTables/media/js/jquery.dataTables.min.js';
    if (file_exists($lib)) {
      drupal_add_js($lib);
    }
    $lib = 'sites/all/libraries/FixedColumns/media/js/FixedColumns.min.js';
    if (file_exists($lib)) {
      drupal_add_js($lib);
    }
    $lib = 'sites/all/libraries/FixedHeader/js/FixedHeader.min.js';
    if (file_exists($lib)) {
      drupal_add_js($lib);
    }
  }
/**
 * Load and render a report based on a drupal path.
 * In this function the arglist is used to get the full path to the report.
 *
 * @return unknown
 */
function forena_report($name_in, $parms = array(), $print = TRUE) {
  require_once('forena.common.inc');
  $desc = Frx::Menu()->parseURL($name_in);
David Metzler's avatar
David Metzler committed
    drupal_not_found();
    exit;
metzlerd's avatar
metzlerd committed

  FrxData::instance()->setContext('cookie', $_COOKIE);
  // Load dataTable plugin if possible.
David Metzler's avatar
David Metzler committed
  //forena_include_data_tables();
  $output = FrxReportGenerator::instance()->report($name_in, $parms, $print);
  $m_path = drupal_get_path('module', 'forena');

  if ($output) {
    // This has been deprecated, but we'll eave it in for now.
David Metzler's avatar
David Metzler committed
    if ($print) drupal_add_js($m_path . '/forena.js');
    $forena_js = array();
    $forena_js['form'] = preg_replace('/[^\w\-]+/u', '_', Frx::Skin()->name);
    $forena_js['report'] = preg_replace('/[^\w\-]+/u', '_', $name_in);
David Metzler's avatar
David Metzler committed
    if ($print) drupal_add_js(array('forena' => $forena_js), 'setting');
David Metzler's avatar
David Metzler committed
 * Render report as an inlcude.  Don't perform the output fuctnions for the document
 * @param $report_name String
 * @param $parms array of parameters to include
 */
David Metzler's avatar
David Metzler committed
function forena_report_include($report_name, $parms=array()) {
David Metzler's avatar
David Metzler committed
  $output = '';
  require_once 'forena.common.inc';
  $desc= Frx::Menu()->parseURL($report_name);
  $name = $desc['name'];

  $r = @FrxReportGenerator::instance()->get_report($name, $parms);
  if (!$r || !$r->rpt_xml) {
    return '';
  }
  //check for default parameters
  $r->processParameters();
  $format = $desc['format'];
  $r->render($format);

  $o =  Frx::Document($format);
  if ($o) {
    $output = $o->render($r, $format,  array());
  }
  return $output;
 * Menu callback for rendering the forena report.
function forena_report_menu_callback() {
  $args = func_get_args();
David Metzler's avatar
David Metzler committed
  $path = array_shift($args);
  $report_name = array_shift($args);
  $parms = $_GET;
  unset($parms['q']);
  $menu_parms = array();
  $tokens = Frx::Menu()->tokens($path);
David Metzler's avatar
David Metzler committed
  if ($args && $tokens) {
    foreach ($args as $i=> $value) {
      @$menu_parms[$tokens[$i]] = $value;
    }
  }

  Frx::Data()->setContext('menu-parms', $menu_parms);
  $parms = array_merge($parms, $menu_parms);
  $output = forena_report($report_name, $parms);
  if ($output) return $output;
 * Used in hook_menu to test access to menu items.
 * @param $checks array key value of callbacks and args to check.
 */
function forena_check_all_access($checks) {
  // Check each callback function to see if we have an error.
  $access = FALSE;
  if ($checks) foreach ((array)$checks as $callback => $args) {
David Metzler's avatar
David Metzler committed
    if ($callback && $args) foreach ($args as $arg) {
      if (function_exists($callback)) {
        $a = $callback($arg);
      }
      if ($a) $access = TRUE;
    }
    else {
      $access = TRUE;
    }
metzlerd's avatar
metzlerd committed
/**
 * Callback for setting international titles
 * @param $report_name string name of report
 * @param $use_menu_title boolean indicate wether to use menu title attribute.
 */
function forena_report_title_callback($report_name, $use_menu_title=TRUE) {
  GLOBAL $language;
  $title = '';
  $lang = $language->language;
  $result = db_query('SELECT * FROM {forena_reports} where report_name = :name and language=:language',
metzlerd's avatar
metzlerd committed
  array(':name' => $report_name, 'language' => $lang));
  foreach ($result as $row) {
metzlerd's avatar
metzlerd committed
    $cache = $row->cache;
    if ($cache) {
      $cache = unserialize($cache);
      // Load menu item defaults
      $menu = $cache['menu'];
    }
    $title = $use_menu_title && @$menu['title'] ? $menu['title']:  $row->title;
  }
  return $title;
}

David Metzler's avatar
David Metzler committed
/**
 * Render report with some data
 *
 * @param string $report
 * @param string $format
 * @param mixed $data
David Metzler's avatar
David Metzler committed
 * @return unknown
 */
function forena_render_report($report, $format='', $data='', $options= array(), $print = TRUE) {
  require_once('forena.common.inc');
  $o = forena_report_object($report, $data);
David Metzler's avatar
David Metzler committed
  $output = $o->render($format);

  //If a format was requested render a custom non-drupal document
  if ($format && $format != 'web') {
    $output = FrxReportGenerator::instance()->generate_doc($format, $output, $options, $print);
David Metzler's avatar
David Metzler committed
  }
 * Self register plugins with forena.
David Metzler's avatar
David Metzler committed
function forena_forena_plugins() {
  $plugins[] = array('file' => 'plugins/FrxPDO.inc',
                     'class' => 'FrxPDO',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $plugins[] = array('file' => 'plugins/FrxOracle.inc',
                     'class' => 'FrxOracle',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $plugins[] = array('file' => 'plugins/FrxDrupal.inc',
                     'class' => 'FrxDrupal',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $plugins[] = array('file' => 'plugins/FrxFiles.inc',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $plugins[] = array('file' => 'plugins/FrxPostgres.inc',
                     'class' => 'FrxPostgres',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  $plugins[] = array('file' => 'plugins/FrxMSSQL.inc',
                     'class' => 'FrxMSSQL',
David Metzler's avatar
David Metzler committed
  );
David Metzler's avatar
David Metzler committed
  return $plugins;
/**
 * Self register document formats with Forena
function forena_forena_document_types() {
  require_once 'docformats/FrxWebDoc.inc';
  require_once 'docformats/FrxCSVDoc.inc';
  require_once 'docformats/FrxHtmlDoc.inc';
  require_once 'docformats/FrxSVGDoc.inc';
  require_once 'docformats/FrxWordDoc.inc';
  require_once 'docformats/FrxXLSDoc.inc';
  require_once 'docformats/FrxXMLDoc.inc';
  require_once 'docformats/FrxEmailMergeDoc.inc';
    'class' => 'FrxWebDoc',
    'title' => t('Themed Drupal Page'),
  );

  $items['csv'] = array(
    'class' => 'FrxCSVDoc',
    'title' => t('Comma separated values'),
  );

  $items['email'] = array(
    'class' => 'FrxEmailMergeDoc',
    'title' => t('Email Merge Document'),
  );

  $items['html'] = array(
    'class' => 'FrxHtmlDoc',
    'title' => t('Unthemed HTML'),
  );

  $items['svg'] = array(
    'class' => 'FrxSVGDoc',
    'title' => t('SVG Document'),
  );

  $items['doc'] = array(
    'class' => 'FrxWordDoc',