Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

jsarnowski / jsarnowski/jet-popup   php

Repository URL to install this package:

Version: 1.5.2 

/ conditions / advanced-url-param.php

<?php
/**
 * Is front page condition
 */

// If this file is called directly, abort.
if ( ! defined( 'WPINC' ) ) {
	die;
}

if ( ! class_exists( 'Jet_Popup_Conditions_Advanced_Url_Param' ) ) {

	/**
	 * Define Jet_Popup_Conditions_Advanced_Url_Param class
	 */
	class Jet_Popup_Conditions_Advanced_Url_Param extends Jet_Popup_Conditions_Base {

		/**
		 * Condition slug
		 *
		 * @return string
		 */
		public function get_id() {
			return 'url-param';
		}

		/**
		 * Condition label
		 *
		 * @return string
		 */
		public function get_label() {
			return __( 'Url Parameter', 'jet-popup' );
		}

		/**
		 * Condition group
		 *
		 * @return string
		 */
		public function get_group() {
			return 'advanced';
		}

		/**
		 * [get_control description]
		 * @return [type] [description]
		 */
		public function get_control() {
			return [
				'type'        => 'input',
				'placeholder' => __( 'Input params string', 'jet-popup' ),
			];
		}

		/**
		 * [ajax_action description]
		 * @return [type] [description]
		 */
		public function ajax_action() {
			return false;
		}

		/**
		 * [get_label_by_value description]
		 * @param  string $value [description]
		 * @return [type]        [description]
		 */
		public function get_label_by_value( $value = '' ) {
			return $value;
		}

		/**
		 * Condition check callback
		 *
		 * @return bool
		 */
		public function check( $arg = '' ) {

			if ( empty( $arg ) || empty( $_REQUEST ) ) {
				return false;
			}

			$params_data = [];

			if ( strpos( $arg, '&' ) ) {
				$param_list = explode( '&', $arg );

				if ( ! empty( $param_list ) && is_array( $param_list ) ) {
					foreach ( $param_list as $key => $value ) {
						$param_pair = $this->explode_to_pairs( $value );

						if ( $param_pair ) {
							$params_data[ $param_pair[0] ] = $param_pair[1];
						}
					}
				}
			} else {

				$param_pair = $this->explode_to_pairs( $arg );

				if ( $param_pair ) {
					$params_data[ $param_pair[0] ] = $param_pair[1];
				}
			}

			$request_data = $_REQUEST;

			$is_match = false;

			foreach ( $request_data as $request_param => $request_value ) {

				if ( array_key_exists( $request_param, $params_data ) && $request_value === $params_data[ $request_param ] ) {
					$is_match = true;

					break;
				}
			}

			return $is_match;
		}

		/**
		 * [explode_to_pairs description]
		 * @return [type] [description]
		 */
		public function explode_to_pairs( $string = false ) {

			if ( ! $string || empty( $string ) ) {
				return false;
			}

			if ( ! strpos( $string, '=' ) ) {
				return false;
			}

			return explode( '=', $string );

		}

	}

}