', self::render_attributes( $attributes ) ); // Value $val = isset( $meta[1] ) ? $meta[1] : ''; $attributes = self::get_attributes( $field, $val ); $attributes['placeholder'] = $field['placeholder']['value']; $html .= sprintf( '', self::render_attributes( $attributes ) ); return $html; } /** * Show begin HTML markup for fields * * @param mixed $meta * @param array $field * @return string */ static function begin_html( $meta, $field ) { $desc = $field['desc'] ? "

{$field['desc']}

" : ''; if ( empty( $field['name'] ) ) { return '
' . $desc; } return sprintf( '
%s', $field['id'], $field['name'], $desc ); } /** * Do not show field description. * * @param array $field * @return string */ public static function element_description( $field ) { return ''; } /** * Escape meta for field output * * @param mixed $meta * @return mixed */ static function esc_meta( $meta ) { foreach ( (array) $meta as $k => $pairs ) { $meta[ $k ] = array_map( 'esc_attr', (array) $pairs ); } return $meta; } /** * Sanitize field value. * * @param mixed $new * @param mixed $old * @param int $post_id * @param array $field * * @return string */ static function value( $new, $old, $post_id, $field ) { foreach ( $new as &$arr ) { if ( empty( $arr[0] ) && empty( $arr[1] ) ) { $arr = false; } } $new = array_filter( $new ); return $new; } /** * Normalize parameters for field * * @param array $field * @return array */ static function normalize( $field ) { $field = parent::normalize( $field ); $field['clone'] = true; $field['multiple'] = true; $field['attributes']['type'] = 'text'; $field['placeholder'] = wp_parse_args( (array) $field['placeholder'], array( 'key' => 'Key', 'value' => 'Value', ) ); return $field; } /** * Format value for the helper functions. * * @param array $field Field parameter * @param string|array $value The field meta value * @return string */ public static function format_value( $field, $value ) { $output = ''; return $output; } }