You are here

function views_plugin_row_aggregator_rss::render in Views (for Drupal 7) 6.2

Same name and namespace in other branches
  1. 6.3 modules/aggregator/views_plugin_row_aggregator_rss.inc \views_plugin_row_aggregator_rss::render()
  2. 7.3 modules/aggregator/views_plugin_row_aggregator_rss.inc \views_plugin_row_aggregator_rss::render()

Render a row object. This usually passes through to a theme template of some form, but not always.

Overrides views_plugin_row::render

File

modules/aggregator/views_plugin_row_aggregator_rss.inc, line 33
Contains the Aggregator Item RSS row style plugin.

Class

views_plugin_row_aggregator_rss
Plugin which loads an aggregator item and formats it as an RSS item.

Code

function render($row) {
  $sql = "SELECT ai.iid, ai.fid, ai.title, ai.link, ai.author, ai.description, ";
  $sql .= "ai.timestamp, ai.guid, af.title AS feed_title, ai.link AS feed_LINK ";
  $sql .= "FROM {aggregator_item} ai LEFT JOIN {aggregator_feed} af ON ai.fid = af.fid ";
  $sql .= "WHERE ai.iid = %d";
  $item = db_fetch_object(db_query($sql, $row->iid));
  $item->elements = array(
    array(
      'key' => 'pubDate',
      'value' => gmdate('r', $item->timestamp),
    ),
    array(
      'key' => 'dc:creator',
      'value' => $item->author,
      'namespace' => array(
        'xmlns:dc' => 'http://purl.org/dc/elements/1.1/',
      ),
    ),
    array(
      'key' => 'guid',
      'value' => $item->guid,
      'attributes' => array(
        'isPermaLink' => 'false',
      ),
    ),
  );
  foreach ($item->elements as $element) {
    if (isset($element['namespace'])) {
      $this->view->style_plugin->namespaces = array_merge($this->view->style_plugin->namespaces, $element['namespace']);
    }
  }
  return theme($this
    ->theme_functions(), $this->view, $this->options, $item);
}