[ Index ] |
PHP Cross Reference of BuddyPress |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * BuddyPress XProfile Classes. 4 * 5 * @package BuddyPress 6 * @subpackage XProfileClasses 7 * @since 2.0.0 8 */ 9 10 // Exit if accessed directly. 11 defined( 'ABSPATH' ) || exit; 12 13 /** 14 * Selectbox xprofile field type. 15 * 16 * @since 2.0.0 17 */ 18 class BP_XProfile_Field_Type_Selectbox extends BP_XProfile_Field_Type { 19 20 /** 21 * Constructor for the selectbox field type. 22 * 23 * @since 2.0.0 24 */ 25 public function __construct() { 26 parent::__construct(); 27 28 $this->category = _x( 'Multi Fields', 'xprofile field type category', 'buddypress' ); 29 $this->name = _x( 'Drop Down Select Box', 'xprofile field type', 'buddypress' ); 30 31 $this->supports_options = true; 32 33 $this->set_format( '/^.+$/', 'replace' ); 34 35 /** 36 * Fires inside __construct() method for BP_XProfile_Field_Type_Selectbox class. 37 * 38 * @since 2.0.0 39 * 40 * @param BP_XProfile_Field_Type_Selectbox $this Current instance of 41 * the field type select box. 42 */ 43 do_action( 'bp_xprofile_field_type_selectbox', $this ); 44 } 45 46 /** 47 * Output the edit field HTML for this field type. 48 * 49 * Must be used inside the {@link bp_profile_fields()} template loop. 50 * 51 * @since 2.0.0 52 * 53 * @param array $raw_properties Optional key/value array of 54 * {@link http://dev.w3.org/html5/markup/select.html permitted attributes} 55 * that you want to add. 56 */ 57 public function edit_field_html( array $raw_properties = array() ) { 58 59 // User_id is a special optional parameter that we pass to 60 // {@link bp_the_profile_field_options()}. 61 if ( isset( $raw_properties['user_id'] ) ) { 62 $user_id = (int) $raw_properties['user_id']; 63 unset( $raw_properties['user_id'] ); 64 } else { 65 $user_id = bp_displayed_user_id(); 66 } ?> 67 68 <legend id="<?php bp_the_profile_field_input_name(); ?>-1"> 69 <?php bp_the_profile_field_name(); ?> 70 <?php bp_the_profile_field_required_label(); ?> 71 </legend> 72 73 <?php 74 75 /** This action is documented in bp-xprofile/bp-xprofile-classes */ 76 do_action( bp_get_the_profile_field_errors_action() ); ?> 77 78 <select <?php echo $this->get_edit_field_html_elements( $raw_properties ); ?> aria-labelledby="<?php bp_the_profile_field_input_name(); ?>-1" aria-describedby="<?php bp_the_profile_field_input_name(); ?>-3"> 79 <?php bp_the_profile_field_options( array( 'user_id' => $user_id ) ); ?> 80 </select> 81 82 <?php if ( bp_get_the_profile_field_description() ) : ?> 83 <p class="description" id="<?php bp_the_profile_field_input_name(); ?>-3"><?php bp_the_profile_field_description(); ?></p> 84 <?php endif; ?> 85 86 <?php 87 } 88 89 /** 90 * Output the edit field options HTML for this field type. 91 * 92 * BuddyPress considers a field's "options" to be, for example, the items in a selectbox. 93 * These are stored separately in the database, and their templating is handled separately. 94 * 95 * This templating is separate from {@link BP_XProfile_Field_Type::edit_field_html()} because 96 * it's also used in the wp-admin screens when creating new fields, and for backwards compatibility. 97 * 98 * Must be used inside the {@link bp_profile_fields()} template loop. 99 * 100 * @since 2.0.0 101 * 102 * @param array $args Optional. The arguments passed to {@link bp_the_profile_field_options()}. 103 */ 104 public function edit_field_options_html( array $args = array() ) { 105 $original_option_values = maybe_unserialize( BP_XProfile_ProfileData::get_value_byid( $this->field_obj->id, $args['user_id'] ) ); 106 107 $options = $this->field_obj->get_children(); 108 $html = '<option value="">' . /* translators: no option picked in select box */ esc_html__( '----', 'buddypress' ) . '</option>'; 109 110 if ( empty( $original_option_values ) && !empty( $_POST['field_' . $this->field_obj->id] ) ) { 111 $original_option_values = sanitize_text_field( $_POST['field_' . $this->field_obj->id] ); 112 } 113 114 $option_values = ( $original_option_values ) ? (array) $original_option_values : array(); 115 for ( $k = 0, $count = count( $options ); $k < $count; ++$k ) { 116 $selected = ''; 117 118 // Check for updated posted values, but errors preventing them from 119 // being saved first time. 120 foreach( $option_values as $i => $option_value ) { 121 if ( isset( $_POST['field_' . $this->field_obj->id] ) && $_POST['field_' . $this->field_obj->id] != $option_value ) { 122 if ( ! empty( $_POST['field_' . $this->field_obj->id] ) ) { 123 $option_values[$i] = sanitize_text_field( $_POST['field_' . $this->field_obj->id] ); 124 } 125 } 126 } 127 128 // Run the allowed option name through the before_save filter, so 129 // we'll be sure to get a match. 130 $allowed_options = xprofile_sanitize_data_value_before_save( $options[$k]->name, false, false ); 131 132 // First, check to see whether the user-entered value matches. 133 if ( in_array( $allowed_options, $option_values ) ) { 134 $selected = ' selected="selected"'; 135 } 136 137 // Then, if the user has not provided a value, check for defaults. 138 if ( ! is_array( $original_option_values ) && empty( $option_values ) && $options[$k]->is_default_option ) { 139 $selected = ' selected="selected"'; 140 } 141 142 /** 143 * Filters the HTML output for options in a select input. 144 * 145 * @since 1.1.0 146 * 147 * @param string $value Option tag for current value being rendered. 148 * @param object $value Current option being rendered for. 149 * @param int $id ID of the field object being rendered. 150 * @param string $selected Current selected value. 151 * @param string $k Current index in the foreach loop. 152 */ 153 $html .= apply_filters( 'bp_get_the_profile_field_options_select', '<option' . $selected . ' value="' . esc_attr( stripslashes( $options[$k]->name ) ) . '">' . esc_html( stripslashes( $options[$k]->name ) ) . '</option>', $options[$k], $this->field_obj->id, $selected, $k ); 154 } 155 156 echo $html; 157 } 158 159 /** 160 * Output HTML for this field type on the wp-admin Profile Fields screen. 161 * 162 * Must be used inside the {@link bp_profile_fields()} template loop. 163 * 164 * @since 2.0.0 165 * 166 * @param array $raw_properties Optional key/value array of permitted attributes that you want to add. 167 */ 168 public function admin_field_html( array $raw_properties = array() ) { 169 ?> 170 171 <label for="<?php bp_the_profile_field_input_name(); ?>" class="screen-reader-text"><?php 172 /* translators: accessibility text */ 173 esc_html_e( 'Select', 'buddypress' ); 174 ?></label> 175 <select <?php echo $this->get_edit_field_html_elements( $raw_properties ); ?>> 176 <?php bp_the_profile_field_options(); ?> 177 </select> 178 179 <?php 180 } 181 182 /** 183 * Output HTML for this field type's children options on the wp-admin Profile Fields "Add Field" and "Edit Field" screens. 184 * 185 * Must be used inside the {@link bp_profile_fields()} template loop. 186 * 187 * @since 2.0.0 188 * 189 * @param BP_XProfile_Field $current_field The current profile field on the add/edit screen. 190 * @param string $control_type Optional. HTML input type used to render the current 191 * field's child options. 192 */ 193 public function admin_new_field_html( BP_XProfile_Field $current_field, $control_type = '' ) { 194 parent::admin_new_field_html( $current_field, 'radio' ); 195 } 196 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Sat Sep 7 01:00:55 2024 | Cross-referenced by PHPXref 0.7.1 |