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' );
?>