'textfield',
'#title' => t('Administrative title'),
'#description' => t('This will appear in the administrative interface to easily identify it.'),
'#default_value' => $panelizer->title,
);
}
// We only allow this setting on the "full page override" because it
// does not make sense in other modes.
if ($form_state['view_mode'] == 'page_manager') {
$form['no_blocks'] = array(
'#type' => 'checkbox',
'#default_value' => $panelizer->no_blocks,
'#title' => t('Disable Drupal blocks/regions'),
'#description' => t("Check this to have the display not show the theme's sidebars. Note that some themes support this setting better than others. If in doubt, try with stock themes to see."),
);
}
ctools_include('plugins', 'panels');
$pipelines = panels_get_renderer_pipelines();
// If there are no pipelines, that probably means we're operating in
// legacy mode.
if (empty($pipelines)) {
// We retain the original pipeline so we don't wreck things by installing
// old modules.
$form['pipeline'] = array(
'#type' => 'value',
'#value' => $panelizer->pipeline,
);
}
else {
$options = array();
foreach ($pipelines as $name => $pipeline) {
$options[$name] = check_plain($pipeline->admin_title) . '
' . check_plain($pipeline->admin_description) . '
';
}
$form['pipeline'] = array(
'#type' => 'radios',
'#options' => $options,
'#title' => t('Renderer'),
'#default_value' => $panelizer->pipeline,
);
}
if ($form_state['view_mode'] != 'page_manager') {
$form['title_element'] = array(
'#type' => 'textfield',
'#default_value' => $panelizer->title_element,
'#title' => t('Title element'),
'#description' => t('The HTML element to use for the entity title. Typically this will be an H2.'),
);
$form['link_to_entity'] = array(
'#type' => 'checkbox',
'#default_value' => $panelizer->link_to_entity,
'#title' => t('Link title to entity'),
'#description' => t('If checked the title will be a link to the entity.'),
);
$form['css_class'] = array(
'#type' => 'textfield',
'#size' => 35,
'#default_value' => $panelizer->css_class,
'#title' => t('CSS class'),
'#description' => t('The CSS class to apply to this display. You may use context substitions here.'),
);
}
else {
$form['css_class'] = array(
'#type' => 'textfield',
'#size' => 35,
'#default_value' => $panelizer->css_class,
'#title' => t('Body class'),
'#description' => t('The CSS class to apply to the BODY tag. You may use context substitions here.'),
);
}
$form['css_id'] = array(
'#type' => 'textfield',
'#size' => 35,
'#default_value' => $panelizer->css_id,
'#title' => t('CSS ID'),
'#description' => t('The CSS ID to apply to this display.'),
);
$form['css'] = array(
'#type' => 'textarea',
'#title' => t('CSS code'),
'#description' => t('Enter well-formed CSS code here; this code will be embedded into the display and should only be used for minor adjustments; it is usually better to try to put CSS for this display into the theme if possible. This CSS will be filtered for safety so some CSS may not work.'),
'#default_value' => $panelizer->css,
);
panelizer_add_revision_info_form($form, $form_state);
$form['actions'] = array(
'#type' => 'actions',
);
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save'),
);
return $form;
}
/**
* Submit callback
*/
function panelizer_settings_form_submit(&$form, &$form_state) {
$panelizer = $form_state['panelizer'];
if ($form_state['view_mode'] == 'page_manager') {
$panelizer->no_blocks = $form_state['values']['no_blocks'];
}
else {
$panelizer->title_element = $form_state['values']['title_element'];
}
$panelizer->css_class = $form_state['values']['css_class'];
$panelizer->css = $form_state['values']['css'];
$panelizer->css_id = $form_state['values']['css_id'];
$panelizer->pipeline = $form_state['values']['pipeline'];
// Behind an if because this value does not always exist.
if (isset($form_state['values']['link_to_entity'])) {
$panelizer->link_to_entity = $form_state['values']['link_to_entity'];
}
if (!empty($form_state['has title'])) {
$panelizer->title = $form_state['values']['title'];
}
// NOTE: We do not save in the submit so that the form can be re-used.
}
/**
* Mini form to add revision settings to a panelizer form so that
* we can properly handle revisioning.
*/
function panelizer_add_revision_info_form(&$form, &$form_state) {
if (empty($form_state['entity'])) {
return;
}
if (empty($form_state['revision info'])) {
return;
}
$entity = $form_state['entity'];
list($use_revisions, $control_revisions, $default_revision) = $form_state['revision info'];
if ($use_revisions) {
// @todo -- what if an entity uses some other flag to control revisioning?
if (!isset($entity->revision)) {
$entity->revision = $default_revision;
$entity->log = '';
}
$form_state['use revisions'] = TRUE;
$form['revision_information'] = array(
'#weight' => 11,
);
$form['revision_information']['revision'] = array(
'#type' => 'checkbox',
'#title' => t('Create new revision'),
'#default_value' => !empty($entity->revision),
'#id' => 'edit-revision',
'#access' => $control_revisions,
);
if ($control_revisions || $entity->revision) {
$form['revision_information']['log'] = array(
'#type' => 'textarea',
'#title' => t('Log message'),
'#description' => t('Provide an explanation of the changes you are making. This will help other authors understand your motivations.'),
'#default_value' => $entity->log,
);
if ($control_revisions) {
$form['revision_information']['log']['#dependency'] = array('edit-revision' => array(1));
}
}
// Don't override the existing submit, eh?
if (!empty($form_state['input']['form_id']) && empty($form['#submit']) && function_exists($form_state['input']['form_id'] . '_submit')) {
$form['#submit'][] = $form_state['input']['form_id'] . '_submit';
}
// The submit handler needs to go in a different location depending on
// what form this is.
$submit_handler = 'panelizer_add_revision_info_form_submit';
if (!empty($form['buttons']['submit']['#submit'])) {
$form['buttons']['submit']['#submit'][] = $submit_handler;
}
elseif (!empty($form['buttons']['return']['#submit'])) {
$form['buttons']['return']['#submit'][] = $submit_handler;
}
else {
$form['#submit'][] = $submit_handler;
}
}
}
/**
* Form submission callback for panelizer_add_revision_info_form().
*/
function panelizer_add_revision_info_form_submit(&$form, &$form_state) {
$entity = &$form_state['entity'];
if (!empty($form_state['use revisions'])) {
$entity->revision = $form_state['values']['revision'];
$entity->log = $form_state['values']['log'];
}
}
/**
* Form to edit contexts that go with a Panelizer display.
*/
function panelizer_default_context_form($form, &$form_state) {
ctools_include('context-admin');
ctools_context_admin_includes();
$panelizer = &$form_state['panelizer'];
if (!empty($panelizer->cached)) {
$form['markup'] = array(
'#prefix' => '',
'#markup' => t('This form contains unsaved changes that will not be stored until the Save button is clicked.'),
'#suffix' => '
',
);
}
$form['right'] = array(
'#prefix' => '',
'#suffix' => '
',
);
$form['left'] = array(
'#prefix' => '
',
'#suffix' => '
',
);
$module = 'panelizer_context::' . $form_state['panelizer type'];
ctools_context_add_context_form($module, $form, $form_state, $form['right']['contexts_table'], $panelizer, $form_state['cache key']);
ctools_context_add_relationship_form($module, $form, $form_state, $form['right']['relationships_table'], $panelizer, $form_state['cache key']);
// Set an additional description if CCK and Token are enabled, to notify of unlisted keywords
if (!module_exists('token')) {
$description = t('More keywords will be available if you install the Token module, see http://drupal.org/project/token.');
}
else {
$description = '';
}
$form['left']['summary'] = array(
'#prefix' => '',
'#suffix' => '
',
'#markup' => theme('ctools_context_list', array(
'object' => $panelizer,
'header' => t('Summary of contexts'),
'description' => $description,
)),
);
panelizer_add_revision_info_form($form, $form_state);
$form['actions'] = array(
'#type' => 'actions'
);
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save'),
'#write' => TRUE,
);
$form['actions']['cancel'] = array(
'#type' => 'submit',
'#value' => t('Cancel'),
);
return $form;
}
/**
* Form used when an entity bundle is panelized but there is no default
* display. Entities are then individually panelized.
*/
function panelizer_panelize_entity_form($form, &$form_state) {
$entity_type = $form_state['panelizer']->panelizer_type;
$entity_info = entity_get_info($entity_type);
$form = array();
$form['markup'] = array(
'#markup' => '' . t('This %entity is not currently panelized.', array('%entity' => $entity_info['label'])) . '
',
);
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Panelize it!'),
);
return $form;
}
/**
* Form used when an entity is panelized and is being reset.
*/
function panelizer_reset_entity_form($form, &$form_state) {
$entity_type = $form_state['panelizer']->entity_type;
$entity_info = entity_get_info($entity_type);
$form = array();
// Build the confirmation form.
$form = confirm_form(
$form,
t('Are you sure you want to reset the panelizer status for this %entity?', array('%entity' => $entity_info['label'])),
dirname(dirname($_GET['q'])),
t('This %entity will be reset to the default panelizer state, discarding any modifications made to it. This action cannot be undone.', array('%entity' => $entity_info['label'])),
t('Reset'),
t('Cancel'),
'panelizer_reset_entity_confirm');
// Append the revision form.
panelizer_add_revision_info_form($form, $form_state);
return $form;
}
/**
* Panelizer layout change form. If there is no content this will be
* a 'choose' layout form. If there is content it will be a 'change' layout
* form.
*
* @param $form_state
* The initial form state array to be used by the wizard. This *must* contain:
* - 'display': The display whose layout should be changed.
* - 'wizard path': The Drupal path where this wizard lives, so it knows where
* to redirect to. Note that the layout chosen will be appended to this
* path for the second step, so the page callback for this wizard needs to
* make sure to pass that through when teh function is called.
*
* This can also contain:
* - 'allowed_layouts' => The key to the allowed layouts array to use.
* - 'finish' => The text to use on the save button.
*
* @param $step
* The wizard step that must be passed through. It should be in the %step
* portion of the path.
*
* @param $layout
* A layout that is chosen in the first step. It is passed through the URL
* so that no caching is needed. The caller needs to be sure to extract this
* from the URL.
*
* @return
* While the return value is render array, if $form_state['complete'] is
* true, then$form_state['display'] can be saved by the caller and
* redirection chosen. If $form_state['cancel'] is true, then the display
* should not be saved.
*/
function panelizer_change_layout_wizard(&$form_state, $step = 'choose', $layout = NULL) {
ctools_include('common', 'panels');
// Add defaults to the form state sent in.
$form_state += array(
'finish' => t('Save'),
'allowed_layouts' => '',
'no_redirect' => TRUE,
'no buttons' => TRUE,
'layout' => $layout,
);
$form_info = array(
'id' => 'panelizer_change_layout_wizard',
'finish text' => $form_state['finish'],
'path' => $form_state['wizard path'],
'show back' => TRUE,
'order' => array(
'choose' => t('Choose layout'),
),
'forms' => array(
'choose' => array(
'form id' => 'panelizer_choose_layout_form',
),
'move' => array(
'form id' => 'panelizer_move_content_form',
),
),
);
if (!empty($form_state['display']->content)) {
$form_info['order']['move'] = t('Move content');
}
ctools_include('common', 'panels');
ctools_include('display-layout', 'panels');
ctools_include('plugins', 'panels');
ctools_include('wizard');
$output = ctools_wizard_multistep_form($form_info, $step, $form_state);
if (!empty($form_state['complete'])) {
$form_state['display']->layout = $form_state['layout'];
}
return $output;
}
function panelizer_choose_layout_form($form, &$form_state) {
// Change the #id of the form so the CSS applies properly.
$form['#id'] = 'panels-choose-layout';
$form = panels_choose_layout($form, $form_state);
if (!empty($form['buttons']['return'])) {
panelizer_add_revision_info_form($form, $form_state);
}
return $form;
}
function panelizer_choose_layout_form_validate(&$form, &$form_state) {
if ($form_state['values']['layout'] == $form_state['display']->layout) {
form_error($form['layout'], t('You must select a different layout if you wish to change layouts.'));
}
}
function panelizer_choose_layout_form_submit(&$form, &$form_state) {
$form_state['layout'] = $form_state['values']['layout'];
$form_state['form_info']['path'] .= '/' . $form_state['values']['layout'];
}
function panelizer_move_content_form($form, &$form_state) {
// Tell the Panels form not to display buttons.
$form_state['no buttons'] = TRUE;
// Change the #id of the form so the CSS applies properly.
$form = panels_change_layout($form, $form_state);
$form['buttons']['return']['#submit'][] = 'panels_change_layout_submit';
panelizer_add_revision_info_form($form, $form_state);
return $form;
}
function panelizer_edit_content_form($form, &$form_state) {
ctools_include('ajax');
ctools_include('plugins', 'panels');
ctools_include('display-edit', 'panels');
ctools_include('context');
$cache = $form_state['display cache'];
$form_state['renderer'] = panels_get_renderer_handler('editor', $cache->display);
$form_state['renderer']->cache = $cache;
$form_state['display'] = &$cache->display;
$form_state['content_types'] = $cache->content_types;
$form_state['display_title'] = TRUE;
$form = panels_edit_display_form($form, $form_state);
panelizer_add_revision_info_form($form, $form_state);
$form['preview']['#weight'] = 100;
return $form;
}