name = 'checkbox'; $this->label = __("Checkbox",'acf'); $this->category = 'choice'; $this->defaults = array( 'layout' => 'vertical', 'choices' => array(), 'default_value' => '', 'toggle' => 0, 'return_format' => 'value' ); // do not delete! parent::__construct(); } /* * render_field() * * Create the HTML interface for your field * * @param $field (array) the $field being rendered * * @type action * @since 3.6 * @date 23/01/13 * * @param $field (array) the $field being edited * @return n/a */ function render_field( $field ) { // decode value (convert to array) $field['value'] = acf_get_array($field['value'], false); // hiden input acf_hidden_input( array('name' => $field['name']) ); // vars $i = 0; $li = ''; $all_checked = true; // checkbox saves an array $field['name'] .= '[]'; // foreach choices if( !empty($field['choices']) ) { foreach( $field['choices'] as $value => $label ) { // increase counter $i++; // vars $atts = array( 'type' => 'checkbox', 'id' => $field['id'], 'name' => $field['name'], 'value' => $value, ); // is choice selected? if( in_array($value, $field['value']) ) { $atts['checked'] = 'checked'; } else { $all_checked = false; } if( isset($field['disabled']) && acf_in_array($value, $field['disabled']) ) { $atts['disabled'] = 'disabled'; } // each input ID is generated with the $key, however, the first input must not use $key so that it matches the field's label for attribute if( $i > 1 ) { $atts['id'] .= '-' . $value; } // append HTML $li .= '
  • '; } // toggle all if( $field['toggle'] ) { // vars $label = __("Toggle All", 'acf'); $atts = array( 'type' => 'checkbox', 'class' => 'acf-checkbox-toggle' ); // custom label if( is_string($field['toggle']) ) { $label = $field['toggle']; } // checked if( $all_checked ) { $atts['checked'] = 'checked'; } // append HTML $li = '
  • ' . $li; } } // class $field['class'] .= ' acf-checkbox-list'; $field['class'] .= ($field['layout'] == 'horizontal') ? ' acf-hl' : ' acf-bl'; // return echo ''; } /* * render_field_settings() * * Create extra options for your field. This is rendered when editing a field. * The value of $field['name'] can be used (like bellow) to save extra data to the $field * * @type action * @since 3.6 * @date 23/01/13 * * @param $field - an array holding all the field's data */ function render_field_settings( $field ) { // encode choices (convert from array) $field['choices'] = acf_encode_choices($field['choices']); $field['default_value'] = acf_encode_choices($field['default_value'], false); // choices acf_render_field_setting( $field, array( 'label' => __('Choices','acf'), 'instructions' => __('Enter each choice on a new line.','acf') . '

    ' . __('For more control, you may specify both a value and label like this:','acf'). '

    ' . __('red : Red','acf'), 'type' => 'textarea', 'name' => 'choices', )); // default_value acf_render_field_setting( $field, array( 'label' => __('Default Value','acf'), 'instructions' => __('Enter each default value on a new line','acf'), 'type' => 'textarea', 'name' => 'default_value', )); // layout acf_render_field_setting( $field, array( 'label' => __('Layout','acf'), 'instructions' => '', 'type' => 'radio', 'name' => 'layout', 'layout' => 'horizontal', 'choices' => array( 'vertical' => __("Vertical",'acf'), 'horizontal' => __("Horizontal",'acf') ) )); // layout acf_render_field_setting( $field, array( 'label' => __('Toggle','acf'), 'instructions' => __('Prepend an extra checkbox to toggle all choices','acf'), 'type' => 'radio', 'name' => 'toggle', 'layout' => 'horizontal', 'choices' => array( 1 => __("Yes",'acf'), 0 => __("No",'acf'), ) )); // return_format acf_render_field_setting( $field, array( 'label' => __('Return Value','acf'), 'instructions' => __('Specify the returned value on front end','acf'), 'type' => 'radio', 'name' => 'return_format', 'layout' => 'horizontal', 'choices' => array( 'value' => __('Value','acf'), 'label' => __('Label','acf'), 'array' => __('Both (Array)','acf') ) )); } /* * update_field() * * This filter is appied to the $field before it is saved to the database * * @type filter * @since 3.6 * @date 23/01/13 * * @param $field - the field array holding all the field options * @param $post_id - the field group ID (post_type = acf) * * @return $field - the modified field */ function update_field( $field ) { return acf_get_field_type('select')->update_field( $field ); } /* * update_value() * * This filter is appied to the $value before it is updated in the db * * @type filter * @since 3.6 * @date 23/01/13 * * @param $value - the value which will be saved in the database * @param $post_id - the $post_id of which the value will be saved * @param $field - the field array holding all the field options * * @return $value - the modified value */ function update_value( $value, $post_id, $field ) { return acf_get_field_type('select')->update_value( $value, $post_id, $field ); } /* * translate_field * * This function will translate field settings * * @type function * @date 8/03/2016 * @since 5.3.2 * * @param $field (array) * @return $field */ function translate_field( $field ) { return acf_get_field_type('select')->translate_field( $field ); } /* * format_value() * * This filter is appied to the $value after it is loaded from the db and before it is returned to the template * * @type filter * @since 3.6 * @date 23/01/13 * * @param $value (mixed) the value which was loaded from the database * @param $post_id (mixed) the $post_id from which the value was loaded * @param $field (array) the field array holding all the field options * * @return $value (mixed) the modified value */ function format_value( $value, $post_id, $field ) { return acf_get_field_type('select')->format_value( $value, $post_id, $field ); } } new acf_field_checkbox(); endif; ?>