function aggregator_view in Drupal 7
Same name and namespace in other branches
- 4 modules/aggregator.module \aggregator_view()
- 5 modules/aggregator/aggregator.module \aggregator_view()
- 6 modules/aggregator/aggregator.admin.inc \aggregator_view()
Displays the aggregator administration page.
Return value
A HTML-formatted string with administration page content.
1 call to aggregator_view()
- aggregator_admin_overview in modules/
aggregator/ aggregator.admin.inc - Page callback: Displays the Aggregator module administration page.
File
- modules/
aggregator/ aggregator.admin.inc, line 21 - Administration page callbacks for the Aggregator module.
Code
function aggregator_view() {
$result = db_query('SELECT f.fid, f.title, f.url, f.refresh, f.checked, f.link, f.description, f.hash, f.etag, f.modified, f.image, f.block, COUNT(i.iid) AS items FROM {aggregator_feed} f LEFT JOIN {aggregator_item} i ON f.fid = i.fid GROUP BY f.fid, f.title, f.url, f.refresh, f.checked, f.link, f.description, f.hash, f.etag, f.modified, f.image, f.block ORDER BY f.title');
$output = '<h3>' . t('Feed overview') . '</h3>';
$header = array(
t('Title'),
t('Items'),
t('Last update'),
t('Next update'),
array(
'data' => t('Operations'),
'colspan' => '3',
),
);
$rows = array();
foreach ($result as $feed) {
$rows[] = array(
l($feed->title, "aggregator/sources/{$feed->fid}"),
format_plural($feed->items, '1 item', '@count items'),
$feed->checked ? t('@time ago', array(
'@time' => format_interval(REQUEST_TIME - $feed->checked),
)) : t('never'),
$feed->checked && $feed->refresh ? t('%time left', array(
'%time' => format_interval($feed->checked + $feed->refresh - REQUEST_TIME),
)) : t('never'),
l(t('edit'), "admin/config/services/aggregator/edit/feed/{$feed->fid}"),
l(t('remove items'), "admin/config/services/aggregator/remove/{$feed->fid}"),
l(t('update items'), "admin/config/services/aggregator/update/{$feed->fid}", array(
'query' => array(
'token' => drupal_get_token("aggregator/update/{$feed->fid}"),
),
)),
);
}
$output .= theme('table', array(
'header' => $header,
'rows' => $rows,
'empty' => t('No feeds available. <a href="@link">Add feed</a>.', array(
'@link' => url('admin/config/services/aggregator/add/feed'),
)),
));
$result = db_query('SELECT c.cid, c.title, COUNT(ci.iid) as items FROM {aggregator_category} c LEFT JOIN {aggregator_category_item} ci ON c.cid = ci.cid GROUP BY c.cid, c.title ORDER BY title');
$output .= '<h3>' . t('Category overview') . '</h3>';
$header = array(
t('Title'),
t('Items'),
t('Operations'),
);
$rows = array();
foreach ($result as $category) {
$rows[] = array(
l($category->title, "aggregator/categories/{$category->cid}"),
format_plural($category->items, '1 item', '@count items'),
l(t('edit'), "admin/config/services/aggregator/edit/category/{$category->cid}"),
);
}
$output .= theme('table', array(
'header' => $header,
'rows' => $rows,
'empty' => t('No categories available. <a href="@link">Add category</a>.', array(
'@link' => url('admin/config/services/aggregator/add/category'),
)),
));
return $output;
}