'',
'form_key' => NULL,
'pid' => 0,
'weight' => 0,
'value' => '',
'mandatory' => 0,
'email' => 1,
'extra' => array(
'timezone' => 'site',
'check_daylight_savings' => 0,
'hourformat' => '12-hour',
'description' => '',
),
);
}
/**
* Create a set of form items to be displayed on the form for editing this component.
* Use care naming the form items, as this correlates directly to the database schema.
* The component "Name" and "Description" fields are added to every component type and
* are not necessary to specify here (although they may be overridden if desired).
* @return An array of form items to be displayed on the edit component page
*/
function _webform_edit_time($currfield) {
$edit_fields = array();
$edit_fields['value'] = array(
'#type' => 'textfield',
'#title' => t('Default value'),
'#default_value' => $currfield['value'],
'#description' => t('The default value of the field.') .'
'. t('Accepts a time in any GNU Date Input Format. Strings such as now, +2 hours, and 10:30pm are all valid.'),
'#size' => 60,
'#maxlength' => 127,
'#weight' => 0,
'#element_validate' => array('webform_validate_time_string'),
);
$edit_fields['extra']['timezone'] = array(
'#type' => 'radios',
'#title' => t('Timezone'),
'#default_value' => empty($currfield['extra']['timezone']) ? 'site' : $currfield['extra']['timezone'],
'#description' => t('Adjust the time according to a specific timezone. Website timezone is defined in the Site Settings and is the default.', array('!settings' => url('admin/settings/date-time'))),
'#options' => array('site' => 'Website Timezone', 'user' => 'User Timezone', 'gmt' => 'GMT'),
'#weight' => 0,
);
$edit_fields['extra']['check_daylight_savings'] = array(
'#type' => 'checkbox',
'#title' => t('Observe Daylight Savings'),
'#default_value' => $currfield['extra']['check_daylight_savings'],
'#checked_value' => 1,
'#description' => t('Automatically adjust the time during daylight savings.'),
'#weight' => 1,
);
$edit_fields['extra']['hourformat'] = array(
'#type' => 'radios',
'#title' => t('Time Format'),
'#default_value' => isset($currfield['extra']['hourformat']) ? $currfield['extra']['hourformat'] : '12-hour',
'#description' => t('Format the display of the time in 12 or 24 hours.'),
'#options' => array('12-hour' => '12-hour (am/pm)', '24-hour' => '24-hour'),
'#weight' => 2,
);
return $edit_fields;
}
/**
* Build a form item array containing all the properties of this component
* @param $component An array of information describing the component, directly correlating to the webform_component database schema
* @return An array of a form item to be displayed on the client-side webform
*/
function _webform_render_time($component) {
if (drupal_strlen($component['value']) > 0) {
// Calculate the timestamp in GMT.
$timestamp = strtotime($component['value']);
if ($component['extra']['timezone'] == 'user') {
// Use the users timezone.
global $user;
$timestamp += (int)$user->timezone;
}
elseif ($component['extra']['timezone'] == 'gmt') {
// Use GMT.
$timestamp += 0;
}
else {
// Use the Drupal site time.
$timestamp += (int)variable_get('date_default_timezone', 0);
}
// Check for daylight savings time.
if ($component['extra']['check_daylight_savings'] && date('I')) {
$timestamp += 3600;
}
}
if ($component['extra']['hourformat'] == '12-hour') {
$first_hour = 1;
$last_hour = 12;
$hour_format = 'g';
}
else {
$first_hour = 0;
$last_hour = 23;
$hour_format = 'G';
}
if (drupal_strlen($component['value']) > 0) {
$hour = gmdate($hour_format, $timestamp);
$minute = gmdate('i', $timestamp);
$am_pm = gmdate('a', $timestamp);
}
// Generate the choices for drop-down selects.
$hours[''] = t('hour');
$minutes[''] = t('minute');
for ($i = $first_hour; $i <= $last_hour; $i++) $hours[$i] = $i;
for ($i = 0; $i <= 59; $i++) $minutes[$i < 10 ? "0$i" : $i] = $i < 10 ? "0$i" : $i;
$am_pms = array('am' => t('am'), 'pm' => t('pm'));
$form_item = array(
'#title' => $component['name'],
'#required' => $component['mandatory'],
'#weight' => $component['weight'],
'#description' => _webform_filter_descriptions($component['extra']['description']),
'#prefix' => '
',
'#suffix' => '
',
'#theme' => 'webform_time',
'#element_validate' => array('webform_validate_time'),
'#webform_component' => $component,
);
$form_item['hour'] = array(
'#prefix' => '',
'#type' => 'select',
'#default_value' => $hour,
'#options' => $hours,
);
$form_item['minute'] = array(
'#prefix' => ':',
'#type' => 'select',
'#default_value' => $minute,
'#options' => $minutes,
);
if ($component['extra']['hourformat'] == '12-hour') {
$form_item['ampm'] = array(
'#type' => 'radios',
'#default_value' => $am_pm,
'#options' => $am_pms,
);
}
return $form_item;
}
function webform_validate_time($form_item, $form_state) {
$form_key = $form_item['#webform_component']['form_key'];
$name = $form_item['#webform_component']['name'];
// Check if the user filled the required fields.
foreach ($form_item['#webform_component'] == '12-hour' ? array('hour', 'minute', 'ampm') : array('hour', 'minute') as $field_type) {
if (!is_numeric($form_item[$field_type]['#value']) && $form_item['#required']) {
form_set_error($form_key, t('%field field is required.', array('%field' => $name)));
return;
}
}
// Check for a valid time.
if ($form_item['hour']['#value'] !== '' || $form_item['minute']['#value'] !== '' || (isset($form_item['ampm']) && $form_item['ampm']['#value'] !== '')) {
if (!is_numeric($form_item['hour']['#value']) || !is_numeric($form_item['minute']['#value']) || (isset($form_item['ampm']) && $form_item['ampm']['#value'] === '')) {
form_set_error($form_key, t('Entered %name is not a valid time.', array('%name' => $name)));
return;
}
}
}
/**
* Display the result of a textfield submission. The output of this function
* will be displayed under the "results" tab then "submissions".
* @param $data
* An array of information containing the submission result, directly
* correlating to the webform_submitted_data database schema.
* @param $component
* An array of information describing the component, directly correlating to
* the webform_component database schema.
* @param $enabled
* If enabled, the value may be changed. Otherwise it will set to readonly.
* @return
* Textual output formatted for human reading.
*/
function _webform_submission_display_time($data, $component, $enabled = FALSE) {
$form_item = _webform_render_time($component);
$form_item['minute']['#default_value'] = $data['value']['1'];
$form_item['minute']['#disabled'] = !$enabled;
$form_item['hour']['#disabled'] = !$enabled;
$form_item['ampm']['#disabled'] = !$enabled;
// Match the hourly data to the hour format.
if ($data['value']['1']) {
$timestamp = strtotime($data['value']['0'] .':'. $data['value']['1'] . (isset($data['value']['2']) ? $data['value']['2'] : ''));
if ($component['extra']['hourformat'] == '24-hour') {
$form_item['hour']['#default_value'] = date('H', $timestamp);
}
else {
$form_item['hour']['#default_value'] = date('g', $timestamp);
$form_item['ampm']['#default_value'] = $data['value']['2'];
}
}
return $form_item;
}
/**
* Format the output of emailed data for this component
*
* @param $data
* A string or array of the submitted data
* @param $component
* An array of information describing the component, directly correlating to
* the webform_component database schema.
* @return
* Textual output to be included in the email.
*/
function theme_webform_mail_time($data, $component) {
$output = $component['name'] .':';
if ($data['hour'] && $data['minute']) {
if ($component['extra']['hourformat'] == '24-hour') {
$output .= ' '. $data['hour'] .':'. $data['minute'];
}
else {
$output .= ' '. $data['hour'] .':'. $data['minute'] .' '. $data['ampm'];
}
}
return $output;
}
/**
* Module specific instance of hook_help().
*/
function _webform_help_time($section) {
switch ($section) {
case 'admin/settings/webform#time_description':
return t('Presents the user with hour and minute fields. Optional am/pm fields.');
}
}
/**
* Module specific instance of hook_theme().
*/
function _webform_theme_time() {
return array(
'webform_time' => array(
'arguments' => array('element' => NULL),
),
'webform_mail_time' => array(
'arguments' => array('data' => NULL, 'component' => NULL),
),
);
}
/**
* Calculate and returns statistics about results for this component from all
* submission to this webform. The output of this function will be displayed
* under the "results" tab then "analysis".
* @param $component
* An array of information describing the component, directly correlating to
* the webform_component database schema.
* @param $sids
* An optional array of submission IDs (sid). If supplied, the analysis will be limited
* to these sids.
* @return
* An array of data rows, each containing a statistic for this component's
* submissions.
*/
function _webform_analysis_rows_time($component, $sids = array()) {
$placeholders = count($sids) ? array_fill(0, count($sids), "'%s'") : array();
$sidfilter = count($sids) ? " AND sid in (".implode(",", $placeholders).")" : "";
$query = 'SELECT no,data '.
' FROM {webform_submitted_data} '.
' WHERE nid = %d '.
' AND cid = %d '. $sidfilter.
' ORDER BY sid,no ASC ';
$result = db_query($query, array_merge(array($component['nid'], $component['cid']), $sids));
// build an array of timestamps from entered values.
$timestamps = array();
$submissions = 0;
while ($row = db_fetch_array($result)) {
if ($row['no'] == '0') {
$submissions++;
$hour = $row['data'];
if ($row = db_fetch_array($result)) {
if ($row['no'] == '1') {
$minute = $row['data'];
if ($row = db_fetch_array($result)) {
if ($row['no'] == '2') {
$ampm = $row['data'];
// Build the full timestamp.
if (drupal_strlen($hour) > 0 && drupal_strlen($minute) > 0 ) {
$timestamps[] = strtotime($hour .':'. $minute .' '. $ampm);
}
}
else {
// Build military time.
$timestamps[] = strtotime($hour .':'. $minute);
}
}
}
}
}
}
// Display stats.
// TODO: display date statistics in javascript tabs.
$nonblanks = count($timestamps);
$rows[0] = array(t('Left Blank'), ($submissions - $nonblanks));
$rows[1] = array(t('User entered value'), $nonblanks);
return $rows;
}
/**
* Return the result of this component's submission for display in a table. The
* output of this function will be displayed under the "results" tab then "table".
* @param $data
* An array of information containing the submission result, directly
* correlating to the webform_submitted_data database schema.
* @return
* Textual output formatted for human reading.
*/
function _webform_table_data_time($data, $component) {
if (drupal_strlen($data['value']['0']) > 0 && drupal_strlen($data['value']['1']) > 0) {
$timestamp = strtotime($data['value']['0'] .':'. $data['value']['1'] . $data['value']['2']);
if ($component['extra']['hourformat'] == '24-hour') {
return check_plain(date('H:i', $timestamp));
}
else {
return check_plain(date('g:i a', $timestamp));
}
}
else {
return '';
}
}
/**
* Return the header information for this component to be displayed in a comma
* seperated value file. The output of this function will be displayed under the
* "results" tab then "download".
* @param $component
* An array of information describing the component, directly correlating to
* the webform_component database schema.
* @return
* An array of data to be displayed in the first three rows of a CSV file, not
* including either prefixed or trailing commas.
*/
function _webform_csv_headers_time($component) {
$header = array();
$header[0] = '';
$header[1] = '';
$header[2] = $component['name'];
return $header;
}
/**
* Return the result of a textfield submission. The output of this function will
* be displayed under the "results" tab then "submissions".
* @param $data
* An array of information containing the submission result, directly
* correlating to the webform_submitted_data database schema.
* @return
* Textual output formatted for CSV, not including either prefixed or trailing
* commas.
*/
function _webform_csv_data_time($data, $component) {
if (drupal_strlen($data['value']['0']) > 0 && drupal_strlen($data['value']['1']) > 0) {
$timestamp = strtotime($data['value']['0'] .':'. $data['value']['1'] . $data['value']['2']);
if ($component['extra']['hourformat'] == '24-hour') {
return date('H:i', $timestamp);
}
else {
return date('g:i a', $timestamp);
}
}
else {
return '';
}
}
/**
* Theme a webform time element.
*/
function theme_webform_time($element) {
$element['#type'] = 'element';
$element['#children'] = ''. drupal_render($element['hour']) . drupal_render($element['minute']) . drupal_render($element['ampm']) .'
';
return theme('form_element', $element, $element['#children']);
}