You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

134 lines
4.0 KiB

9 months ago
<?php
defined( 'ABSPATH' ) || die;
/**
* The oEmbed field which allows users to enter oEmbed URLs.
*/
class RWMB_OEmbed_Field extends RWMB_Input_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, [
'not_available_string' => __( 'Embed HTML not available.', 'meta-box' ),
] );
$field['attributes'] = wp_parse_args( $field['attributes'], [
'data-not-available' => $field['not_available_string'],
] );
return $field;
}
public static function admin_enqueue_scripts() {
wp_enqueue_style( 'rwmb-oembed', RWMB_CSS_URL . 'oembed.css', [], RWMB_VER );
wp_style_add_data( 'rwmb-oembed', 'path', RWMB_CSS_DIR . 'oembed.css' );
wp_enqueue_script( 'rwmb-oembed', RWMB_JS_URL . 'oembed.js', [ 'jquery', 'underscore', 'rwmb' ], RWMB_VER, true );
wp_localize_script( 'rwmb-oembed', 'rwmbOembed', [
'nonce' => wp_create_nonce( 'oembed_get' ),
] );
}
public static function add_actions() {
add_action( 'wp_ajax_rwmb_get_embed', [ __CLASS__, 'ajax_get_embed' ] );
}
public static function ajax_get_embed() {
check_ajax_referer( 'oembed_get' );
$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 = [];
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'] );
}
}