Current File : /home/getxxhzo/tinyrnd.com/wp-content/plugins/flyweb-common/meta-box/inc/fields/object-choice.php |
<?php
/**
* The object choice class which allows users to select specific objects in WordPress.
*
* @package Meta Box
*/
/**
* Abstract field to select an object: post, user, taxonomy, etc.
*/
abstract class RWMB_Object_Choice_Field extends RWMB_Choice_Field {
/**
* Show field HTML.
* Populate field options before showing to make sure query is made only once.
*
* @param array $field Field parameters.
* @param bool $saved Whether the meta box is saved at least once.
* @param int $post_id Post ID.
*/
public static function show( $field, $saved, $post_id = 0 ) {
// Get unique saved IDs for ajax fields.
$meta = self::call( $field, 'meta', $post_id, $saved );
$meta = self::filter( 'field_meta', $meta, $field, $saved );
$meta = RWMB_Helpers_Array::flatten( (array) $meta );
$meta = array_unique( array_filter( array_map( 'absint', $meta ) ) );
sort( $meta );
$field['options'] = self::call( $field, 'query', $meta );
parent::show( $field, $saved, $post_id );
}
/**
* Get field HTML.
*
* @param mixed $meta Meta value.
* @param array $field Field parameters.
* @return string
*/
public static function html( $meta, $field ) {
$html = call_user_func( array( self::get_type_class( $field ), 'html' ), $meta, $field );
if ( $field['add_new'] ) {
$html .= self::call( 'add_new_form', $field );
}
return $html;
}
/**
* Render "Add New" form
*
* @param array $field Field settings.
* @return string
*/
public static function add_new_form( $field ) {
return '';
}
/**
* Normalize parameters for field.
*
* @param array $field Field parameters.
*
* @return array
*/
public static function normalize( $field ) {
$field = parent::normalize( $field );
$field = wp_parse_args(
$field,
array(
'flatten' => true,
'query_args' => array(),
'field_type' => 'select_advanced',
'add_new' => false,
'ajax' => true,
)
);
if ( 'select_advanced' !== $field['field_type'] ) {
$field['ajax'] = false;
}
if ( 'checkbox_tree' === $field['field_type'] ) {
$field['field_type'] = 'checkbox_list';
$field['flatten'] = false;
}
if ( 'radio_list' === $field['field_type'] ) {
$field['field_type'] = 'radio';
}
$field = call_user_func( array( self::get_type_class( $field ), 'normalize' ), $field );
return $field;
}
/**
* Set ajax parameters.
*
* @param array $field Field settings.
*/
protected static function set_ajax_params( &$field ) {
if ( ! $field['ajax'] ) {
return;
}
if ( empty( $field['js_options']['ajax'] ) ) {
$field['js_options']['ajax'] = array();
}
$field['js_options']['ajax'] = wp_parse_args(
array(
'url' => admin_url( 'admin-ajax.php' ),
),
$field['js_options']['ajax']
);
$field['js_options']['ajax_data'] = array(
'field' => array(
'id' => $field['id'],
'type' => $field['type'],
'query_args' => $field['query_args'],
),
'_wpnonce' => wp_create_nonce( 'query' ),
);
}
/**
* 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 = call_user_func( array( self::get_type_class( $field ), 'get_attributes' ), $field, $value );
if ( 'select_advanced' === $field['field_type'] ) {
$attributes['class'] .= ' rwmb-select_advanced';
} elseif ( 'select' === $field['field_type'] ) {
$attributes['class'] .= ' rwmb-select';
}
return $attributes;
}
/**
* Enqueue scripts and styles.
*/
public static function admin_enqueue_scripts() {
RWMB_Input_List_Field::admin_enqueue_scripts();
RWMB_Select_Field::admin_enqueue_scripts();
RWMB_Select_Tree_Field::admin_enqueue_scripts();
RWMB_Select_Advanced_Field::admin_enqueue_scripts();
}
/**
* Get correct rendering class for the field.
*
* @param array $field Field parameters.
* @return string
*/
protected static function get_type_class( $field ) {
return RWMB_Helpers_Field::get_class(
array(
'type' => $field['field_type'],
)
);
}
}