nodesinblock.admin.inc in Nodes In Block 6
Same filename and directory in other branches
Administration page for nodes in block.
File
nodesinblock.admin.incView source
<?php
/**
* @file
* Administration page for nodes in block.
*/
/**
* Menu callback to configure general settings for nodes in block.
*/
function nodesinblock_settings() {
$form = array();
$content_types = node_get_types('names');
$saved_types = variable_get('nodesinblock_contenttypes', array());
$form['nodesinblock'] = array(
'#type' => 'fieldset',
'#title' => t('General settings'),
'#description' => t('Select number of blocks to create and associate content types which nodes can be used to insert as content in a block. When you change the number, be sure to goto the <a href="@url">block configuration</a> page so the block settings are updated in the database. When at least one content type is selected, two fieldsets will become available after clicking the submit button where you can change general settings and associate content types per block.', array(
'@url' => url('admin/build/block'),
)),
);
$form['nodesinblock']['nodesinblock_nrofblocks'] = array(
'#type' => 'select',
'#title' => t('Total number of blocks'),
'#options' => drupal_map_assoc(array(
1,
2,
3,
4,
5,
6,
7,
8,
9,
10,
11,
12,
13,
14,
15,
)),
'#default_value' => variable_get('nodesinblock_nrofblocks', 1),
);
$form['nodesinblock']['nodesinblock_contenttypes'] = array(
'#type' => 'checkboxes',
'#title' => t('Content types'),
'#options' => $content_types,
'#default_value' => $saved_types,
);
$form['nodesinblock']['nodesinblock_referer'] = array(
'#type' => 'checkbox',
'#title' => t('Use the referring page as the default value for <em>visibility</em> at the content node form'),
'#default_value' => variable_get('nodesinblock_referer', FALSE),
'#prefix' => '<strong>' . t('Creating and modifying blocks') . ':</strong>',
);
$form['nodesinblock']['nodesinblock_editbuttons'] = array(
'#type' => 'checkbox',
'#title' => t('Show an edit button near each node'),
'#default_value' => variable_get('nodesinblock_editbuttons', FALSE),
);
$form['nodesinblock']['nodesinblock_editbuttons_text'] = array(
'#type' => 'textfield',
'#title' => t('Texts for edit button'),
'#default_value' => variable_get('nodesinblock_editbuttons_text', t('(edit)')),
);
// Settings per block & content type.
if (!empty($saved_types)) {
$form['general_settings'] = array(
'#type' => 'fieldset',
'#title' => t('Settings per block'),
'#description' => t('Note: if you set the visibility setting for the block as "<em>Show on every page except the listed pages</em>", multiple paths will not work correct because of the way that Drupal core block visibility works. You\'ll be better off choosing the default option.'),
);
for ($i = 0, $a = 1; $i < variable_get('nodesinblock_nrofblocks', 1); $i++, $a++) {
$form['general_settings']['nodesinblock_friendlyname_' . $i] = array(
'#type' => 'textfield',
'#title' => t('User friendly name for block') . ' ' . $a,
'#default_value' => check_plain(variable_get('nodesinblock_friendlyname_' . $i, t('Nodes in block ' . $a))),
'#description' => t('Only use alphanumeric characters.'),
);
$form['general_settings']['nodesinblock_visibility_' . $i] = array(
'#type' => 'select',
'#title' => t('Visibility settings for block') . ' ' . $a,
'#options' => array(
t('Show on every page except the listed pages.'),
t('Show on only the listed pages.'),
),
'#default_value' => variable_get('nodesinblock_visibility_' . $i, '1'),
);
}
$blocks = module_invoke('nodesinblock', 'block', 'list');
$block_options = array();
$a = 1;
foreach ($blocks as $key => $value) {
$block_options[$a] = $value['info'];
$a++;
}
$form['contenttypes_block'] = array(
'#type' => 'fieldset',
'#title' => t('Settings per content type'),
'#description' => t('Define per content type which blocks are available. On the content node form, a select box will be available to select the appropriate block where the node content must be displayed. You can also choose the label of the fieldset and if it is collapsible and/or collapsed by default. Finally, you can set a default render mode for the node. If you choose one, the select box on the node form will be hidden.'),
);
// Iterate over selected types
foreach ($saved_types as $key => $value) {
if ($value != '0') {
$form['contenttypes_block']['nodesinblock_' . $key . '_block'] = array(
'#type' => 'checkboxes',
'#title' => t('Blocks'),
'#options' => $block_options,
'#default_value' => variable_get('nodesinblock_' . $key . '_block', array()),
'#prefix' => '<div style="float: left; padding:5px; margin-right: 10px; border: 1px solid #cccccc;"> <strong>' . t('Configure @key', array(
'@key' => $key,
)) . '</strong>',
);
$form['contenttypes_block']['nodesinblock_' . $key . '_label'] = array(
'#type' => 'textfield',
'#title' => t('Fieldset label'),
'#default_value' => check_plain(variable_get('nodesinblock_' . $key . '_label', t('Nodes in block'))),
'#size' => 20,
);
$form['contenttypes_block']['nodesinblock_' . $key . '_collapsed'] = array(
'#type' => 'checkbox',
'#title' => t('Collapsed fieldset'),
'#default_value' => variable_get('nodesinblock_' . $key . '_collapsed', TRUE),
);
$form['contenttypes_block']['nodesinblock_' . $key . '_collapsible'] = array(
'#type' => 'checkbox',
'#title' => t('Collapsible fieldset'),
'#default_value' => variable_get('nodesinblock_' . $key . '_collapsible', TRUE),
);
$options = array(
0 => t('Let the user decide'),
);
$options += _nodesinblock_render_status(0);
$form['contenttypes_block']['nodesinblock_' . $key . '_render'] = array(
'#type' => 'select',
'#title' => t('Render mode'),
'#default_value' => variable_get('nodesinblock_' . $key . '_render', 0),
'#options' => $options,
'#suffix' => '</div>',
);
}
}
}
// Don't use system_settings_form because we want
// to have a warning screen when clearing configuration.
$form['buttons']['submit'] = array(
'#value' => t('Save configuration'),
'#type' => 'submit',
'#submit' => array(
'nodesinblock_settings_save',
),
);
$form['buttons']['reset'] = array(
'#value' => t('Clear configuration'),
'#type' => 'submit',
'#submit' => array(
'nodesinblock_settings_clear_redirect',
),
);
return $form;
}
/**
* Submit callback: save settings.
* We use parts of system_settings_submit here to save the variables.
*/
function nodesinblock_settings_save($form, &$form_state) {
// Exclude unnecessary elements.
unset($form_state['values']['submit'], $form_state['values']['reset'], $form_state['values']['form_id'], $form_state['values']['op'], $form_state['values']['form_token'], $form_state['values']['form_build_id']);
foreach ($form_state['values'] as $key => $value) {
if (is_array($value) && isset($form_state['values']['array_filter'])) {
$value = array_keys(array_filter($value));
}
variable_set($key, $value);
}
drupal_set_message(t('The configuration options have been saved.'));
cache_clear_all();
}
/**
* Submit callback: clear settings, simply redirects to confirmation page.
*/
function nodesinblock_settings_clear_redirect($form, &$form_state) {
$form_state['redirect'] = 'admin/settings/nodesinblock/clear';
}
/**
* Menu callback: show confirmation screen to clear nodes in block settings.
*/
function nodesinblock_settings_clear_confirm() {
$form = array();
return confirm_form($form, t('Do you want to clear the settings for nodes in block?'), 'admin/settings/nodesinblock', t('Warning, you will loose all settings including all entries in the nodesinblock table and the blocks generated by your previous configuration.'), t('Clear configuration'), t('Cancel'));
}
/**
* Submit callback: clear nodes in block settings.
*/
function nodesinblock_settings_clear_confirm_submit($form, &$form_state) {
db_query("DELETE FROM {variable} WHERE name LIKE 'nodesinblock_%%'");
db_query("DELETE FROM {blocks} where module = 'nodesinblock'");
db_query("TRUNCATE {nodesinblock}");
cache_clear_all('variables', 'cache');
drupal_set_message(t('All nodes in block settings have been cleared'));
$form_state['redirect'] = 'admin/settings/nodesinblock';
}
/**
* Menu callback to look at the queue for nodes in block.
*
* @param integer $block The delta of the block.
* @param integer $show_block_links Whether to render the blocklinks or not.
* @param integer $show_create_links Whether to render the create node links or not.
*/
function nodesinblock_queue($form_state, $block = NULL, $show_block_links = TRUE, $show_create_links = TRUE) {
$form = array();
$form['nodes'] = array(
'#tree' => TRUE,
);
$number_of_blocks = variable_get('nodesinblock_nrofblocks', 1);
if ($block == NULL) {
$block = 0;
}
// Blocklinks.
if ($show_block_links == TRUE) {
$blocklinks = array();
for ($i = 0, $a = 1; $i < $number_of_blocks; $i++, $a++) {
$title = check_plain(variable_get('nodesinblock_friendlyname_' . $i, t('Nodes in block ' . $a)));
$delta = $i != '0' ? '/' . $i : '';
$blocklinks[] = array(
'title' => $title,
'href' => 'admin/settings/nodesinblock/queue' . $delta,
);
}
$form['blocklinks'] = array(
'#type' => 'item',
'#value' => theme('links', $blocklinks),
);
}
// Content create links.
if ($show_create_links == TRUE) {
$createlinks = array();
$saved_delta = $block + 1;
$saved_types = variable_get('nodesinblock_contenttypes', array());
foreach ($saved_types as $type) {
$deltas = variable_get('nodesinblock_' . $type . '_block', array());
if (isset($deltas[$saved_delta]) && $deltas[$saved_delta] != 0) {
$createlinks[] = array(
'title' => t('Create new @type', array(
'@type' => $type,
)),
'href' => 'node/add/' . $type,
);
}
}
$form['createlinks'] = array(
'#type' => 'item',
'#value' => theme('links', $createlinks),
);
}
// Get nodes and store them in #nodes key.
$query = "SELECT n.nid, n.title, n.status as node_status,\n \t\t\t\t\tnib.weight, nib.visibility FROM {nodesinblock} nib INNER JOIN {node} n\n \t\t\t\t\ton n.nid = nib.nid WHERE nib.delta = %d ORDER BY weight ASC";
$nodes = db_query($query, $block);
while ($row = db_fetch_object($nodes)) {
$form['nodes'][$row->nid]['nid'] = array(
'#type' => 'value',
'#value' => $row->nid,
);
$form['nodes'][$row->nid]['title'] = array(
'#type' => 'item',
'#value' => check_plain($row->title),
);
$form['nodes'][$row->nid]['node_status'] = array(
'#type' => 'item',
'#value' => $row->node_status == 1 ? t('published') : t('unpublished'),
);
$form['nodes'][$row->nid]['visibility'] = array(
'#type' => 'item',
'#value' => htmlentities($row->visibility),
);
$form['nodes'][$row->nid]['weight'] = array(
'#type' => 'weight',
'#default_value' => $row->weight,
'#delta' => 30,
);
}
// Block delta
$form['delta'] = array(
'#type' => 'value',
'#value' => $block,
);
// Save button.
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Save'),
);
return $form;
}
/**
* Submit callback, save weights after queue submit.
*/
function nodesinblock_queue_submit($form, &$form_state) {
foreach ($form_state['values']['nodes'] as $node) {
db_query("UPDATE {nodesinblock} set weight = %d WHERE delta = %d AND nid = %d", $node['weight'], $form_state['values']['delta'], $node['nid']);
}
}
/**
* Theme queue form.
*/
function theme_nodesinblock_queue($form) {
$output = '';
$rows = array();
foreach (element_children($form['nodes']) as $nid) {
$element =& $form['nodes'][$nid];
$element['weight']['#attributes']['class'] = 'nodes-weight';
$row = array();
$row[] = drupal_render($element['title']);
$row[] = drupal_render($element['node_status']);
$row[] = drupal_render($element['visibility']);
$row[] = drupal_render($element['weight']);
$row[] = l(t('View'), 'node/' . $nid) . ' - ' . l(t('Edit'), 'node/' . $nid . '/edit', array(
'query' => drupal_get_destination(),
));
$row = array_merge(array(
'data' => $row,
), array());
$row['class'] = !empty($row['class']) ? $row['class'] . ' draggable' : 'draggable';
$rows[] = $row;
}
if (isset($form['blocklinks'])) {
$output .= drupal_render($form['blocklinks']);
}
if (isset($form['createlinks'])) {
$output .= drupal_render($form['createlinks']);
}
if ($rows) {
drupal_add_tabledrag('nodesinblock', 'order', 'sibling', 'nodes-weight');
$header = array(
t('Title'),
t('Node status'),
t('Visibility'),
t('Weight'),
t('Operations'),
);
$output .= theme('table', $header, $rows, array(
'id' => 'nodesinblock',
));
$output .= drupal_render($form);
}
else {
$output .= t('No nodes found.');
}
return $output;
}
Functions
Name | Description |
---|---|
nodesinblock_queue | Menu callback to look at the queue for nodes in block. |
nodesinblock_queue_submit | Submit callback, save weights after queue submit. |
nodesinblock_settings | Menu callback to configure general settings for nodes in block. |
nodesinblock_settings_clear_confirm | Menu callback: show confirmation screen to clear nodes in block settings. |
nodesinblock_settings_clear_confirm_submit | Submit callback: clear nodes in block settings. |
nodesinblock_settings_clear_redirect | Submit callback: clear settings, simply redirects to confirmation page. |
nodesinblock_settings_save | Submit callback: save settings. We use parts of system_settings_submit here to save the variables. |
theme_nodesinblock_queue | Theme queue form. |