1.20.x date.admin.inc | _date_field_settings_form($field, $instance, $has_data) |
Helper function for date_field_settings_form().
See also
date_field_settings_validate()
File
- modules/
date/ date.admin.inc, line 482 - Admin page callbacks for the Date module.
Code
function _date_field_settings_form($field, $instance, $has_data) {
$settings = $field['settings'];
$form = array(
'#element_validate' => array('date_field_settings_validate'),
);
// Make sure granularity is in the right format and has no empty values.
if (!empty($settings['granularity']) && is_array($settings['granularity'])) {
$granularity = array_filter($settings['granularity']);
}
$tz_handling = $settings['tz_handling'];
$description = '';
if ($has_data) {
$description = t('Changing date granularity will affect only new or updated content.');
}
$options = date_granularity_names();
$checkbox_year = array(
'#type' => 'checkbox',
'#title' => check_plain($options['year']),
'#value' => 'year',
'#return_value' => 'year',
'#disabled' => TRUE,
);
unset($options['year']);
$form['granularity'] = array(
'#type' => 'checkboxes',
'#title' => t('Date granularity'),
'#default_value' => $granularity,
'#options' => $options,
'#attributes' => array(
'class' => array('container-inline'),
),
'#description' => $description,
'year' => $checkbox_year,
);
$description = t('End dates are used to collect duration, e.g. allow an event to start on September 15, and end on September 16.');
$form['enddate_get'] = array(
'#type' => 'checkbox',
'#title' => t('Collect an end date'),
'#description' => $description,
'#default_value' => (empty($settings['todate']) ? FALSE : TRUE),
'#disabled' => $has_data,
);
$form['enddate_required'] = array(
'#type' => 'checkbox',
'#title' => t('Required'),
'#default_value' => ((isset($settings['todate']) && $settings['todate'] === 'required') ? TRUE : FALSE),
'#disabled' => $has_data,
'#states' => array(
'invisible' => array(
'input[name="field[settings][enddate_get]"]' => array('checked' => FALSE),
),
),
);
$description = t('Select the timezone handling method for this date field.');
$form['tz_handling'] = array(
'#type' => 'select',
'#title' => t('Time zone handling'),
'#default_value' => $tz_handling,
'#options' => date_timezone_handling_options(),
'#description' => $description,
'#attached' => array(
'js' => array(backdrop_get_path('module', 'date') . '/js/date.admin.js'),
),
);
// Force this value to hidden because we don't want to allow it to be changed
// right now, but allow it to be a variable if needed.
$form['timezone_db'] = array(
'#type' => 'hidden',
'#value' => date_get_timezone_db($tz_handling),
);
$form['cache_enabled'] = array(
'#type' => 'checkbox',
'#title' => t('Cache dates'),
'#description' => t('Date objects can be created and cached as date fields are loaded rather than when they are displayed to improve performance.'),
'#default_value' => !empty($settings['cache_enabled']),
'#weight' => 10,
);
$form['cache_count'] = array(
'#type' => 'textfield',
'#title' => t('Maximum dates per field'),
'#default_value' => (isset($settings['cache_count'])) ? $settings['cache_count'] : 4,
'#description' => t("If set to '0', all date values on every entity will be cached. Note that caching every date on fields that may have a large number of multiple or repeating values may create a significant performance penalty when the cache is cleared. The suggested setting for multiple value and repeating fields is no more than 4 values per field."),
'#size' => 3,
'#weight' => 11,
'#states' => array(
'visible' => array(
'input[name="field[settings][cache_enabled]"]' => array(
'checked' => TRUE,
),
),
),
);
$context = array(
'field' => $field,
'instance' => $instance,
'has_data' => $has_data,
);
backdrop_alter('date_field_settings_form', $form, $context);
return $form;
}