$image ) {
$attributes = self::get_attributes( $field, $value );
$html[] = sprintf(
'',
$image,
self::render_attributes( $attributes ),
checked( in_array( $value, $meta ), true, false )
);
}
return implode( ' ', $html );
}
/**
* Normalize parameters for field.
*
* @param array $field Field parameters.
* @return array
*/
public static function normalize( $field ) {
$field = parent::normalize( $field );
$field['options'] = $field['options'] ?? [];
$field['field_name'] .= $field['multiple'] ? '[]' : '';
return $field;
}
/**
* Get the attributes for a field.
*
* @param array $field Field parameters.
* @param mixed $value Meta value.
* @return array
*/
public static function get_attributes( $field, $value = null ) {
$attributes = parent::get_attributes( $field, $value );
$attributes['id'] = false;
$attributes['type'] = $field['multiple'] ? 'checkbox' : 'radio';
$attributes['value'] = $value;
return $attributes;
}
/**
* Format a single value for the helper functions. Sub-fields should overwrite this method if necessary.
*
* @param array $field Field parameters.
* @param string $value The value.
* @param array $args Additional arguments. Rarely used. See specific fields for details.
* @param int|null $post_id Post ID. null for current post. Optional.
*
* @return string
*/
public static function format_single_value( $field, $value, $args, $post_id ) {
return $value ? sprintf( '', esc_url( $field['options'][ $value ] ) ) : '';
}
}