You are here

function scheduler_views_data in Scheduler 7

Same name and namespace in other branches
  1. 6 scheduler.views.inc \scheduler_views_data()

Implements hook_views_data().

File

./scheduler.views.inc, line 11
Views integration file for Scheduler module.

Code

function scheduler_views_data() {
  $tables['scheduler']['table']['group'] = t('Scheduler');

  // Advertise the Scheduler table as a possible base table.
  // @see https://www.drupal.org/node/2611712
  $tables['scheduler']['table']['base'] = array(
    'field' => 'nid',
    'title' => t('Content via Scheduler'),
    'help' => t('Display node data using the Scheduler table as the base table'),
  );

  // Define how the Scheduler table is linked to the node table. This is used
  // for the normal 'content' view when 'node' is the base table.
  $tables['scheduler']['table']['join']['node'] = array(
    'left_field' => 'nid',
    'field' => 'nid',
  );

  // Define how the node table is linked to the Scheduler table. This is needed
  // when 'scheduler' is the base table, to give access to the node fields.
  // Type = 'inner' will exclude any bad data rows in the scheduler table.
  $tables['node']['table']['join']['scheduler'] = array(
    'left_field' => 'nid',
    'field' => 'nid',
    'type' => 'inner',
  );

  // Describe the two fields in the Scheduler database table.
  $tables['scheduler']['publish_on'] = array(
    'title' => t('Publish on'),
    'help' => t('Date/time on which the article will be automatically published'),
    'field' => array(
      'handler' => 'views_handler_field_date',
      'click sortable' => TRUE,
    ),
    'filter' => array(
      'handler' => 'views_handler_filter_date',
      'label' => t('Publish on'),
      'allow empty' => TRUE,
    ),
    'sort' => array(
      'handler' => 'views_handler_sort_date',
    ),
  );
  $tables['scheduler']['unpublish_on'] = array(
    'title' => t('Unpublish on'),
    'help' => t('Date/time on which the article will be automatically unpublished'),
    'field' => array(
      'handler' => 'views_handler_field_date',
      'click sortable' => TRUE,
    ),
    'filter' => array(
      'handler' => 'views_handler_filter_date',
      'label' => t('Unpublish on'),
      'allow empty' => TRUE,
    ),
    'sort' => array(
      'handler' => 'views_handler_sort_date',
    ),
  );

  // Describe the two extra derived fields provided for Views.
  $tables['scheduler']['publish_countdown'] = array(
    'title' => t('Publish countdown'),
    'help' => t('Time until the content will be published'),
    'field' => array(
      'handler' => 'SchedulerHandlerFieldSchedulerCountdown',
      'click sortable' => FALSE,
      'timestamp_field' => 'publish_on',
    ),
  );
  $tables['scheduler']['unpublish_countdown'] = array(
    'title' => t('Unpublish countdown'),
    'help' => t('Time until the content will be unpublished'),
    'field' => array(
      'handler' => 'SchedulerHandlerFieldSchedulerCountdown',
      'click sortable' => FALSE,
      'timestamp_field' => 'unpublish_on',
    ),
  );
  return $tables;
}