HEX
Server: Apache
System: Linux andromeda.lojoweb.com 4.18.0-372.26.1.el8_6.x86_64 #1 SMP Tue Sep 13 06:07:14 EDT 2022 x86_64
User: nakedfoamlojoweb (1056)
PHP: 8.0.30
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //proc/self/cwd/wp-content/plugins/password-protect-page/includes/customizers/class-ppw-presets.php
<?php
// Exit if accessed directly.
if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

// Exit if WP_Customize_Control does not exsist.
if ( ! class_exists( 'WP_Customize_Control' ) ) {
	return null;
}

class PPW_Presets_Control extends WP_Customize_Control {
	/**
	 * @var string Control type
	 */
	public $type = 'ppw-presets';

	/**
	 * Render the content on the theme customizer page.
	 */
	public function render_content() {
		if ( empty( $this->choices ) ) {
			return;
		}
		$name = 'password-protect-page_preset-' . $this->id; ?>

		<span class="customize-control-title">
      <?php echo esc_attr( $this->label ); ?>
			<?php if ( ! empty( $this->description ) ) : ?>
				<span class="description customize-control-description"><?php echo esc_html( $this->description ); ?></span>
			<?php endif; ?>
        </span>

		<div id="input_<?php echo esc_attr( $this->id ); ?>" class="image">
			<?php foreach ( $this->choices as $val ) : ?>
				<div class="password-protect-page_thumbnail">
					<input class="image-select" type="radio"
					                                       value="<?php echo esc_attr( $val['id'] ); ?>"
					                                       id="<?php echo esc_attr($this->id . $val['id']); ?>"
					                                       name="<?php echo esc_attr( $name ); ?>" <?php checked( $this->value(), $val['id'] ); ?> />
					<label for="<?php echo esc_attr($this->id . $val['id']); ?>">
						<div class="password-protect-page_thumbnail_img">
							<img src="<?php echo esc_url($val['thumbnail']); ?>" alt="<?php echo esc_attr( $val['id'] ); ?>"
							     title="<?php echo esc_attr( $val['id'] ); ?>">
						</div>
						<h3><?php echo esc_html( $val['name'] ) ?></h3>
					</label>

				</div>
			<?php endforeach; ?>
		</div>

		<input name='presets_hidden' type="hidden" <?php $this->link(); ?> value="<?php echo esc_attr( $this->value() ); ?>"/>
	<?php }
}

function ppw_presets_control_css() {
	?>
	<style>
        .customize-control-ppw-presets .image.ui-buttonset input[type=radio] {
            height: auto;
        }
        .customize-control-ppw-presets .image.ui-buttonset label {
            display: inline-block;
            margin-right: 5px;
            margin-bottom: 5px;
        }
        .customize-control-ppw-presets .image.ui-buttonset label.ui-state-active {
            background: none;
        }
        .customize-control-ppw-presets .customize-control-radio-buttonset label {
            padding: 5px 10px;
            background: #f7f7f7;
            border-left: 1px solid #dedede;
            line-height: 35px;
        }
        .customize-control-ppw-presets label img {
            border: 1px solid #bbb;
            opacity: 0.5;
        }
        #customize-controls .customize-control-ppw-presets label img {
            max-width: 250px;
            height: auto;
            width: 100%;
            margin-bottom: 0;
            border: 0;
            display: block;
        }
        .customize-control-ppw-presets label.ui-state-active img {
            background: #dedede;
            border-color: #000;
            opacity: 1;
            margin-bottom: 0;
        }
        .customize-control-ppw-presets label.ui-state-hover img {
            opacity: 0.9;
            border-color: #999;
        }
        .customize-control-radio-buttonset label.ui-corner-left {
            border-radius: 3px 0 0 3px;
            border-left: 0;
        }
        .customize-control-radio-buttonset label.ui-corner-right {
            border-radius: 0 3px 3px 0;
        }
        #customize-control-ppw_customize_presets_settings input[type=radio]{
            display: none;
        }
        #customize-control-ppw_customize_presets_settings label{
            display: block;
            position: relative;
            width: 100%;
        }
        #customize-control-ppw_customize_presets_settings .password-protect-page_thumbnail{
            width: calc(50% - 10px);
            margin-bottom: 10px;
            position: relative;
            border: 5px solid transparent;
            -webkit-transition:all 0.2s ease-in-out;
            -moz-transition:all 0.2s ease-in-out;
            -ms-transition:all 0.2s ease-in-out;
            transition:all 0.2s ease-in-out;
        }
        #customize-control-ppw_customize_presets_settings .password-protect-page_thumbnail:nth-child(odd){
            float: left;
        }
        #customize-control-ppw_customize_presets_settings .password-protect-page_thumbnail:nth-child(even){
            float: right;
        }
        #customize-control-ppw_customize_presets_settings .image:after{
            content: '';
            display: table;
            clear: both;
        }
        #customize-control-ppw_customize_presets_settings h3{
            margin: 0;
            font: 400 14px 'Open Sans', Arial, Helvetica, sans-serif;
            line-height: 1.1;
            padding: 3px;
            text-align: center;
            background: #eee;
            color: #777777;
        }
        #customize-control-ppw_customize_presets_settings label .password-protect-page_thumbnail_img:after {
            content: '';
            width: 20px;
            height: 20px;
            border-radius: 50%;
            background: #ff8935;
            position: absolute;
            top: -5px;
            left: -5px;
            border-radius: 50%;
            visibility: hidden;
        }
        #customize-control-ppw_customize_presets_settings label .password-protect-page_thumbnail_img:before {
            height: 6px;
            width: 3px;
            -webkit-transform-origin: left top;
            -moz-transform-origin: left top;
            -ms-transform-origin: left top;
            -o-transform-origin: left top;
            transform-origin: left top;
            border-right: 3px solid white;
            border-top: 3px solid white;
            border-radius: 2.5px !important;
            content: '';
            position: absolute;
            z-index: 2;
            opacity: 0;
            margin-top: 0px;
            margin-left: -7px;
            top: 5px;
            left: 4px;
        }
        #customize-control-ppw_customize_presets_settings .password-protect-page_thumbnail_img{
            display: block;
            position: relative;
        }
        #customize-control-ppw_customize_presets_settings input[type="radio"]:checked + label .password-protect-page_thumbnail_img:before {
            -webkit-animation-delay: 100ms;
            -moz-animation-delay: 100ms;
            animation-delay: 100ms;
            -webkit-animation-duration: 1s;
            -moz-animation-duration: 1s;
            animation-duration: 1s;
            -webkit-animation-timing-function: ease;
            -moz-animation-timing-function: ease;
            animation-timing-function: ease;
            -webkit-animation-name: checkmark;
            -moz-animation-name: checkmark;
            animation-name: checkmark;
            -webkit-transform: scaleX(-1) rotate(135deg);
            -moz-transform: scaleX(-1) rotate(135deg);
            -ms-transform: scaleX(-1) rotate(135deg);
            -o-transform: scaleX(-1) rotate(135deg);
            transform: scaleX(-1) rotate(135deg);
            -webkit-animation-fill-mode: forwards;
            -moz-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
            z-index: 2;
        }
        #customize-control-ppw_customize_presets_settings input[type="radio"]:checked + label .password-protect-page_thumbnail_img:after{
            visibility: visible;
        }
        #customize-control-ppw_customize_presets_settings img{
            margin-bottom: 0;
        }
        #customize-control-ppw_customize_presets_settings input[type="radio"]:checked + label img{
            opacity: 1;
        }
        #customize-control-ppw_customize_presets_settings .password-protect-page_thumbnail:hover{
            border-color: #ccc;
        }

        @-webkit-keyframes checkmark {
            0% {
                height: 0;
                width: 0;
                opacity: 1;
            }
            20% {
                height: 0;
                width: 5px;
                opacity: 1;
            }
            40% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
            100% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
        }
        @-moz-keyframes checkmark {
            0% {
                height: 0;
                width: 0;
                opacity: 1;
            }
            20% {
                height: 0;
                width: 5px;
                opacity: 1;
            }
            40% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
            100% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
        }
        @keyframes checkmark {
            0% {
                height: 0;
                width: 0;
                opacity: 1;
            }
            20% {
                height: 0;
                width: 5px;
                opacity: 1;
            }
            40% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
            100% {
                height: 10px;
                width: 5px;
                opacity: 1;
            }
        }

	</style>
	<?php
}
add_action( 'customize_controls_print_styles', 'ppw_presets_control_css' );
?>