Current File : /home/getxxhzo/tinyrnd.com/wp-content/plugins/flyweb-common/meta-box/inc/fields/oembed.php |
<?php
/**
* The oEmbed field which allows users to enter oEmbed URLs.
*
* @package Meta Box
*/
/**
* OEmbed field class.
*/
class RWMB_OEmbed_Field extends RWMB_Text_Field {
/**
* 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(
'not_available_string' => __( 'Embed HTML not available.', 'meta-box' ),
)
);
$field['attributes'] = wp_parse_args(
$field['attributes'],
array(
'data-not-available' => $field['not_available_string'],
)
);
return $field;
}
/**
* Enqueue scripts and styles.
*/
public static function admin_enqueue_scripts() {
wp_enqueue_style( 'rwmb-oembed', RWMB_CSS_URL . 'oembed.css', '', RWMB_VER );
wp_enqueue_script( 'rwmb-oembed', RWMB_JS_URL . 'oembed.js', array( 'jquery', 'underscore' ), RWMB_VER, true );
}
/**
* Add actions.
*/
public static function add_actions() {
add_action( 'wp_ajax_rwmb_get_embed', array( __CLASS__, 'wp_ajax_get_embed' ) );
}
/**
* Ajax callback for returning oEmbed HTML.
*/
public static function wp_ajax_get_embed() {
$request = rwmb_request();
$url = (string) $request->filter_post( 'url', FILTER_SANITIZE_URL );
$not_available = (string) $request->post( 'not_available' );
wp_send_json_success( self::get_embed( $url, $not_available ) );
}
/**
* Get embed html from url.
*
* @param string $url URL.
* @param string $not_available Not available string displayed to users.
* @return string
*/
public static function get_embed( $url, $not_available = '' ) {
/**
* Set arguments for getting embeded HTML.
* Without arguments, default width will be taken from global $content_width, which can break UI in the admin.
*
* @link https://github.com/rilwis/meta-box/issues/801
* @see WP_oEmbed::fetch()
* @see WP_Embed::shortcode()
* @see wp_embed_defaults()
*/
$args = array();
if ( is_admin() ) {
$args['width'] = 360;
}
// Try oembed first.
$embed = wp_oembed_get( $url, $args );
// If no oembed provides found, try WordPress auto embed.
if ( ! $embed ) {
global $wp_embed;
$temp = $wp_embed->return_false_on_fail;
$wp_embed->return_false_on_fail = true; // Do not fallback to make a link.
$embed = $wp_embed->shortcode( $args, $url );
$wp_embed->return_false_on_fail = $temp;
}
if ( $not_available ) {
$not_available = '<div class="rwmb-oembed-not-available">' . wp_kses_post( $not_available ) . '</div>';
}
$not_available = apply_filters( 'rwmb_oembed_not_available_string', $not_available );
return $embed ? $embed : $not_available;
}
/**
* Get field HTML.
*
* @param mixed $meta Meta value.
* @param array $field Field parameters.
* @return string
*/
public static function html( $meta, $field ) {
return parent::html( $meta, $field ) . sprintf(
'<span class="spinner"></span>
<div class="rwmb-embed-media">%s</div>',
$meta ? self::get_embed( $meta, $field['not_available_string'] ) : ''
);
}
/**
* 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['type'] = 'url';
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 self::get_embed( $value, $field['not_available_string'] );
}
}