function theme_nodequeue_arrange_subqueue_form_table in Nodequeue 7.3
Same name and namespace in other branches
- 7.2 nodequeue.theme.inc \theme_nodequeue_arrange_subqueue_form_table()
Theme the subqueue overview as a sortable list.
File
- ./
nodequeue.module, line 2067 - Maintains queues of nodes in arbitrary order.
Code
function theme_nodequeue_arrange_subqueue_form_table($variables) {
$form = $variables['form'];
$output = '';
// Get css to hide some of the help text if javascript is disabled.
drupal_add_css(drupal_get_path('module', 'nodequeue') . '/nodequeue.css');
$table_id = 'nodequeue-dragdrop-' . $form['#subqueue']['sqid'];
$table_classes = array(
'nodequeue-dragdrop',
'nodequeue-dragdrop-name-' . $form['#subqueue']['name'],
'nodequeue-dragdrop-sqid-' . $form['#subqueue']['sqid'],
'nodequeue-dragdrop-reference-' . $form['#subqueue']['reference'],
);
drupal_add_tabledrag($table_id, 'order', 'sibling', 'node-position');
drupal_add_js(drupal_get_path('module', 'nodequeue') . '/nodequeue_dragdrop.js');
$reverse[str_replace('-', '_', $table_id)] = (bool) $form['#queue']['reverse'];
drupal_add_js(array(
'nodequeue' => array(
'reverse' => $reverse,
),
), array(
'type' => 'setting',
'scope' => JS_DEFAULT,
));
// Render form as table rows.
$rows = array();
$counter = 1;
foreach (element_children($form) as $key) {
if (isset($form[$key]['title'])) {
$row = array();
$row[] = drupal_render($form[$key]['title']);
$row[] = drupal_render($form[$key]['author']);
$row[] = drupal_render($form[$key]['date']);
$row[] = drupal_render($form[$key]['position']);
$row[] = !empty($form[$key]['edit']) ? drupal_render($form[$key]['edit']) : ' ';
$row[] = drupal_render($form[$key]['remove']);
$row[] = array(
'data' => $counter,
'class' => array(
'position',
),
);
$rows[] = array(
'data' => $row,
'class' => array(
'draggable',
),
);
}
$counter++;
}
if (empty($rows)) {
$rows[] = array(
array(
'data' => t('No nodes in this queue.'),
'colspan' => 7,
),
);
}
// Render the main nodequeue table.
$header = array(
t('Title'),
t('Author'),
t('Post Date'),
t('Position'),
array(
'data' => t('Operations'),
'colspan' => 2,
),
t('Position'),
);
$output .= theme('table', array(
'header' => $header,
'rows' => $rows,
'attributes' => array(
'id' => $table_id,
'class' => $table_classes,
),
));
return $output;
}