admin.inc in Panelizer 7
Same filename and directory in other branches
Contains administrative forms and settings.
File
includes/admin.incView source
<?php
/**
* @file
* Contains administrative forms and settings.
*/
/**
* Primary settings page.
*
* This settings page allows the administrator to select which node types
* can be panelized, whether they have a default, and provides links to
* edit those defaults.
*/
function panelizer_settings_page_form($form, &$form_state) {
ctools_include('dependent');
$form = array();
$task = page_manager_get_task('node_view');
if (!empty($task->disabled)) {
drupal_set_message('The node template page is currently not enabled in page manager. You must enable this for Panelizer to be able to panelize nodes.', 'warning');
}
$handler = page_manager_load_task_handler($task, '', 'node_view_panelizer');
if (!empty($handler->disabled)) {
drupal_set_message('The panelizer variant on the node template page is currently not enabled in page manager. You must enable this for Panelizer to be able to panelize nodes.', 'warning');
}
$form['types'] = array(
'#tree' => TRUE,
);
// Add 'node' settings
$form['types']['node'] = array(
'#theme' => 'panelizer_node_settings_page_form',
);
$types = node_type_get_names();
$context = 'node';
drupal_alter('panelizer_default_types', $types, $context);
foreach ($types as $type => $title) {
$base_id = str_replace(array(
'][',
'_',
' ',
), '-', '#edit-types-node-' . $type);
$base_url = 'admin/config/content/panelizer/node/' . $type;
$settings = variable_get('panelizer_defaults_node_' . $type, array());
$form['types']['node'][$type]['title'] = array(
'#markup' => $title,
);
$form['types']['node'][$type]['status'] = array(
'#type' => 'checkbox',
'#default_value' => !empty($settings['status']),
);
$form['types']['node'][$type]['default'] = array(
'#type' => 'checkbox',
'#default_value' => !empty($settings['default']),
'#states' => array(
'visible' => array(
$base_id . '-status' => array(
'checked' => TRUE,
),
),
),
);
$form['types']['node'][$type]['choice'] = array(
'#type' => 'checkbox',
'#default_value' => !empty($settings['choice']),
'#status' => array(
'visible' => array(
$base_id . '-status' => array(
'checked' => TRUE,
),
),
),
'#access' => FALSE,
);
$form['types']['node'][$type]['links'] = array(
'#prefix' => '<div class="container-inline">',
'#suffix' => '</div>',
);
// Panelize is on all content types get this option
$links = array(
'settings' => array(
'title' => t('allowed content'),
'href' => $base_url . '/allowed',
),
);
$form['types']['node'][$type]['links']['basic'] = array(
'#type' => 'item',
'#title' => theme('links', array(
'links' => $links,
'attributes' => array(
'class' => 'links inline',
),
)),
'#states' => array(
'visible' => array(
$base_id . '-status' => array(
'checked' => TRUE,
),
),
),
);
// Panelize is enabled and a default panel will be provided
$links = array(
'settings' => array(
'title' => t('settings'),
'href' => $base_url . '/settings',
),
'context' => array(
'title' => t('context'),
'href' => $base_url . '/context',
),
'layout' => array(
'title' => t('layout'),
'href' => $base_url . '/layout',
),
'content' => array(
'title' => t('content'),
'href' => $base_url . '/content',
),
);
$form['types']['node'][$type]['links']['default'] = array(
'#type' => 'item',
'#title' => theme('links', array(
'links' => $links,
'attributes' => array(
'class' => 'links inline',
),
)),
'#states' => array(
'visible' => array(
$base_id . '-default' => array(
'checked' => TRUE,
),
),
),
);
/*
$links = array(
'list' => array(
'title' => t('list'),
'href' => $base_url . '/list',
),
);
$form['types']['node'][$type]['links']['default2'] = array(
'#type' => 'item',
'#title' => theme('links', array(
'links' => $links,
'attributes' => array('class' => 'links inline'),
)),
'#states' => array(
'visible' => array(
$base_id . '-status' => array('checked' => TRUE),
$base_id . '-choice' => array('checked' => TRUE),
),
),
);
*/
}
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Save'),
);
return $form;
}
/**
* Format the output of the main settings form.
*
* We want our checkboxes to show up in a table.
*/
function theme_panelizer_node_settings_page_form($variables) {
$element = $variables['form'];
// Render the 'node' table
$header = array(
t('Node type'),
t('Panelize'),
t('Provide default panel'),
t('Operations'),
);
$rows = array();
foreach (element_children($element) as $type) {
$rows[] = array(
drupal_render($element[$type]['title']),
drupal_render($element[$type]['status']),
drupal_render($element[$type]['default']),
drupal_render($element[$type]['links']),
);
}
$output = theme('table', array(
'header' => $header,
'rows' => $rows,
));
// Render everything else
$output .= drupal_render_children($element);
return $output;
}
/**
* Submit callback for the main panelizer settings form.
*/
function panelizer_settings_page_form_submit($form, &$form_state) {
$types = $form_state['values']['types'];
foreach ($types as $entity => $bundles) {
foreach ($bundles as $bundle => $values) {
variable_set('panelizer_defaults_' . $entity . '_' . $bundle, $values);
}
}
}
/**
* Page to configure what content is available for a given node type.
*/
function panelizer_allowed_content_page($type, $key) {
if (!panelizer_is_panelized($type, $key)) {
return MENU_NOT_FOUND;
}
ctools_include('common', 'panels');
return drupal_get_form('panels_common_settings', 'panelizer_' . $type . ':' . $key);
}
/**
* Page to list available panelizer defaults for a given type and key combo.
*/
function panelizer_default_list_page($type, $key) {
return 'placeholder';
}
/**
* Page to configure basic settings for a panelizer default.
*/
function panelizer_default_settings_page($type, $key, $name) {
$panelizer = panelizer_load_default($type, $key, $name);
if (empty($panelizer)) {
return MENU_NOT_FOUND;
}
$form_state = array(
'panelizer' => &$panelizer,
'no_redirect' => TRUE,
'reset button' => TRUE,
);
ctools_include('common', 'panelizer');
$output = drupal_build_form('panelizer_settings_form', $form_state);
if (!empty($form_state['executed'])) {
if (empty($form_state['clicked_button']['#reset'])) {
ctools_include('export');
ctools_export_crud_save('panelizer_defaults', $panelizer);
drupal_set_message(t('The settings have been updated.'));
}
else {
panelizer_delete_panelizer_defaults($panelizer);
drupal_set_message(t('The panelizer settings have been reset to the default.'));
}
drupal_goto($_GET['q']);
}
return $output;
}
/**
* Delete a panelizer node panel from the database.
*/
function panelizer_delete_panelizer_defaults($panelizer) {
if (!empty($panelizer->pnid)) {
if (!empty($panelizer->did)) {
panels_delete_display($panelizer->did);
}
db_delete('panelizer_defaults')
->condition('pnid', $panelizer->pnid)
->execute();
}
}
/**
* Page to configure what content is available for a given node type.
*/
function panelizer_default_context_page($type, $key, $name) {
$cache_key = $type . ':' . $key . ':' . $name;
$panelizer = panelizer_context_cache_get('default', $cache_key);
if (empty($panelizer)) {
return MENU_NOT_FOUND;
}
$form_state = array(
'panelizer' => &$panelizer,
'panelizer type' => 'default',
'panelizer id' => $type,
'cache key' => $cache_key,
'no_redirect' => TRUE,
);
ctools_include('common', 'panelizer');
$output = drupal_build_form('panelizer_default_context_form', $form_state);
if (!empty($form_state['executed'])) {
if (!empty($form_state['clicked_button']['#write'])) {
drupal_set_message(t('The settings have been updated.'));
ctools_include('export');
ctools_export_crud_save('panelizer_defaults', $panelizer);
}
else {
drupal_set_message(t('Changes have been discarded.'));
}
panelizer_context_cache_clear('default', $cache_key);
drupal_goto($_GET['q']);
}
return $output;
}
/**
* Pass through to the panels layout editor.
*/
function panelizer_default_layout_page($type, $key, $name) {
$panelizer = panelizer_load_default($type, $key, $name);
if (empty($panelizer)) {
return MENU_NOT_FOUND;
}
$display = panelizer_load_display($panelizer);
ctools_include('context');
$display->context = panelizer_get_contexts($panelizer);
$output = panels_edit_layout($display, t('Save'), '', 'panelizer_' . $type . ':' . $key);
if (is_object($output)) {
// The display was already saved, but if we were given a did, that
// needs to be saved too.
if ($panelizer->did != $output->did) {
ctools_include('export');
$panelizer->did = $output->did;
// Ensure we don't try to write again:
if (isset($panelizer->display)) {
unset($panelizer->display);
}
ctools_export_crud_save('panelizer_defaults', $panelizer);
}
drupal_goto($_GET['q']);
}
return $output;
}
/**
* Pass through to the panels content editor.
*/
function panelizer_default_content_page($type, $key, $name) {
$panelizer = panelizer_load_default($type, $key, $name);
if (empty($panelizer)) {
return MENU_NOT_FOUND;
}
$cache = panels_edit_cache_get('panelizer:default:' . $type . ':' . $key . ':' . $name);
ctools_include('plugins', 'panels');
ctools_include('display-edit', 'panels');
ctools_include('context');
$renderer = panels_get_renderer_handler('editor', $cache->display);
$renderer->cache = $cache;
$output = $renderer
->edit();
if (is_object($output)) {
// The display was already saved, but if we were given a did, that
// needs to be saved too.
if ($panelizer->did != $output->did) {
ctools_include('export');
$panelizer->did = $output->did;
// Ensure we don't try to write again:
if (isset($panelizer->display)) {
unset($panelizer->display);
}
ctools_export_crud_save('panelizer_defaults', $panelizer);
}
panels_edit_cache_clear($cache);
drupal_goto($_GET['q']);
}
return $output;
}
Functions
Name | Description |
---|---|
panelizer_allowed_content_page | Page to configure what content is available for a given node type. |
panelizer_default_content_page | Pass through to the panels content editor. |
panelizer_default_context_page | Page to configure what content is available for a given node type. |
panelizer_default_layout_page | Pass through to the panels layout editor. |
panelizer_default_list_page | Page to list available panelizer defaults for a given type and key combo. |
panelizer_default_settings_page | Page to configure basic settings for a panelizer default. |
panelizer_delete_panelizer_defaults | Delete a panelizer node panel from the database. |
panelizer_settings_page_form | Primary settings page. |
panelizer_settings_page_form_submit | Submit callback for the main panelizer settings form. |
theme_panelizer_node_settings_page_form | Format the output of the main settings form. |