288 lines
9.4 KiB
PHP
288 lines
9.4 KiB
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' );
|
|
?>
|