'textfield', '#title' => t('Maximum length'), '#default_value' => $settings['max_length'], '#required' => FALSE, '#element_validate' => array('_element_validate_integer_positive'), '#description' => t('The maximum length of the field in characters. Leave blank for an unlimited size.'), ); return $form; } /** * Add settings to an instance field settings form. * * Invoked from field_ui_field_edit_form() to allow the module defining the * field to add settings for a field instance. * * @param $field * The field structure being configured. * @param $instance * The instance structure being configured. * * @return * The form definition for the field instance settings. */ function hook_field_instance_settings_form($field, $instance) { $settings = $instance['settings']; $form['text_processing'] = array( '#type' => 'radios', '#title' => t('Text processing'), '#default_value' => $settings['text_processing'], '#options' => array( t('Plain text'), t('Filtered text (user selects text format)'), ), ); if ($field['type'] == 'text_with_summary') { $form['display_summary'] = array( '#type' => 'select', '#title' => t('Display summary'), '#options' => array( t('No'), t('Yes'), ), '#description' => t('Display the summary to allow the user to input a summary value. Hide the summary to automatically fill it with a trimmed portion from the main post. '), '#default_value' => !empty($settings['display_summary']) ? $settings['display_summary'] : 0, ); } return $form; } /** * Add settings to a widget settings form. * * Invoked from field_ui_field_edit_form() to allow the module defining the * widget to add settings for a widget instance. * * @param $field * The field structure being configured. * @param $instance * The instance structure being configured. * * @return * The form definition for the widget settings. */ function hook_field_widget_settings_form($field, $instance) { $widget = $instance['widget']; $settings = $widget['settings']; if ($widget['type'] == 'text_textfield') { $form['size'] = array( '#type' => 'textfield', '#title' => t('Size of textfield'), '#default_value' => $settings['size'], '#element_validate' => array('_element_validate_integer_positive'), '#required' => TRUE, ); } else { $form['rows'] = array( '#type' => 'textfield', '#title' => t('Rows'), '#default_value' => $settings['rows'], '#element_validate' => array('_element_validate_integer_positive'), '#required' => TRUE, ); } return $form; } /** * Provide information on view mode tabs for an entity type. * * @param $entity_type * The type of entity to return tabs for. * * @return * An array whose keys are internal-use tab names, and whose values are * arrays of tab information, with the following elements: * - 'title': Human-readable title of the tab. * - 'view modes': Array of view modes for this entity type that should * be displayed on this tab. * * @see field_ui_view_modes_tabs() */ function hook_field_ui_view_modes_tabs($entity_type) { $modes = array( 'basic' => array( 'title' => t('Basic'), 'view modes' => array('teaser', 'full'), ), 'rss' => array( 'title' => t('RSS'), 'view modes' => array('rss'), ), 'print' => array( 'title' => t('Print'), 'view modes' => array('print'), ), 'search' => array( 'title' => t('Search'), 'view modes' => array('search_index', 'search_result'), ), ); return $modes; } /** * @} End of "ingroup field_ui_field_type" */