function panels_page_advanced_form in Panels 5.2
Same name and namespace in other branches
- 6.2 panels_page/panels_page.admin.inc \panels_page_advanced_form()
The form to edit the advanced settings of a panel page.
1 string reference to 'panels_page_advanced_form'
- panels_page_edit_advanced in panels_page/
panels_page.admin.inc - Edit advanced settings of a panel page.
File
- panels_page/
panels_page.admin.inc, line 407 - panels_page.admin.inc
Code
function panels_page_advanced_form($panel_page, $next = NULL) {
drupal_add_css(panels_get_path('css/panels_admin.css'));
$form['panel_page'] = array(
'#type' => 'value',
'#value' => $panel_page,
);
$form['right'] = array(
'#prefix' => '<div class="right-container">',
'#suffix' => '</div>',
);
$form['left'] = array(
'#prefix' => '<div class="left-container">',
'#suffix' => '</div>',
);
$form['right']['advanced'] = array(
'#type' => 'fieldset',
'#collapsible' => FALSE,
'#collapsed' => FALSE,
'#title' => t('Advanced settings'),
);
$form['right']['advanced']['no_blocks'] = array(
'#type' => 'checkbox',
'#default_value' => $panel_page->no_blocks,
'#title' => t('Disable Drupal blocks/regions'),
'#description' => t('Check this to have the panel page disable all regions displayed in the theme.'),
);
$rids = array();
$result = db_query("SELECT r.rid, r.name FROM {role} r ORDER BY r.name");
while ($obj = db_fetch_object($result)) {
$rids[$obj->rid] = $obj->name;
}
$form['right']['advanced']['access'] = array(
'#type' => 'checkboxes',
'#title' => t('Access'),
'#default_value' => $panel_page->access,
'#options' => $rids,
'#description' => t('Only the checked roles will be able to see this panel in any form; if no roles are checked, access will not be restricted.'),
);
$form['right']['advanced']['css'] = array(
'#type' => 'textarea',
'#title' => t('CSS code'),
'#description' => t('Enter well-formed CSS code here; this code will be embedded into the page, and should only be used for minor adjustments; it is usually better to try to put CSS for the page into the theme if possible.'),
'#default_value' => $panel_page->css,
);
$form['left']['menu-info'] = array(
'#type' => 'fieldset',
'#collapsible' => FALSE,
'#title' => t('Menu'),
);
$form['left']['menu-info']['menu'] = array(
'#type' => 'checkbox',
'#title' => t('Provide Menu'),
'#return_value' => 1,
'#default_value' => $panel_page->menu,
'#description' => t('If checked this panel be given a menu entry in the Drupal menu system. If not checked the data in this group will be ignored.'),
);
$form['left']['menu-info']['menu_tab'] = array(
'#type' => 'checkbox',
'#title' => t('Provide Menu as Tab'),
'#return_value' => 1,
'#default_value' => $panel_page->menu_tab,
'#description' => t("If checked this panel's menu entry will be provided as a tab rather than in the main menu system."),
);
$form['left']['menu-info']['menu_tab_weight'] = array(
'#type' => 'textfield',
'#title' => t('Tab Weight'),
'#default_value' => $panel_page->menu_tab_weight,
'#size' => 5,
'#description' => t('If this is a menu tab, select the weight; lower numbers will be further to the left.'),
);
$form['left']['menu-info']['menu_title'] = array(
'#type' => 'textfield',
'#title' => t('Menu Title'),
'#default_value' => $panel_page->menu_title,
'#size' => 35,
'#maxlength' => 255,
'#description' => t('Enter the title to use for the menu entry or tab. If blank, the page title will be used.'),
);
$form['left']['menu-info']['default-tab'] = array(
'#type' => 'fieldset',
'#collapsible' => TRUE,
'#collapsed' => TRUE,
'#title' => t('Default Menu Tab'),
);
$form['left']['menu-info']['default-tab']['menu_tab_default'] = array(
'#type' => 'checkbox',
'#title' => t('Make Default Menu Tab'),
'#return_value' => 1,
'#default_value' => $panel_page->menu_tab_default,
'#description' => t("If checked this panel's menu entry will be provided as a tab, and will be the default tab for that URL path. For example, if the URL is 'tracker/all' and it is set as the default menu tab, it will be put into the menu as 'tracker' and 'tracker/all' will be the default tab. The following settings allow you to customize the parent item, for example 'tracker'. For tabs to work properly, one tab in the group must be set as the default."),
);
$form['left']['menu-info']['default-tab']['menu_tab_default_parent_type'] = array(
'#type' => 'select',
'#title' => t('Parent Menu Item Type'),
'#default_value' => $panel_page->menu_tab_default_parent_type,
'#options' => array(
'tab' => t("Tab"),
'normal' => t("Normal menu item"),
'existing' => t("Already exists (don't create)"),
),
'#description' => t("Select type of parent item to use for this default menu tab. You can either specify the parent should be a tab (the default), a normal menu item, or to use the menu item that already exists at the specified URL. For example, if the URL for the default tab is 'tracker/all', then 'tracker' would already have to be a valid menu item to use this final choice."),
);
$form['left']['menu-info']['default-tab']['menu_parent_tab_weight'] = array(
'#type' => 'textfield',
'#title' => t('Tab Weight'),
'#default_value' => $panel_page->menu_parent_tab_weight,
'#size' => 5,
'#description' => t('If the parent menu item is a tab, select the weight; lower numbers will be further to the left.'),
);
$form['left']['menu-info']['default-tab']['menu_parent_title'] = array(
'#type' => 'textfield',
'#title' => t('Parent Menu Item Title'),
'#default_value' => $panel_page->menu_parent_title,
'#size' => 35,
'#maxlength' => 255,
'#description' => t('If the Parent Menu Item is being defined by this panel (if you set the %type_field to either %tab or %menu), you can specify its title here. If blank, the menu title will be used if that is defined, or the page title if not.', array(
'%type_field' => t('Parent Menu Item Type'),
'%tab' => t('Tab'),
'%menu' => t('Normal menu item'),
)),
);
$label = $next ? t('Save and proceed') : t('Save');
$form['submit'] = array(
'#type' => 'submit',
'#value' => $label,
);
return $form;
}