annotate sites/all/modules/webform/components/email.inc @ 0:ff03f76ab3fe

initial version
author danieleb <danielebarchiesi@me.com>
date Wed, 21 Aug 2013 18:51:11 +0100
parents
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Webform module email component.
danielebarchiesi@0 6 */
danielebarchiesi@0 7
danielebarchiesi@0 8 /**
danielebarchiesi@0 9 * Implements _webform_defaults_component().
danielebarchiesi@0 10 */
danielebarchiesi@0 11 function _webform_defaults_email() {
danielebarchiesi@0 12 return array(
danielebarchiesi@0 13 'name' => '',
danielebarchiesi@0 14 'form_key' => NULL,
danielebarchiesi@0 15 'pid' => 0,
danielebarchiesi@0 16 'weight' => 0,
danielebarchiesi@0 17 'value' => '',
danielebarchiesi@0 18 'mandatory' => 0,
danielebarchiesi@0 19 'extra' => array(
danielebarchiesi@0 20 'width' => '',
danielebarchiesi@0 21 'unique' => 0,
danielebarchiesi@0 22 'disabled' => 0,
danielebarchiesi@0 23 'title_display' => 0,
danielebarchiesi@0 24 'description' => '',
danielebarchiesi@0 25 'attributes' => array(),
danielebarchiesi@0 26 'private' => FALSE,
danielebarchiesi@0 27 ),
danielebarchiesi@0 28 );
danielebarchiesi@0 29 }
danielebarchiesi@0 30
danielebarchiesi@0 31 /**
danielebarchiesi@0 32 * Implements _webform_theme_component().
danielebarchiesi@0 33 */
danielebarchiesi@0 34 function _webform_theme_email() {
danielebarchiesi@0 35 return array(
danielebarchiesi@0 36 'webform_email' => array(
danielebarchiesi@0 37 'render element' => 'element',
danielebarchiesi@0 38 'file' => 'components/email.inc',
danielebarchiesi@0 39 ),
danielebarchiesi@0 40 'webform_display_email' => array(
danielebarchiesi@0 41 'render element' => 'element',
danielebarchiesi@0 42 'file' => 'components/email.inc',
danielebarchiesi@0 43 ),
danielebarchiesi@0 44 );
danielebarchiesi@0 45 }
danielebarchiesi@0 46
danielebarchiesi@0 47 /**
danielebarchiesi@0 48 * Implements _webform_edit_component().
danielebarchiesi@0 49 */
danielebarchiesi@0 50 function _webform_edit_email($component) {
danielebarchiesi@0 51 $form['value'] = array(
danielebarchiesi@0 52 '#type' => 'textfield',
danielebarchiesi@0 53 '#title' => t('Default value'),
danielebarchiesi@0 54 '#default_value' => $component['value'],
danielebarchiesi@0 55 '#description' => t('The default value of the field.') . theme('webform_token_help'),
danielebarchiesi@0 56 '#size' => 60,
danielebarchiesi@0 57 '#maxlength' => 127,
danielebarchiesi@0 58 '#weight' => 0,
danielebarchiesi@0 59 '#attributes' => ($component['value'] == '%useremail' && count(form_get_errors()) == 0) ? array('disabled' => TRUE) : array(),
danielebarchiesi@0 60 '#id' => 'email-value',
danielebarchiesi@0 61 );
danielebarchiesi@0 62 $form['user_email'] = array(
danielebarchiesi@0 63 '#type' => 'checkbox',
danielebarchiesi@0 64 '#title' => t('User email as default'),
danielebarchiesi@0 65 '#default_value' => $component['value'] == '%useremail' ? 1 : 0,
danielebarchiesi@0 66 '#description' => t('Set the default value of this field to the user email, if he/she is logged in.'),
danielebarchiesi@0 67 '#attributes' => array('onclick' => 'getElementById("email-value").value = (this.checked ? "%useremail" : ""); getElementById("email-value").disabled = this.checked;'),
danielebarchiesi@0 68 '#weight' => 0,
danielebarchiesi@0 69 '#element_validate' => array('_webform_edit_email_validate'),
danielebarchiesi@0 70 );
danielebarchiesi@0 71 $form['display']['width'] = array(
danielebarchiesi@0 72 '#type' => 'textfield',
danielebarchiesi@0 73 '#title' => t('Width'),
danielebarchiesi@0 74 '#default_value' => $component['extra']['width'],
danielebarchiesi@0 75 '#description' => t('Width of the textfield.') . ' ' . t('Leaving blank will use the default size.'),
danielebarchiesi@0 76 '#size' => 5,
danielebarchiesi@0 77 '#maxlength' => 10,
danielebarchiesi@0 78 '#parents' => array('extra', 'width'),
danielebarchiesi@0 79 );
danielebarchiesi@0 80 $form['display']['disabled'] = array(
danielebarchiesi@0 81 '#type' => 'checkbox',
danielebarchiesi@0 82 '#title' => t('Disabled'),
danielebarchiesi@0 83 '#return_value' => 1,
danielebarchiesi@0 84 '#description' => t('Make this field non-editable. Useful for setting an unchangeable default value.'),
danielebarchiesi@0 85 '#weight' => 11,
danielebarchiesi@0 86 '#default_value' => $component['extra']['disabled'],
danielebarchiesi@0 87 '#parents' => array('extra', 'disabled'),
danielebarchiesi@0 88 );
danielebarchiesi@0 89 $form['validation']['unique'] = array(
danielebarchiesi@0 90 '#type' => 'checkbox',
danielebarchiesi@0 91 '#title' => t('Unique'),
danielebarchiesi@0 92 '#return_value' => 1,
danielebarchiesi@0 93 '#description' => t('Check that all entered values for this field are unique. The same value is not allowed to be used twice.'),
danielebarchiesi@0 94 '#weight' => 1,
danielebarchiesi@0 95 '#default_value' => $component['extra']['unique'],
danielebarchiesi@0 96 '#parents' => array('extra', 'unique'),
danielebarchiesi@0 97 );
danielebarchiesi@0 98 return $form;
danielebarchiesi@0 99 }
danielebarchiesi@0 100
danielebarchiesi@0 101 /**
danielebarchiesi@0 102 * Element validation function for the email edit form.
danielebarchiesi@0 103 */
danielebarchiesi@0 104 function _webform_edit_email_validate($element, &$form_state) {
danielebarchiesi@0 105 if ($form_state['values']['user_email']) {
danielebarchiesi@0 106 $form_state['values']['value'] = '%useremail';
danielebarchiesi@0 107 }
danielebarchiesi@0 108 }
danielebarchiesi@0 109
danielebarchiesi@0 110 /**
danielebarchiesi@0 111 * Implements _webform_render_component().
danielebarchiesi@0 112 */
danielebarchiesi@0 113 function _webform_render_email($component, $value = NULL, $filter = TRUE) {
danielebarchiesi@0 114 global $user;
danielebarchiesi@0 115 $node = isset($component['nid']) ? node_load($component['nid']) : NULL;
danielebarchiesi@0 116
danielebarchiesi@0 117 $element = array(
danielebarchiesi@0 118 '#type' => 'webform_email',
danielebarchiesi@0 119 '#title' => $filter ? _webform_filter_xss($component['name']) : $component['name'],
danielebarchiesi@0 120 '#title_display' => $component['extra']['title_display'] ? $component['extra']['title_display'] : 'before',
danielebarchiesi@0 121 '#default_value' => $filter ? _webform_filter_values($component['value'], $node) : $component['value'],
danielebarchiesi@0 122 '#required' => $component['mandatory'],
danielebarchiesi@0 123 '#weight' => $component['weight'],
danielebarchiesi@0 124 '#description' => $filter ? _webform_filter_descriptions($component['extra']['description'], $node) : $component['extra']['description'],
danielebarchiesi@0 125 '#attributes' => $component['extra']['attributes'],
danielebarchiesi@0 126 '#element_validate' => array('_webform_validate_email'),
danielebarchiesi@0 127 '#theme_wrappers' => array('webform_element'),
danielebarchiesi@0 128 '#translatable' => array('title', 'description'),
danielebarchiesi@0 129 );
danielebarchiesi@0 130
danielebarchiesi@0 131 // Add an e-mail class for identifying the difference from normal textfields.
danielebarchiesi@0 132 $element['#attributes']['class'][] = 'email';
danielebarchiesi@0 133
danielebarchiesi@0 134 // Enforce uniqueness.
danielebarchiesi@0 135 if ($component['extra']['unique']) {
danielebarchiesi@0 136 $element['#element_validate'][] = 'webform_validate_unique';
danielebarchiesi@0 137 }
danielebarchiesi@0 138
danielebarchiesi@0 139 if (isset($value)) {
danielebarchiesi@0 140 $element['#default_value'] = $value[0];
danielebarchiesi@0 141 }
danielebarchiesi@0 142
danielebarchiesi@0 143 if ($component['extra']['disabled']) {
danielebarchiesi@0 144 if ($filter) {
danielebarchiesi@0 145 $element['#attributes']['readonly'] = 'readonly';
danielebarchiesi@0 146 }
danielebarchiesi@0 147 else {
danielebarchiesi@0 148 $element['#disabled'] = TRUE;
danielebarchiesi@0 149 }
danielebarchiesi@0 150 }
danielebarchiesi@0 151
danielebarchiesi@0 152 // Change the 'width' option to the correct 'size' option.
danielebarchiesi@0 153 if ($component['extra']['width'] > 0) {
danielebarchiesi@0 154 $element['#size'] = $component['extra']['width'];
danielebarchiesi@0 155 }
danielebarchiesi@0 156
danielebarchiesi@0 157 return $element;
danielebarchiesi@0 158 }
danielebarchiesi@0 159
danielebarchiesi@0 160 /**
danielebarchiesi@0 161 * Theme function to render an email component.
danielebarchiesi@0 162 */
danielebarchiesi@0 163 function theme_webform_email($variables) {
danielebarchiesi@0 164 $element = $variables['element'];
danielebarchiesi@0 165
danielebarchiesi@0 166 // This IF statement is mostly in place to allow our tests to set type="text"
danielebarchiesi@0 167 // because SimpleTest does not support type="email".
danielebarchiesi@0 168 if (!isset($element['#attributes']['type'])) {
danielebarchiesi@0 169 $element['#attributes']['type'] = 'email';
danielebarchiesi@0 170 }
danielebarchiesi@0 171
danielebarchiesi@0 172 // Convert properties to attributes on the element if set.
danielebarchiesi@0 173 foreach (array('id', 'name', 'value', 'size') as $property) {
danielebarchiesi@0 174 if (isset($element['#' . $property]) && $element['#' . $property] !== '') {
danielebarchiesi@0 175 $element['#attributes'][$property] = $element['#' . $property];
danielebarchiesi@0 176 }
danielebarchiesi@0 177 }
danielebarchiesi@0 178 _form_set_class($element, array('form-text', 'form-email'));
danielebarchiesi@0 179
danielebarchiesi@0 180 return '<input' . drupal_attributes($element['#attributes']) . ' />';
danielebarchiesi@0 181 }
danielebarchiesi@0 182
danielebarchiesi@0 183 /**
danielebarchiesi@0 184 * A Drupal Form API Validation function. Validates the entered values from
danielebarchiesi@0 185 * email components on the client-side form.
danielebarchiesi@0 186 *
danielebarchiesi@0 187 * @param $form_element
danielebarchiesi@0 188 * The e-mail form element.
danielebarchiesi@0 189 * @param $form_state
danielebarchiesi@0 190 * The full form state for the webform.
danielebarchiesi@0 191 * @return
danielebarchiesi@0 192 * None. Calls a form_set_error if the e-mail is not valid.
danielebarchiesi@0 193 */
danielebarchiesi@0 194 function _webform_validate_email($form_element, &$form_state) {
danielebarchiesi@0 195 $component = $form_element['#webform_component'];
danielebarchiesi@0 196 $value = trim($form_element['#value']);
danielebarchiesi@0 197 if ($value !== '' && !valid_email_address($value)) {
danielebarchiesi@0 198 form_error($form_element, t('%value is not a valid email address.', array('%value' => $value)));
danielebarchiesi@0 199 }
danielebarchiesi@0 200 else {
danielebarchiesi@0 201 form_set_value($form_element, $value, $form_state);
danielebarchiesi@0 202 }
danielebarchiesi@0 203 }
danielebarchiesi@0 204
danielebarchiesi@0 205 /**
danielebarchiesi@0 206 * Implements _webform_display_component().
danielebarchiesi@0 207 */
danielebarchiesi@0 208 function _webform_display_email($component, $value, $format = 'html') {
danielebarchiesi@0 209 return array(
danielebarchiesi@0 210 '#title' => $component['name'],
danielebarchiesi@0 211 '#weight' => $component['weight'],
danielebarchiesi@0 212 '#theme' => 'webform_display_email',
danielebarchiesi@0 213 '#theme_wrappers' => $format == 'html' ? array('webform_element') : array('webform_element_text'),
danielebarchiesi@0 214 '#format' => $format,
danielebarchiesi@0 215 '#value' => isset($value[0]) ? $value[0] : '',
danielebarchiesi@0 216 '#translatable' => array('title'),
danielebarchiesi@0 217 );
danielebarchiesi@0 218 }
danielebarchiesi@0 219
danielebarchiesi@0 220 /**
danielebarchiesi@0 221 * Format the text output for this component.
danielebarchiesi@0 222 */
danielebarchiesi@0 223 function theme_webform_display_email($variables) {
danielebarchiesi@0 224 $element = $variables['element'];
danielebarchiesi@0 225 $element['#value'] = empty($element['#value']) ? ' ' : $element['#value'];
danielebarchiesi@0 226 return $element['#format'] == 'html' ? check_plain($element['#value']) : $element['#value'];
danielebarchiesi@0 227 }
danielebarchiesi@0 228
danielebarchiesi@0 229 /**
danielebarchiesi@0 230 * Implements _webform_analysis_component().
danielebarchiesi@0 231 */
danielebarchiesi@0 232 function _webform_analysis_email($component, $sids = array()) {
danielebarchiesi@0 233 $query = db_select('webform_submitted_data', 'wsd', array('fetch' => PDO::FETCH_ASSOC))
danielebarchiesi@0 234 ->fields('wsd', array('no', 'data'))
danielebarchiesi@0 235 ->condition('nid', $component['nid'])
danielebarchiesi@0 236 ->condition('cid', $component['cid']);
danielebarchiesi@0 237
danielebarchiesi@0 238 if (count($sids)) {
danielebarchiesi@0 239 $query->condition('sid', $sids, 'IN');
danielebarchiesi@0 240 }
danielebarchiesi@0 241
danielebarchiesi@0 242 $nonblanks = 0;
danielebarchiesi@0 243 $submissions = 0;
danielebarchiesi@0 244 $wordcount = 0;
danielebarchiesi@0 245
danielebarchiesi@0 246 $result = $query->execute();
danielebarchiesi@0 247 foreach ($result as $data) {
danielebarchiesi@0 248 if (drupal_strlen(trim($data['data'])) > 0) {
danielebarchiesi@0 249 $nonblanks++;
danielebarchiesi@0 250 $wordcount += str_word_count(trim($data['data']));
danielebarchiesi@0 251 }
danielebarchiesi@0 252 $submissions++;
danielebarchiesi@0 253 }
danielebarchiesi@0 254
danielebarchiesi@0 255 $rows[0] = array(t('Left Blank'), ($submissions - $nonblanks));
danielebarchiesi@0 256 $rows[1] = array(t('User entered value'), $nonblanks);
danielebarchiesi@0 257 $rows[2] = array(t('Average submission length in words (ex blanks)'), ($nonblanks != 0 ? number_format($wordcount/$nonblanks, 2) : '0'));
danielebarchiesi@0 258 return $rows;
danielebarchiesi@0 259 }
danielebarchiesi@0 260
danielebarchiesi@0 261 /**
danielebarchiesi@0 262 * Implements _webform_table_component().
danielebarchiesi@0 263 */
danielebarchiesi@0 264 function _webform_table_email($component, $value) {
danielebarchiesi@0 265 return check_plain(empty($value[0]) ? '' : $value[0]);
danielebarchiesi@0 266 }
danielebarchiesi@0 267
danielebarchiesi@0 268
danielebarchiesi@0 269 /**
danielebarchiesi@0 270 * Implements _webform_csv_headers_component().
danielebarchiesi@0 271 */
danielebarchiesi@0 272 function _webform_csv_headers_email($component, $export_options) {
danielebarchiesi@0 273 $header = array();
danielebarchiesi@0 274 $header[0] = '';
danielebarchiesi@0 275 $header[1] = '';
danielebarchiesi@0 276 $header[2] = $component['name'];
danielebarchiesi@0 277 return $header;
danielebarchiesi@0 278 }
danielebarchiesi@0 279
danielebarchiesi@0 280 /**
danielebarchiesi@0 281 * Implements _webform_csv_data_component().
danielebarchiesi@0 282 */
danielebarchiesi@0 283 function _webform_csv_data_email($component, $export_options, $value) {
danielebarchiesi@0 284 return empty($value[0]) ? '' : $value[0];
danielebarchiesi@0 285 }