mirror of
https://github.com/WenPai-org/wp-china-yes.git
synced 2025-08-03 11:11:30 +08:00
176 lines
8.1 KiB
PHP
Executable file
176 lines
8.1 KiB
PHP
Executable file
<?php if ( ! defined( 'ABSPATH' ) ) { die; } // Cannot access directly.
|
|
/**
|
|
*
|
|
* Field: border
|
|
*
|
|
* @since 1.0.0
|
|
* @version 1.0.0
|
|
*
|
|
*/
|
|
if ( ! class_exists( 'WP_CHINA_YES_Field_border' ) ) {
|
|
class WP_CHINA_YES_Field_border extends WP_CHINA_YES_Fields {
|
|
|
|
public function __construct( $field, $value = '', $unique = '', $where = '', $parent = '' ) {
|
|
parent::__construct( $field, $value, $unique, $where, $parent );
|
|
}
|
|
|
|
public function render() {
|
|
|
|
$args = wp_parse_args( $this->field, array(
|
|
'top_icon' => '<i class="fas fa-long-arrow-alt-up"></i>',
|
|
'left_icon' => '<i class="fas fa-long-arrow-alt-left"></i>',
|
|
'bottom_icon' => '<i class="fas fa-long-arrow-alt-down"></i>',
|
|
'right_icon' => '<i class="fas fa-long-arrow-alt-right"></i>',
|
|
'all_icon' => '<i class="fas fa-arrows-alt"></i>',
|
|
'top_placeholder' => esc_html__( 'top', 'wp_china_yes' ),
|
|
'right_placeholder' => esc_html__( 'right', 'wp_china_yes' ),
|
|
'bottom_placeholder' => esc_html__( 'bottom', 'wp_china_yes' ),
|
|
'left_placeholder' => esc_html__( 'left', 'wp_china_yes' ),
|
|
'all_placeholder' => esc_html__( 'all', 'wp_china_yes' ),
|
|
'top' => true,
|
|
'left' => true,
|
|
'bottom' => true,
|
|
'right' => true,
|
|
'all' => false,
|
|
'color' => true,
|
|
'style' => true,
|
|
'unit' => 'px',
|
|
) );
|
|
|
|
$default_value = array(
|
|
'top' => '',
|
|
'right' => '',
|
|
'bottom' => '',
|
|
'left' => '',
|
|
'color' => '',
|
|
'style' => 'solid',
|
|
'all' => '',
|
|
);
|
|
|
|
$border_props = array(
|
|
'solid' => esc_html__( 'Solid', 'wp_china_yes' ),
|
|
'dashed' => esc_html__( 'Dashed', 'wp_china_yes' ),
|
|
'dotted' => esc_html__( 'Dotted', 'wp_china_yes' ),
|
|
'double' => esc_html__( 'Double', 'wp_china_yes' ),
|
|
'inset' => esc_html__( 'Inset', 'wp_china_yes' ),
|
|
'outset' => esc_html__( 'Outset', 'wp_china_yes' ),
|
|
'groove' => esc_html__( 'Groove', 'wp_china_yes' ),
|
|
'ridge' => esc_html__( 'ridge', 'wp_china_yes' ),
|
|
'none' => esc_html__( 'None', 'wp_china_yes' )
|
|
);
|
|
|
|
$default_value = ( ! empty( $this->field['default'] ) ) ? wp_parse_args( $this->field['default'], $default_value ) : $default_value;
|
|
|
|
$value = wp_parse_args( $this->value, $default_value );
|
|
|
|
echo $this->field_before();
|
|
|
|
echo '<div class="wp_china_yes--inputs" data-depend-id="'. esc_attr( $this->field['id'] ) .'">';
|
|
|
|
if ( ! empty( $args['all'] ) ) {
|
|
|
|
$placeholder = ( ! empty( $args['all_placeholder'] ) ) ? ' placeholder="'. esc_attr( $args['all_placeholder'] ) .'"' : '';
|
|
|
|
echo '<div class="wp_china_yes--input">';
|
|
echo ( ! empty( $args['all_icon'] ) ) ? '<span class="wp_china_yes--label wp_china_yes--icon">'. $args['all_icon'] .'</span>' : '';
|
|
echo '<input type="number" name="'. esc_attr( $this->field_name( '[all]' ) ) .'" value="'. esc_attr( $value['all'] ) .'"'. $placeholder .' class="wp_china_yes-input-number wp_china_yes--is-unit" step="any" />';
|
|
echo ( ! empty( $args['unit'] ) ) ? '<span class="wp_china_yes--label wp_china_yes--unit">'. esc_attr( $args['unit'] ) .'</span>' : '';
|
|
echo '</div>';
|
|
|
|
} else {
|
|
|
|
$properties = array();
|
|
|
|
foreach ( array( 'top', 'right', 'bottom', 'left' ) as $prop ) {
|
|
if ( ! empty( $args[$prop] ) ) {
|
|
$properties[] = $prop;
|
|
}
|
|
}
|
|
|
|
$properties = ( $properties === array( 'right', 'left' ) ) ? array_reverse( $properties ) : $properties;
|
|
|
|
foreach ( $properties as $property ) {
|
|
|
|
$placeholder = ( ! empty( $args[$property.'_placeholder'] ) ) ? ' placeholder="'. esc_attr( $args[$property.'_placeholder'] ) .'"' : '';
|
|
|
|
echo '<div class="wp_china_yes--input">';
|
|
echo ( ! empty( $args[$property.'_icon'] ) ) ? '<span class="wp_china_yes--label wp_china_yes--icon">'. $args[$property.'_icon'] .'</span>' : '';
|
|
echo '<input type="number" name="'. esc_attr( $this->field_name( '['. $property .']' ) ) .'" value="'. esc_attr( $value[$property] ) .'"'. $placeholder .' class="wp_china_yes-input-number wp_china_yes--is-unit" step="any" />';
|
|
echo ( ! empty( $args['unit'] ) ) ? '<span class="wp_china_yes--label wp_china_yes--unit">'. esc_attr( $args['unit'] ) .'</span>' : '';
|
|
echo '</div>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( ! empty( $args['style'] ) ) {
|
|
echo '<div class="wp_china_yes--input">';
|
|
echo '<select name="'. esc_attr( $this->field_name( '[style]' ) ) .'">';
|
|
foreach ( $border_props as $border_prop_key => $border_prop_value ) {
|
|
$selected = ( $value['style'] === $border_prop_key ) ? ' selected' : '';
|
|
echo '<option value="'. esc_attr( $border_prop_key ) .'"'. esc_attr( $selected ) .'>'. esc_attr( $border_prop_value ) .'</option>';
|
|
}
|
|
echo '</select>';
|
|
echo '</div>';
|
|
}
|
|
|
|
echo '</div>';
|
|
|
|
if ( ! empty( $args['color'] ) ) {
|
|
$default_color_attr = ( ! empty( $default_value['color'] ) ) ? ' data-default-color="'. esc_attr( $default_value['color'] ) .'"' : '';
|
|
echo '<div class="wp_china_yes--color">';
|
|
echo '<div class="wp_china_yes-field-color">';
|
|
echo '<input type="text" name="'. esc_attr( $this->field_name( '[color]' ) ) .'" value="'. esc_attr( $value['color'] ) .'" class="wp_china_yes-color"'. $default_color_attr .' />';
|
|
echo '</div>';
|
|
echo '</div>';
|
|
}
|
|
|
|
echo $this->field_after();
|
|
|
|
}
|
|
|
|
public function output() {
|
|
|
|
$output = '';
|
|
$unit = ( ! empty( $this->value['unit'] ) ) ? $this->value['unit'] : 'px';
|
|
$important = ( ! empty( $this->field['output_important'] ) ) ? '!important' : '';
|
|
$element = ( is_array( $this->field['output'] ) ) ? join( ',', $this->field['output'] ) : $this->field['output'];
|
|
|
|
// properties
|
|
$top = ( isset( $this->value['top'] ) && $this->value['top'] !== '' ) ? $this->value['top'] : '';
|
|
$right = ( isset( $this->value['right'] ) && $this->value['right'] !== '' ) ? $this->value['right'] : '';
|
|
$bottom = ( isset( $this->value['bottom'] ) && $this->value['bottom'] !== '' ) ? $this->value['bottom'] : '';
|
|
$left = ( isset( $this->value['left'] ) && $this->value['left'] !== '' ) ? $this->value['left'] : '';
|
|
$style = ( isset( $this->value['style'] ) && $this->value['style'] !== '' ) ? $this->value['style'] : '';
|
|
$color = ( isset( $this->value['color'] ) && $this->value['color'] !== '' ) ? $this->value['color'] : '';
|
|
$all = ( isset( $this->value['all'] ) && $this->value['all'] !== '' ) ? $this->value['all'] : '';
|
|
|
|
if ( ! empty( $this->field['all'] ) && ( $all !== '' || $color !== '' ) ) {
|
|
|
|
$output = $element .'{';
|
|
$output .= ( $all !== '' ) ? 'border-width:'. $all . $unit . $important .';' : '';
|
|
$output .= ( $color !== '' ) ? 'border-color:'. $color . $important .';' : '';
|
|
$output .= ( $style !== '' ) ? 'border-style:'. $style . $important .';' : '';
|
|
$output .= '}';
|
|
|
|
} else if ( $top !== '' || $right !== '' || $bottom !== '' || $left !== '' || $color !== '' ) {
|
|
|
|
$output = $element .'{';
|
|
$output .= ( $top !== '' ) ? 'border-top-width:'. $top . $unit . $important .';' : '';
|
|
$output .= ( $right !== '' ) ? 'border-right-width:'. $right . $unit . $important .';' : '';
|
|
$output .= ( $bottom !== '' ) ? 'border-bottom-width:'. $bottom . $unit . $important .';' : '';
|
|
$output .= ( $left !== '' ) ? 'border-left-width:'. $left . $unit . $important .';' : '';
|
|
$output .= ( $color !== '' ) ? 'border-color:'. $color . $important .';' : '';
|
|
$output .= ( $style !== '' ) ? 'border-style:'. $style . $important .';' : '';
|
|
$output .= '}';
|
|
|
|
}
|
|
|
|
$this->parent->output_css .= $output;
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
}
|
|
}
|