HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: /var/www/html/ielts-store/wp-content/plugins/automatewoo/includes/Fields/Field.php
<?php
// phpcs:ignoreFile

namespace AutomateWoo\Fields;

use AutomateWoo\Clean;

/**
 * @class Field
 */
abstract class Field {

	/** @var string - deprecated, use $title */
	protected $default_title;

	/** @var string - deprecated, use $name */
	protected $default_name;

	/** @var string */
	protected $title;

	/** @var string */
	protected $name;

	/** @var string */
	protected $type;

	/** @var string */
	protected $description;

	/** @var string trigger or action */
	protected $name_base;

	/** @var bool */
	protected $required = false;

	/** @var array */
	protected $classes = [];

	/**
	 * Extra attributes that will appended to the HTML field element.
	 *
	 * @var array
	 */
	protected $extra_attrs = [];

	/** @var string */
	protected $placeholder = '';

	/**
	 * Field meta data.
	 *
	 * This prop can be used when misc data needs to be added to the field.
	 * Not to be confused with $this->extra_attrs.
	 *
	 * @since 4.6.0
	 *
	 * @var array
	 */
	public $meta = [];

	/**
	 * Output the field HTML.
	 *
	 * @param mixed $value
	 */
	abstract function render( $value );

	/**
	 * Field constructor.
	 */
	function __construct() {
		$this->classes[] = 'automatewoo-field';
		$this->classes[] = 'automatewoo-field--type-' . $this->type;
	}



	/**
	 * @param $name
	 * @return $this
	 */
	function set_name( $name ) {
		$this->name = $name;
		return $this;
	}


	/**
	 * @param $title
	 * @return $this
	 */
	function set_title( $title ) {
		$this->title = $title;
		return $this;
	}


	/**
	 * @return string
	 */
	function get_title() {
		return $this->title ? $this->title :$this->default_title;
	}


	/**
	 * @return string
	 */
	function get_name() {
		return $this->name ? $this->name :$this->default_name;
	}


	/**
	 * @return string
	 */
	function get_type() {
		return $this->type;
	}


	/**
	 * @param $description
	 * @return $this
	 */
	function set_description( $description ) {
		$this->description = $description;
		return $this;
	}


	/**
	 * @return string
	 */
	function get_description() {
		return $this->description;
	}


	/**
	 * @param $placeholder string
	 * @return $this
	 */
	function set_placeholder( $placeholder ) {
		$this->placeholder = $placeholder;
		return $this;
	}


	/**
	 * @return string
	 */
	function get_placeholder() {
		return $this->placeholder;
	}


	/**
	 * @param $classes string
	 * @return $this
	 */
	function add_classes( $classes ) {
		$this->classes = array_merge( $this->classes, explode( ' ', $classes ) );
		return $this;
	}


	/**
	 * @param bool $implode
	 * @return array|string
	 */
	function get_classes( $implode = true ) {
		if ( $implode ) {
			return implode( ' ', $this->classes );
		}
		return $this->classes;
	}


	/**
	 * @param $name
	 * @param $value
	 * @return $this
	 */
	function add_extra_attr( $name, $value = null ) {
		$this->extra_attrs[$name] = $value;
		return $this;
	}


	/**
	 * @param $name
	 * @return bool
	 */
	function has_data_attr( $name ) {
		return isset( $this->extra_attrs[ 'data-' . $name ] );
	}


	/**
	 * @param $name
	 * @param $value
	 * @return $this
	 */
	function add_data_attr( $name, $value = null ) {
		$this->add_extra_attr( 'data-' . $name, $value );
		return $this;
	}


	/**
	 * Outputs the extra field attrs in HTML attribute format.
	 */
	function output_extra_attrs() {
		$string = '';

		foreach ( $this->extra_attrs as $name => $value ) {
			if ( is_null( $value ) ) {
				$string .= esc_attr( $name ) . ' ';
			}
			else {
				$string .= esc_attr( $name ) . '="' . esc_attr( $value ) . '" ';
			}
		}

		echo $string;
	}


	/**
	 * @param bool $required
	 * @return $this
	 */
	function set_required( $required = true ) {
		$this->required = $required;
		return $this;
	}


	/**
	 * @return bool
	 */
	function get_required() {
		return $this->required;
	}


	/**
	 * @return $this
	 */
	function set_disabled() {
		$this->add_extra_attr( 'disabled', 'true' );
		return $this;
	}


	/**
	 * @param $name_base
	 * @return $this
	 */
	function set_name_base( $name_base ) {
		$this->name_base = $name_base;
		return $this;
	}


	/**
	 * @return bool
	 */
	function get_name_base() {
		return $this->name_base;
	}

	/**
	 * @return string
	 */
	function get_full_name() {
		return ( $this->get_name_base() ? $this->get_name_base() . '[' . $this->get_name() . ']' : $this->get_name() );
	}


	/**
	 * @param string $options
	 * @return $this
	 */
	function set_variable_validation( $options = '' ) {
		$this->set_validation( 'variables ' . $options );
		return $this;
	}


	/**
	 * If $options is left blank then the field not support variables
	 *
	 * @param string $options
	 * @return $this
	 */
	function set_validation( $options = '' ) {
		$this->add_data_attr( 'automatewoo-validate', $options );
		return $this;
	}


	/**
	 * Sanitizes the value of the field.
	 *
	 * This method runs before WRITING a value to the DB but doesn't run before READING.
	 *
	 * Defaults to sanitize as a single line string. Override this method for fields that should be sanitized differently.
	 *
	 * @since 4.4.0
	 *
	 * @param string $value
	 *
	 * @return string
	 */
	function sanitize_value( $value ) {
		return Clean::string( $value );
	}


}