field, array( 'top_icon' => '', 'right_icon' => '', 'bottom_icon' => '', 'left_icon' => '', 'all_icon' => '', 'top_placeholder' => esc_html__('top', 'csf'), 'right_placeholder' => esc_html__('right', 'csf'), 'bottom_placeholder' => esc_html__('bottom', 'csf'), 'left_placeholder' => esc_html__('left', 'csf'), 'all_placeholder' => esc_html__('all', 'csf'), 'top' => true, 'left' => true, 'bottom' => true, 'right' => true, 'unit' => true, 'show_units' => true, 'all' => false, 'units' => array('px', '%', 'em') )); $default_values = array( 'top' => '', 'right' => '', 'bottom' => '', 'left' => '', 'all' => '', 'unit' => 'px', ); $value = wp_parse_args($this->value, $default_values); $unit = (count($args['units']) === 1 && !empty($args['unit'])) ? $args['units'][0] : ''; $is_unit = (!empty($unit)) ? ' csf--is-unit' : ''; echo $this->field_before(); echo '
'; if (!empty($args['all'])) { $placeholder = (!empty($args['all_placeholder'])) ? ' placeholder="' . esc_attr($args['all_placeholder']) . '"' : ''; echo '
'; echo (!empty($args['all_icon'])) ? '' . $args['all_icon'] . '' : ''; echo ''; echo ($unit) ? '' . esc_attr($args['units'][0]) . '' : ''; echo '
'; } 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 '
'; echo (!empty($args[$property . '_icon'])) ? '' . $args[$property . '_icon'] . '' : ''; echo ''; echo ($unit) ? '' . esc_attr($args['units'][0]) . '' : ''; echo '
'; } } if (!empty($args['unit']) && !empty($args['show_units']) && count($args['units']) > 1) { echo '
'; echo ''; echo '
'; } echo '
'; echo $this->field_after(); } public function output() { $output = ''; $element = (is_array($this->field['output'])) ? join(',', $this->field['output']) : $this->field['output']; $important = (!empty($this->field['output_important'])) ? '!important' : ''; $unit = (!empty($this->value['unit'])) ? $this->value['unit'] : 'px'; $mode = (!empty($this->field['output_mode'])) ? $this->field['output_mode'] : 'padding'; if ($mode === 'border-radius' || $mode === 'radius') { $top = 'border-top-left-radius'; $right = 'border-top-right-radius'; $bottom = 'border-bottom-right-radius'; $left = 'border-bottom-left-radius'; } else if ($mode === 'relative' || $mode === 'absolute' || $mode === 'none') { $top = 'top'; $right = 'right'; $bottom = 'bottom'; $left = 'left'; } else { $top = $mode . '-top'; $right = $mode . '-right'; $bottom = $mode . '-bottom'; $left = $mode . '-left'; } if (!empty($this->field['all']) && isset($this->value['all']) && $this->value['all'] !== '') { $output = $element . '{'; $output .= $top . ':' . $this->value['all'] . $unit . $important . ';'; $output .= $right . ':' . $this->value['all'] . $unit . $important . ';'; $output .= $bottom . ':' . $this->value['all'] . $unit . $important . ';'; $output .= $left . ':' . $this->value['all'] . $unit . $important . ';'; $output .= '}'; } else { $top = (isset($this->value['top']) && $this->value['top'] !== '') ? $top . ':' . $this->value['top'] . $unit . $important . ';' : ''; $right = (isset($this->value['right']) && $this->value['right'] !== '') ? $right . ':' . $this->value['right'] . $unit . $important . ';' : ''; $bottom = (isset($this->value['bottom']) && $this->value['bottom'] !== '') ? $bottom . ':' . $this->value['bottom'] . $unit . $important . ';' : ''; $left = (isset($this->value['left']) && $this->value['left'] !== '') ? $left . ':' . $this->value['left'] . $unit . $important . ';' : ''; if ($top !== '' || $right !== '' || $bottom !== '' || $left !== '') { $output = $element . '{' . $top . $right . $bottom . $left . '}'; } } $this->parent->output_css .= $output; return $output; } } }