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.
73 lines
2.3 KiB
73 lines
2.3 KiB
<?php
|
|
defined( 'ABSPATH' ) || die;
|
|
|
|
/**
|
|
* The slider field which users jQueryUI slider widget.
|
|
*/
|
|
class RWMB_Slider_Field extends RWMB_Field {
|
|
public static function admin_enqueue_scripts() {
|
|
$url = RWMB_CSS_URL . 'jqueryui';
|
|
wp_register_style( 'jquery-ui-core', "$url/core.css", [], '1.13.2' );
|
|
wp_style_add_data( 'jquery-ui-core', 'path', RWMB_CSS_DIR . 'jqueryui/core.css' );
|
|
|
|
wp_register_style( 'jquery-ui-theme', "$url/theme.css", [], '1.13.2' );
|
|
wp_style_add_data( 'jquery-ui-theme', 'path', RWMB_CSS_DIR . 'jqueryui/theme.css' );
|
|
|
|
wp_register_style( 'jquery-ui-slider', "$url/slider.css", [ 'jquery-ui-core', 'jquery-ui-theme' ], '1.13.2' );
|
|
wp_style_add_data( 'jquery-ui-slider', 'path', RWMB_CSS_DIR . 'jqueryui/slider.css' );
|
|
|
|
wp_enqueue_style( 'rwmb-slider', RWMB_CSS_URL . 'slider.css', [ 'jquery-ui-slider' ], RWMB_VER );
|
|
wp_style_add_data( 'rwmb-slider', 'path', RWMB_CSS_DIR . 'slider.css' );
|
|
wp_enqueue_script( 'rwmb-slider', RWMB_JS_URL . 'slider.js', [ 'jquery-ui-slider', 'jquery-ui-widget', 'jquery-ui-mouse', 'jquery-ui-core' ], RWMB_VER, true );
|
|
}
|
|
|
|
/**
|
|
* Get div HTML.
|
|
*
|
|
* @param mixed $meta Meta value.
|
|
* @param array $field Field parameters.
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function html( $meta, $field ) {
|
|
$attributes = self::call( 'get_attributes', $field, $meta );
|
|
return sprintf(
|
|
'<div class="rwmb-slider-inner">
|
|
<div class="rwmb-slider-ui" id="%s" data-options="%s"></div>
|
|
<span class="rwmb-slider-label">%s<span>%s</span>%s</span>
|
|
<input type="hidden" value="%s" %s>
|
|
</div>',
|
|
$field['id'],
|
|
esc_attr( wp_json_encode( $field['js_options'] ) ),
|
|
$field['prefix'],
|
|
$meta,
|
|
$field['suffix'],
|
|
$meta,
|
|
self::render_attributes( $attributes )
|
|
);
|
|
}
|
|
|
|
/**
|
|
* 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, [
|
|
'prefix' => '',
|
|
'suffix' => '',
|
|
'std' => '',
|
|
'js_options' => [],
|
|
] );
|
|
$field['js_options'] = wp_parse_args( $field['js_options'], [
|
|
'range' => 'min', // range = 'min' will add a dark background to sliding part, better UI.
|
|
'value' => $field['std'],
|
|
] );
|
|
|
|
return $field;
|
|
}
|
|
}
|