function node_clone_settings in Node clone 8
Menu callback to configure module settings.
1 string reference to 'node_clone_settings'
- NodeCloneSettings::getFormId in src/
Form/ NodeCloneSettings.php - Returns a unique string identifying the form.
File
- ./
node_clone.pages.inc, line 10 - Additional functions for Node_Clone module.
Code
function node_clone_settings($form, &$form_state) {
$form['basic'] = array(
'#type' => 'fieldset',
'#title' => t('General settings'),
);
$form['basic']['clone_method'] = array(
'#type' => 'radios',
'#title' => t('Method to use when cloning a node'),
'#options' => array(
'prepopulate' => t('Pre-populate the node form fields'),
'save-edit' => t('Save as a new node then edit'),
),
'#default_value' => \Drupal::config('node_clone.settings')
->get('node_clone_method'),
);
$form['basic']['clone_nodes_without_confirm'] = array(
'#type' => 'radios',
'#title' => t('Confirmation mode when using the "Save as a new node then edit" method'),
'#default_value' => (int) \Drupal::config('node_clone.settings')
->get('node_clone_nodes_without_confirm'),
'#options' => array(
t('Require confirmation (recommended)'),
t('Bypass confirmation'),
),
'#description' => t('A new node may be saved immediately upon clicking the "clone" link when viewing a node, bypassing the normal confirmation form.'),
'#states' => array(
// Only show this field when the clone method is save-edit.
'visible' => array(
':input[name="clone_method"]' => array(
'value' => 'save-edit',
),
),
),
);
// @FIXME
// // @FIXME
// // This looks like another module's variable. You'll need to rewrite this call
// // to ensure that it uses the correct configuration object.
// $form['basic']['clone_menu_links'] = array(
// '#type' => 'radios',
// '#title' => t('Clone menu links'),
// '#options' => array(0 => t('No'), 1 => t('Yes')),
// '#default_value' => (int) variable_get('clone_menu_links', 0),
// '#description' => t('Should any menu link for a node also be cloned?'),
// );
$form['basic']['clone_use_node_type_name'] = array(
'#type' => 'checkbox',
'#title' => t('Use node type name in clone link'),
'#default_value' => (int) \Drupal::config('node_clone.settings')
->get('node_clone_use_node_type_name'),
'#description' => t('If checked, the link to clone the node will contain the node type name, for example, "Clone this article", otherwise it will read "Clone content".'),
);
$form['publishing'] = array(
'#type' => 'fieldset',
'#title' => t('Should the publishing options ( e.g. published, promoted, etc) be reset to the defaults?'),
);
$types = node_type_get_names();
foreach ($types as $type => $name) {
// @FIXME
// // @FIXME
// // The correct configuration object could not be determined. You'll need to
// // rewrite this call manually.
// $form['publishing']['clone_reset_' . $type] = array(
// '#type' => 'checkbox',
// '#title' => t('@s: reset publishing options when cloned', array('@s' => $name)),
// '#default_value' => variable_get('node_clone_reset_' . $type, FALSE),
// );
}
// Need the variable default key to be something that's never a valid node type.
$form['omit'] = array(
'#type' => 'fieldset',
'#title' => t('Content types that are not to be cloned - omitted due to incompatibility'),
);
// @FIXME
// Could not extract the default value because it is either indeterminate, or
// not scalar. You'll need to provide a default value in
// config/install/node_clone.settings.yml and config/schema/node_clone.schema.yml.
$form['omit']['clone_omitted'] = array(
'#type' => 'checkboxes',
'#title' => t('Omitted content types'),
'#default_value' => \Drupal::config('node_clone.settings')
->get('node_clone_omitted'),
'#options' => $types,
'#description' => t('Select any node types which should <em>never</em> be cloned. In other words, all node types where cloning will fail.'),
);
return system_settings_form($form);
}