%PDF- %PDF-
| Direktori : /home/infra/betheme/betheme/muffin-options/fields/color/ |
| Current File : //home/infra/betheme/betheme/muffin-options/fields/color/field_color.js |
/**
* wp-color-picker-alpha
*
* Overwrite Automattic Iris for enabled Alpha Channel in wpColorPicker
* Only run in input and is defined data alpha in true
*
* Version: 2.1.4
* https://github.com/kallookoo/wp-color-picker-alpha
* Licensed under the GPLv2 license.
*/
!function(t){if(!t.wp.wpColorPicker.prototype._hasAlpha){var o="";Color.fn.toString=function(){if(this._alpha<1)return this.toCSS("rgba",this._alpha).replace(/\s+/g,"");var t=parseInt(this._color,10).toString(16);return this.error?"":(t.length<6&&(t=("00000"+t).substr(-6)),"#"+t)},t.widget("wp.wpColorPicker",t.wp.wpColorPicker,{_hasAlpha:!0,_create:function(){if(t.support.iris){var i=this,a=i.element,e="Color value",r="Select color",s="Default",n="Clear";if(t.extend(i.options,a.data()),"hue"===i.options.type)return i._createHueOnly();i.close=t.proxy(i.close,i),i.initialValue=a.val(),a.addClass("wp-color-picker"),a.parent("label").length||(a.wrap("<label></label>"),i.wrappingLabelText=t('<span class="screen-reader-text"></span>').insertBefore(a).text(e)),i.wrappingLabel=a.parent(),i.wrappingLabel.wrap('<div class="wp-picker-container" />'),i.wrap=i.wrappingLabel.parent(),i.toggler=t('<button type="button" class="button wp-color-result" aria-expanded="false"><span class="wp-color-result-text"></span></button>').insertBefore(i.wrappingLabel).css({backgroundColor:i.initialValue}),i.toggler.find(".wp-color-result-text").text(r),i.pickerContainer=t('<div class="wp-picker-holder" />').insertAfter(i.wrappingLabel),i.button=t('<input type="button" class="button button-small" />'),i.options.defaultColor?i.button.addClass("wp-picker-default").val(s):i.button.addClass("wp-picker-clear").val(n),i.wrappingLabel.wrap('<span class="wp-picker-input-wrap hidden" />').after(i.button),i.inputWrapper=a.closest(".wp-picker-input-wrap"),a.iris({target:i.pickerContainer,hide:i.options.hide,width:i.options.width,mode:i.options.mode,palettes:i.options.palettes,change:function(a,e){i.options.alpha?(i.toggler.css({"background-image":"url("+o+")"}),i.toggler.css({position:"relative"}),0==i.toggler.find("span.color-alpha").length&&i.toggler.append('<span class="color-alpha" />'),i.toggler.find("span.color-alpha").css({width:"30px",height:"100%",position:"absolute",top:0,left:0,"border-top-left-radius":"2px","border-bottom-left-radius":"2px",background:e.color.toString()})):i.toggler.css({backgroundColor:e.color.toString()}),t.isFunction(i.options.change)&&i.options.change.call(this,a,e)}}),a.val(i.initialValue),i._addListeners(),i.options.hide||i.toggler.click()}},_addListeners:function(){var o=this;o.wrap.on("click.wpcolorpicker",function(t){t.stopPropagation()}),o.toggler.click(function(){o.toggler.hasClass("wp-picker-open")?o.close():o.open()}),o.element.on("change",function(i){(""===t(this).val()||o.element.hasClass("iris-error"))&&(o.options.alpha?o.toggler.find("span.color-alpha").css("backgroundColor",""):o.toggler.css("backgroundColor",""),t.isFunction(o.options.clear)&&o.options.clear.call(this,i))}),o.button.on("click",function(i){t(this).hasClass("wp-picker-clear")?(o.element.val(""),o.options.alpha?o.toggler.find("span.color-alpha").css("backgroundColor",""):o.toggler.css("backgroundColor",""),t.isFunction(o.options.clear)&&o.options.clear.call(this,i),o.element.trigger("change")):t(this).hasClass("wp-picker-default")&&o.element.val(o.options.defaultColor).change()})}}),t.widget("a8c.iris",t.a8c.iris,{_create:function(){if(this._super(),this.options.alpha=this.element.data("alpha")||!1,this.element.is(":input")||(this.options.alpha=!1),void 0!==this.options.alpha&&this.options.alpha){var o=this,i=o.element,a=t('<div class="iris-strip iris-slider iris-alpha-slider"><div class="iris-slider-offset iris-slider-offset-alpha"></div></div>').appendTo(o.picker.find(".iris-picker-inner")),e=a.find(".iris-slider-offset-alpha"),r={aContainer:a,aSlider:e};void 0!==i.data("custom-width")?o.options.customWidth=parseInt(i.data("custom-width"))||0:o.options.customWidth=100,o.options.defaultWidth=i.width(),(o._color._alpha<1||-1!=o._color.toString().indexOf("rgb"))&&i.width(parseInt(o.options.defaultWidth+o.options.customWidth)),t.each(r,function(t,i){o.controls[t]=i}),o.controls.square.css({"margin-right":"0"});var s=o.picker.width()-o.controls.square.width()-20,n=s/6,l=s/2-n;t.each(["aContainer","strip"],function(t,i){o.controls[i].width(l).css({"margin-left":n+"px"})}),o._initControls(),o._change()}},_initControls:function(){if(this._super(),this.options.alpha){var t=this;t.controls.aSlider.slider({orientation:"vertical",min:0,max:100,step:1,value:parseInt(100*t._color._alpha),slide:function(o,i){t._color._alpha=parseFloat(i.value/100),t._change.apply(t,arguments)}})}},_change:function(){this._super();var t=this,i=t.element;if(this.options.alpha){var a=t.controls,e=parseInt(100*t._color._alpha),r=t._color.toRgb(),s=["rgb("+r.r+","+r.g+","+r.b+") 0%","rgba("+r.r+","+r.g+","+r.b+", 0) 100%"],n=t.options.defaultWidth,l=t.options.customWidth,p=t.picker.closest(".wp-picker-container").find(".wp-color-result");a.aContainer.css({background:"linear-gradient(to bottom, "+s.join(", ")+"), url("+o+")"}),p.hasClass("wp-picker-open")&&(a.aSlider.slider("value",e),t._color._alpha<1?(a.strip.attr("style",a.strip.attr("style").replace(/rgba\(([0-9]+,)(\s+)?([0-9]+,)(\s+)?([0-9]+)(,(\s+)?[0-9\.]+)\)/g,"rgb($1$3$5)")),i.width(parseInt(n+l))):i.width(n))}(i.data("reset-alpha")||!1)&&t.picker.find(".iris-palette-container").on("click.palette",".iris-palette",function(){t._color._alpha=1,t.active="external",t._change()}),i.trigger("change")},_addInputListeners:function(t){var o=this,i=function(i){var a=new Color(t.val()),e=t.val();t.removeClass("iris-error"),a.error?""!==e&&t.addClass("iris-error"):a.toString()!==o._color.toString()&&("keyup"===i.type&&e.match(/^[0-9a-fA-F]{3}$/)||o._setOption("color",a.toString()))};t.on("change",i).on("keyup",o._debounce(i,100)),o.options.hide&&t.on("focus",function(){o.show()})}})}}(jQuery);
/**
* mfnFieldColor
*/
(function($) {
/* globals jQuery */
"use strict";
$(function($) {
var group = '.form-group.color-picker '; // all field including builder
var $on_load = $('.form-group.color-picker', '.mfn-options, .mfn-meta'); // theme options and page options only
/**
* Get contrast for icon background and border
*/
function getContrastYIQ( hexcolor, tolerance ){
hexcolor = hexcolor.replace( "#", "" );
tolerance = typeof tolerance !== 'undefined' ? tolerance : 169;
if( 6 != hexcolor.length ){
return false;
}
var r = parseInt( hexcolor.substr(0,2),16 );
var g = parseInt( hexcolor.substr(2,2),16 );
var b = parseInt( hexcolor.substr(4,2),16 );
var yiq = ( ( r*299 ) + ( g*587 ) + ( b*114 ) ) / 1000;
return ( yiq >= tolerance ) ? 'light' : 'dark';
}
/**
* Set color
*/
function setColor( el, color ){
var $form = el.closest('.color-picker-group');
if( ! color ){
return;
}
$('.mfn-form-input', $form).val( color ).trigger('change').trigger('blur');
$('.label', $form).removeClass('light dark').addClass(getContrastYIQ(color));
$('.label', $form).css('background-color', color);
if( ! getContrastYIQ(color, 240) || 'light' == getContrastYIQ(color, 240) ){
// very light colors need light grey border
$('.label', $form).css('border-color', '');
} else {
$('.label', $form).css('border-color', color);
}
}
/**
* wpColorPicker init
*/
function init( $el ){
$( 'input.has-colorpicker', $el ).wpColorPicker({
mode : 'hsl',
width : 283,
change : function(event, ui) {
setColor( $(this), ui.color.toString() );
},
clear : function() {
setColor( $(this), '' );
}
});
}
init( $on_load );
/**
* Input change
* update color picker
*/
$('.mfn-ui').on('keyup', group + '.mfn-form-input', function() {
var $form = $(this).closest('.color-picker-group');
var val = $(this).val();
// update colorpicker only after full hash is entered
if( val.length < 7 ){
$(this).trigger('change');
return false;
}
$( 'input.has-colorpicker', $form ).wpColorPicker( 'color', val );
});
/**
* Clear button
* update color picker and remove input value
*/
$('.mfn-ui').on('click', group + '.color-picker-clear', function(e) {
e.preventDefault();
var $form = $(this).closest('.color-picker-group');
$( '.mfn-form-input, .wp-color-picker', $form ).val('');
$('.label', $form).removeClass('dark').css({
'background-color' : '',
'border-color' : ''
});
$( '.mfn-form-input', $form ).trigger('focus');
});
/**
* Reset color picker on builder edit modal open
*/
$(document).on('mfn:builder:edit', function( $this, modal ){
var $modal = $(modal);
$('.color-picker-group', $modal).each(function() {
var $cp = $(this);
var $cpInput = $('input.has-colorpicker', $cp);
if( $cpInput.length ){
var $clone = $cpInput.clone();
$clone.show().removeClass('wp-color-picker').prependTo($cp);
$('.wp-picker-container', $cp).remove();
}
init( $cp );
});
});
});
})(jQuery);