function add_to_head_edit_profile in Add To Head 7
Same name and namespace in other branches
- 6 add_to_head.admin.inc \add_to_head_edit_profile()
This function provides the edit form. The Add Profile form also uses this.
See also
2 string references to 'add_to_head_edit_profile'
- add_to_head_forms in ./
add_to_head.module - Implements hook_forms().
- add_to_head_menu in ./
add_to_head.module - Implements hook_menu().
File
- ./
add_to_head.admin.inc, line 70 - This file contains all the admin-related callbacks
Code
function add_to_head_edit_profile($form, &$form_state, $profile = array()) {
// Fill in profile defaults to ensure all keys exist.
$profile += array(
'name' => '',
'code' => '',
'path_visibility' => '',
'paths' => '',
'scope' => '',
'roles' => array(
'visibility' => 0,
'list' => array(),
),
);
$profile['roles']['visibility'] = empty($profile['roles']['visibility']) ? 0 : $profile['roles']['visibility'];
$profile['roles']['list'] = is_array($profile['roles']['list']) ? $profile['roles']['list'] : array();
$form['name_orig'] = array(
'#type' => 'value',
'#value' => $profile['name'],
);
$form['name'] = array(
'#type' => 'textfield',
'#title' => t('Name'),
'#description' => t('This is the unique name for this profile'),
'#required' => TRUE,
'#default_value' => $profile['name'],
);
$form['code'] = array(
'#type' => 'textarea',
'#title' => t('Code'),
'#description' => t('Enter the code you would like to insert into the head of the page'),
'#required' => TRUE,
'#default_value' => $profile['code'],
'#wysiwyg' => FALSE,
);
$form['path_visibility'] = array(
'#type' => 'radios',
'#title' => t('Embed code on specific pages'),
'#options' => array(
0 => t('Show on every page except the listed pages.'),
1 => t('Show on only the listed pages.'),
),
'#default_value' => $profile['path_visibility'],
);
$form['paths'] = array(
'#type' => 'textarea',
'#title' => t('Paths'),
'#description' => t("Enter one page per line as Drupal paths. The '*' character is a wildcard. Example paths are %blog for the blog page and %blog-wildcard for every personal blog. %front is the front page.", array(
'%blog' => 'blog',
'%blog-wildcard' => 'blog/*',
'%front' => '<front>',
)),
'#default_value' => $profile['paths'],
'#wysiwyg' => FALSE,
);
// Render the Roles overview.
$form['roles'] = array(
'#type' => 'fieldset',
'#title' => t('Roles'),
'#tree' => TRUE,
);
$form['roles']['visibility'] = array(
'#type' => 'radios',
'#title' => t('Embed code for specific roles'),
'#options' => array(
0 => t('Add for the selected roles only'),
1 => t('Add for every role except the selected ones'),
),
'#default_value' => $profile['roles']['visibility'],
);
$form['roles']['list'] = array(
'#type' => 'checkboxes',
'#title' => t('Selected roles'),
'#default_value' => $profile['roles']['list'],
'#options' => array_map('check_plain', user_roles()),
'#description' => t('If none of the roles are selected, all roles will have the code displayed. If a user has any of the roles checked, that user will be have the code displayed (or not, depending on the setting above).'),
);
$form['scope'] = array(
'#type' => 'radios',
'#title' => t('Scope of addition'),
'#description' => t('Which section of the head would you like this snippet appended to?'),
'#options' => array(
'head' => t('Head - This appears early on in the head (before any CSS and JS are included)'),
'styles' => t('Styles - It will be appended to the CSS files section. This is usually before any other JS is included.'),
'scripts' => t('Scripts - It will be appended to the Javascripts section. This can, sometimes, be in the footer of the document depending on the theme.'),
),
'#default_value' => $profile['scope'],
);
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Save'),
);
return $form;
}