WordPress.org

Make WordPress Core

Ticket #21206: iris-picker.2.diff

File iris-picker.2.diff, 27.6 KB (added by mattwiebe, 20 months ago)
  • wp-includes/script-loader.php

     
    399399 
    400400                $scripts->add( 'farbtastic', '/wp-admin/js/farbtastic.js', array('jquery'), '1.2' ); 
    401401 
     402                $iris_deps = array( 'jquery-ui-draggable', 'jquery-ui-slider' ); 
     403                if ( wp_is_mobile() ) 
     404                        $iris_deps[] = 'touch-punch'; 
     405                $scripts->add( 'iris', '/wp-admin/js/iris.js', $iris_deps, false, 1 ); 
     406 
     407                $scripts->add( 'wp-color-picker', "/wp-admin/js/wp-color-picker$suffix.js", array( 'iris' ), false, 1 ); 
     408                did_action( 'init' ) && $scripts->localize( 'wp-color-picker', 'wpColorPickerL10n', array( 
     409                        'clear' => __( 'Clear' ), 
     410                        'defaultString' => __( 'Default' ), 
     411                        'pick' => __( 'Select a Color' ) 
     412                )); 
     413 
    402414                $scripts->add( 'dashboard', "/wp-admin/js/dashboard$suffix.js", array( 'jquery', 'admin-comments', 'postbox' ), false, 1 ); 
    403415 
    404416                $scripts->add( 'list-revisions', "/wp-includes/js/wp-list-revisions$suffix.js" ); 
     
    426438                        'saveAlert' => __('The changes you made will be lost if you navigate away from this page.') 
    427439                ) ); 
    428440 
    429                 $scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array('farbtastic'), false, 1 ); 
     441                $scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array('wp-color-picker'), false, 1 ); 
    430442                $scripts->add( 'media-gallery', "/wp-admin/js/media-gallery$suffix.js", array('jquery'), false, 1 ); 
    431443        } 
    432444} 
     
    479491        $styles->add( 'install', "/wp-admin/css/install$suffix.css" ); 
    480492        $styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css' ); 
    481493        $styles->add( 'farbtastic', '/wp-admin/css/farbtastic.css', array(), '1.3u1' ); 
     494        $styles->add( 'wp-color-picker', '/wp-admin/css/wp-color-picker.css' ); 
    482495        $styles->add( 'jcrop', '/wp-includes/js/jcrop/jquery.Jcrop.css', array(), '0.9.8' ); 
    483496        $styles->add( 'imgareaselect', '/wp-includes/js/imgareaselect/imgareaselect.css', array(), '0.9.8' ); 
    484497        $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css" ); 
  • wp-admin/js/iris.js

     
     1/*! Iris - v0.9.0 - 2012-08-15 
     2* https://github.com/Automattic/Iris 
     3* Copyright (c) 2012 Matt Wiebe; Licensed GPL */ 
     4(function(a,b){function h(){if(d)e="filter";else{var b=a('<div id="iris-gradtest" />'),c="linear-gradient(top,#fff,#000)";a.each(f,function(a,d){b.css("backgroundImage",d+c);if(b.css("backgroundImage").match("gradient"))return e=a,!1}),a.browser.webkit&&e===!1&&(b.css("background","-webkit-gradient(linear,0% 0%,0% 100%,from(#fff),to(#000))"),b.css("backgroundImage").match("gradient")&&(e="webkit")),b.remove()}}function i(b,c){return b=b==="top"?"top":"left",c=a.isArray(c)?c:Array.prototype.slice.call(arguments,1),e==="webkit"?k(b,c):f[e]+"linear-gradient("+b+", "+c.join(", ")+")"}function j(b,c){b=b==="top"?"top":"left",c=a.isArray(c)?c:Array.prototype.slice.call(arguments,1);var d=b==="top"?0:1,e=a(this),f=c.length-1,g=parseInt(a.browser.version,10)>=8?"-ms-filter":"filter";g="filter";var h=d===1?"left":"top",i=d===1?"right":"bottom",j=d===1?"height":"width",k='<div class="iris-ie-gradient-shim" style="position:absolute;'+j+":100%;"+h+":%start%;"+i+":%end%;"+g+':%filter%;" data-color:"%color%"></div>',m="";e.css("position")==="static"&&e.css({position:"relative"}),c=l(c),a.each(c,function(a,b){if(a===f)return!1;var e=c[a+1];if(b.stop===e.stop)return;var g=100-parseFloat(e.stop)+"%";b.octoHex=(new Color(b.color)).toIEOctoHex(),e.octoHex=(new Color(e.color)).toIEOctoHex();var h="progid:DXImageTransform.Microsoft.Gradient(GradientType="+d+", StartColorStr='"+b.octoHex+"', EndColorStr='"+e.octoHex+"')";m+=k.replace("%start%",b.stop).replace("%end%",g).replace("%filter%",h)}),e.find(".iris-ie-gradient-shim").remove(),a(m).prependTo(e)}function k(b,c){var d=[];return b=b==="top"?"0% 0%,0% 100%,":"0% 100%,100% 100%,",c=l(c),a.each(c,function(a,b){d.push("color-stop("+parseFloat(b.stop)/100+", "+b.color+")")}),"-webkit-gradient(linear,"+b+d.join(",")+")"}function l(b){var c=[],d=[],e=[],f=b.length-1;return a.each(b,function(a,b){var e=b,f=!1,g=b.match(/1?[0-9]{1,2}%$/);g&&(e=b.replace(/\s?1?[0-9]{1,2}%$/,""),f=g.shift()),c.push(e),d.push(f)}),d[0]===!1&&(d[0]="0%"),d[f]===!1&&(d[f]="100%"),d=m(d),a.each(d,function(a){e[a]={color:c[a],stop:d[a]}}),e}function m(b){var c=0,d=b.length-1,e=0,f=!1,g,h,i,j;if(b.length<=2||a.inArray(!1,b)<0)return b;while(e<b.length-1)!f&&b[e]===!1?(c=e-1,f=!0):f&&b[e]!==!1&&(d=e,e=b.length),e++;h=d-c,j=parseInt(b[c].replace("%"),10),g=(parseFloat(b[d].replace("%"))-j)/h,e=c+1,i=1;while(e<d)b[e]=j+i*g+"%",i++,e++;return m(b)}var c='<div class="iris-picker"><div class="iris-picker-inner"><div class="iris-square"><a class="iris-square-value" href="#"><span class="iris-square-handle ui-slider-handle"></span></a><div class="iris-square-slider iris-square-horiz"></div><div class="iris-square-slider iris-square-vert"></div></div><div class="iris-slider iris-hue"><div class="iris-slider-offset"></div></div></div></div>',d=!!(a.browser.msie&&parseInt(a.browser.version,10)<10),e=!1,f=["-moz-","-webkit-","-o-","-ms-"],g='.iris-picker{display:block;position:relative}.iris-border{border-radius:4px;border:1px solid #aaa;width:200px;background-color:#fff}.iris-picker-inner{position:absolute;top:0;right:0;left:0;bottom:0}.iris-border .iris-picker-inner{top:10px;right:10px;left:10px;bottom:10px}.iris-picker .iris-square,.iris-picker .iris-slider,.iris-picker .grad-box{border-radius:4px;-webkit-box-shadow:inset 0 0 5px rgba(0,0,0,0.4);-moz-box-shadow:inset 0 0 5px rgba(0,0,0,0.4);box-shadow:inset 0 0 5px rgba(0,0,0,0.4);height:100%;width:12.5%;float:left;margin-right:5%}.iris-picker .iris-square{width:76%;margin-right:10%}.iris-picker .grad-box{width:auto;margin:0}.iris-picker .iris-square .sat,.iris-ie-9 .iris-square,.iris-ie-9 .iris-slider,.iris-ie-9 .grad-box{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;border-radius:0}.iris-picker .iris-square .sat{-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.iris-ie-lt9 .iris-square,.iris-ie-lt9 .iris-slider,.iris-ie-lt9 .grad-box{outline:1px solid #aaa}.iris-ie-lt9 .iris-square .ui-slider-handle{outline:1px solid #aaa;background-color:#fff;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=30)"}.iris-picker .iris-hue{margin-right:0}.iris-picker .iris-hue .ui-slider-handle{position:absolute;right:-3px;left:-3px;border:4px solid #aaa;border-width:4px 3px;width:auto;height:6px;background:none;border-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,.2);opacity:.9;z-index:5}.iris-hue .ui-slider-handle:before{content:" ";position:absolute;left:-2px;right:-2px;top:-3px;bottom:-3px;border:2px solid #fff;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.iris-picker .iris-result{margin-right:0}.iris-picker .iris-slider-offset{width:100%;height:100%;position:relative;bottom:-6px}.iris-square .iris-square-horiz{position:absolute;top:-7px;left:-7px;height:1px;width:100%}.iris-square .iris-square-vert{position:absolute;right:6px;top:7px;width:1px;height:100%}.iris-square .iris-square-slider a{opacity:.3;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=30)";-moz-transition:opacity 300ms;-webkit-transition:opacity 300ms;transition:opacity 300ms}.iris-square .iris-square-slider .ui-slider-handle.active{opacity:1;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"}.iris-dragging .iris-square-slider .ui-slider-handle.active{opacity:0;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"}.iris-picker .ui-slider-handle{background:#f5f5f5;-webkit-border-radius:10px;-moz-border-radius:50%;border-radius:50%;box-shadow:inset #fff 0 1px 1px,inset 0 -1px 1px rgba( 0,0,0,0.4 ),0px 1px 4px 0 rgba( 0,0,0,0.2 ),0 0 2px rgba( 0,0,0,0.3 );display:block;opacity:0.7;position:absolute;z-index:5;height:20px;width:20px;cursor:default;cursor:ns-resize}.iris-square-horiz .ui-slider-handle{cursor:ew-resize}.iris-square-slider .ui-slider-handle{width:14px;height:14px;opacity:1;background-color:#eee}.iris-picker .iris-square-handle{background:transparent;border:3px solid #fff;box-shadow:inset 0 -1px 1px rgba( 0,0,0,0.4 ),0px 1px 4px 0 rgba( 0,0,0,0.2 ),0 0 2px rgba( 0,0,0,0.3 );width:14px;height:14px;position:absolute;left:-10px;top:-10px;cursor:move}.iris-picker .iris-square-value{width:8px;height:8px;position:absolute}.iris-ie-lt9 .iris-square-value,.iris-mozilla .iris-square-value{width:1px;height:1px}';if(d&&parseInt(a.browser.version,10)<=7)return a.fn.iris=a.noop;a.fn.gradient=function(b){var c=arguments;return this.each(function(){d?j.apply(this,c):a(this).css("backgroundImage",i.apply(this,c))})},a.fn.LSSquare=function(c){return c=c|0,this.each(function(){var d=a(this),e=d.data("hue")!==b;e||(d.append('<div class="sat grad-box" /><div class="lum grad-box" />'),d.css("position","relative"),d.children(".grad-box").css({position:"absolute",top:0,left:0,bottom:0,right:0}));var f=d.find(".lum"),g=d.find(".sat");e||f.gradient("top","#fff","rgba(255,255,255,0) 50%","rgba(0,0,0,0) 50%","rgba(0,0,0,1)"),g.gradient("left","hsl("+c+",0%,50%)","hsl("+c+",100%,50%)"),d.data("hue",c)})},a.fn.raninbowGradient=function(b,c){b=b||"top";var d=a.extend({},{s:100,l:50},c),e="hsl(%h%,"+d.s+"%,"+d.l+"%)",f=0,g=[];while(f<=360)g.push(e.replace("%h%",f)),f+=30;return this.each(function(){a(this).gradient(b,g)})};var n={options:{color:!1,displayType:"float/inline",hide:!0,border:!0,target:!1,width:200},_inited:!1,_create:function(){var b=this.element,d=this.options.color||b.val();e===!1&&h(),b.is("input")?(this.options.target?this.picker=a(c).appendTo(this.options.target):this.picker=a(c).insertAfter(b),this._addInputListeners(b)):(b.append(c),this.picker=b.find(".iris-picker"));if(a.browser.mozilla)this.picker.addClass("iris-mozilla");else if(a.browser.msie){var f=parseInt(a.browser.version,10);f===9?this.picker.addClass("iris-ie-9"):f<=8&&this.picker.addClass("iris-ie-lt9")}this.color=new Color(d),this.options.color=this.color.toString(),this.controls={},this.controls.square=this.picker.find(".iris-square"),this.controls.result=this.picker.find(".iris-result");var g=this.hue=this.color.h();this.options.hide&&this.picker.hide(),this.options.border&&this.picker.addClass("iris-border"),this.controls.square.LSSquare(g),this.picker.find(".iris-hue").raninbowGradient(),this._initControls(),this.active="external",this._dimensions(),this._change()},_dimensions:function(a){var b=this.picker.find(".iris-picker-inner"),c=this.controls,d=c.square,e=this.picker.find(".iris-hue"),f="77.5%",g="12%",h=20,i=this.options.border?this.options.width-h:this.options.width,j;a&&(d.css("width",""),e.css("width",""),this.picker.removeAttr("style")),f=i*(parseFloat(f)/100),g=i*(parseFloat(g)/100),j=this.options.border?f+h:f,d.width(f).height(f),e.height(f).width(g),this.picker.css({width:this.options.width,height:j})},_addInputListeners:function(a){var b=this;a.on("change",function(c){var d=new Color(a.val()),e=a.val().replace(/^#/,"");d.toInt()===0&&e!=="000000"?a.val(b.color.toString()):b._setOption("color",d.toString())})},_initControls:function(){var b=this,c=b.controls.square,d=b.color.h();b.controls.h=b.picker.find(".iris-hue .iris-slider-offset").slider({orientation:"vertical",max:359,min:0,value:359-d,slide:function(a,c){b.active="h",c.value=359-c.value,b.color.h(c.value),b._change.apply(b,arguments)}}),b.controls.squareDrag=b.picker.find(".iris-square-value").draggable({containment:"parent",zIndex:1e3,cursor:"move",drag:function(a,c){b._squareDrag(a,c)},start:function(){c.addClass("iris-dragging")},stop:function(){c.removeClass("iris-dragging")}}),c.mousedown(function(c){if(c.button!==0)return;if(!a(c.target).is("div"))return;var d=b.controls.square.offset(),e={top:c.pageY-d.top,left:c.pageX-d.left};c.preventDefault(),b._squareDrag(c,{position:e}),c.target=b.controls.squareDrag.get(0),b.controls.squareDrag.css(e).trigger(c)}),b.controls.s=c.find(".iris-square-horiz").slider({slide:function(a,c){b.color.s(c.value),b.active="s",b._change.apply(b,arguments)}}),b.controls.l=c.find(".iris-square-vert").slider({orientation:"vertical",slide:function(a,c){b.color.l(c.value),b.active="l",b._change.apply(b,arguments)}}),b.controls.square.mousemove(function(c){var d=a(this),e=d.offset(),f=c.pageX-e.left,g=c.pageY-e.top,h=d.find(".iris-square-horiz .ui-slider-handle"),i=d.find(".iris-square-vert .ui-slider-handle");f>b.controls.square.width()-20?i.addClass("active"):i.removeClass("active"),g<20?h.addClass("active"):h.removeClass("active")}),b.controls.square.mouseleave(function(){a(this).find(".iris-square-slider .ui-slider-handle").removeClass("active")})},_squareDrag:function(a,b){var c=this,d=c._squareDimensions(),e=Math.round((d.h-b.position.top)/d.h*100),f=100-Math.round((d.w-b.position.left)/d.w*100);c.color.s(f).l(e),c.active="square",c._change.apply(c,arguments)},_setOption:function(a,b){var c=this.options[a];if(a==="color"){b=""+b;var d=b.replace(/^#/,""),e=d==="0"||d==="000"||d==="000000",f=new Color(b);if(f.toInt()!==0||!e)this.color=f,this.active="external",this._change(),this.options[a]=this.color.toString()}},_squareDimensions:function(a){var c=this.controls.square,d,e;return a!==b&&c.data("dimensions")?c.data("dimensions"):(e=this.controls.squareDrag,d={w:c.width(),h:c.height()},c.data("dimensions",d),d)},_change:function(b,c){var d=this,e=d.controls,f=d.color.toHsl(),g=d.color.toString(),h=["s","l","square"];d.active==="external"||d.active==="h"?(e.square.LSSquare(f.h),d.active==="h"?h=[]:h.push("h"),this.hue=f.h):f.h!==this.hue&&(f.h=this.hue,d.color.h(this.hue)),g=d.color.toString(),a.each(h,function(a,b){if(b!==d.active)switch(b){case"h":e.h.slider("value",359-f.h);break;case"s":d.active!=="l"&&e.s.slider("value",f.s);break;case"l":d.active!=="s"&&e.l.slider("value",f.l);break;case"square":var c=d._squareDimensions(),g={left:f.s/100*c.w,top:c.h-f.l/100*c.h};d.active==="s"?delete g.top:d.active==="l"&&delete g.left,d.controls.squareDrag.css(g)}}),this.controls.result.css("backgroundColor",g),this.element.is(":input")&&this.element.val(g),this._inited&&this._trigger("change",{type:this.active},{color:this.color}),this._inited=!0,this.active=!1},show:function(){this.picker.show()},hide:function(){this.picker.hide()},toggle:function(){this.picker.toggle()}};a.widget("a8c.iris",n),a('<style id="iris-css">'+g+"</style>").appendTo("head")})(jQuery),function(a,b){var c=function(a,b){return this._init(a,b),this};c.prototype={_color:0,_alpha:1,__hsl:{h:0,s:0,l:0},_init:function(a){var c="noop";switch(typeof a){case"object":return this._alpha=a.a||1,c=a.r!==b?"fromRgb":a.l!==b?"fromHsl":c,this[c](a);case"string":return this.fromCSS(a);case"number":return this.fromInt(parseInt(a,10))}return this},noop:function(){return this},fromCSS:function(a){var b,c;return a.match(/^(rgb|hsl)a?/)?(c=a.replace(/(\s|%)/g,"").replace(/^(rgb|hsl)a?\(/,"").replace(/\);?$/,"").split(","),c.length===4&&(this._alpha=parseFloat(c.pop())),a.match(/^rgb/)?this.fromRgb({r:parseInt(c[0],10),g:parseInt(c[1],10),b:parseInt(c[2],10)}):this.fromHsl({h:parseInt(c[0],10),s:parseInt(c[1],10),l:parseInt(c[2],10)})):this.fromHex(a)},fromRgb:function(a,b){return this.fromInt(parseInt((a.r<<16)+(a.g<<8)+a.b,10),b)},fromHex:function(a){return a=a.replace(/^#/,""),a.length===3&&(a=a[0]+a[0]+a[1]+a[1]+a[2]+a[2]),this.fromInt(parseInt(a,16))},fromHsl:function(a){var b,c,d,e,f,g,h,i;return this.__hsl=a,g=a.h/360,h=a.s/100,i=a.l/100,h===0?b=c=d=i:(e=i<.5?i*(1+h):i+h-i*h,f=2*i-e,b=this.hue2rgb(f,e,g+1/3),c=this.hue2rgb(f,e,g),d=this.hue2rgb(f,e,g-1/3)),this.fromRgb({r:b*255,g:c*255,b:d*255},!0)},fromInt:function(a,c){return this._color=parseInt(a,10),c===b&&(this.__hsl.h=this.__hsl.s=0),this},hue2rgb:function(a,b,c){return c<0&&(c+=1),c>1&&(c-=1),c<1/6?a+(b-a)*6*c:c<.5?b:c<2/3?a+(b-a)*(2/3-c)*6:a},toString:function(){var a=parseInt(this._color,10).toString(16);if(a.length<6)for(var b=6-a.length-1;b>=0;b--)a="0"+a;return"#"+a},toCSS:function(a,b){a=a||"hex",b=parseFloat(b||this._alpha);switch(a){case"rgb":case"rgba":var c=this.toRgb();return b<1?"rgba( "+c.r+", "+c.g+", "+c.b+", "+b+" )":"rgb( "+c.r+", "+c.g+", "+c.b+" )";case"hsl":case"hsla":var d=this.toHsl();return b<1?"hsla( "+d.h+", "+d.s+", "+d.l+", "+b+" )":"hsl( "+d.h+", "+d.s+", "+d.l+" )";default:return this.toString()}},toRgb:function(){return{r:255&this._color>>16,g:255&this._color>>8,b:255&this._color}},toHsl:function(){var a=this.toRgb(),b=a.r/255,c=a.g/255,d=a.b/255,e=Math.max(b,c,d),f=Math.min(b,c,d),g,h,i=(e+f)/2;if(e===f)g=h=0;else{var j=e-f;h=i>.5?j/(2-e-f):j/(e+f);switch(e){case b:g=(c-d)/j+(c<d?6:0);break;case c:g=(d-b)/j+2;break;case d:g=(b-c)/j+4}g/=6}return g=Math.round(g*360),g===0&&this.__hsl.h!==g&&(g=this.__hsl.h),h=Math.round(h*100),h===0&&this.__hsl.s&&(h=this.__hsl.s),{h:g,s:h,l:Math.round(i*100)}},toInt:function(){return this._color},toIEOctoHex:function(){var a=this.toString(),b=parseInt(255*this._alpha,10).toString(16);return b.length===1&&(b="0"+b),"#"+b+a.replace(/^#/,"")},toLuminosity:function(){var a=this.toRgb();return.2126*Math.pow(a.r/255,2.2)+.7152*Math.pow(a.g/255,2.2)+.0722*Math.pow(a.b/255,2.2)},getDistanceLuminosityFrom:function(a){if(a instanceof c){var b=this.toLuminosity(),d=a.toLuminosity();return b>d?(b+.05)/(d+.05):(d+.05)/(b+.05)}throw"getDistanceLuminosityFrom requires a Color object"},getMaxContrastColor:function(){var a=this.toLuminosity(),b=a>=.5?"000000":"ffffff";return new c(b)},getGrayscaleContrastingColor:function(a){if(!a)return this.getMaxContrastColor();var b=a<5?5:a,c=this.getMaxContrastColor();a=c.getDistanceLuminosityFrom(this);if(a<=b)return c;var d=0===c.toInt()?1:-1;while(a>b)c=c.incrementLightness(d),a=c.getDistanceLuminosityFrom(this);return c},getReadableContrastingColor:function(a,d){if(!a instanceof c)return this;var e=d===b?5:d,f=a.getDistanceLuminosityFrom(this),g=a.getMaxContrastColor(),h=g.getDistanceLuminosityFrom(a);if(h<=e)return g;if(f>=e)return this;var i=0===g.toInt()?-1:1;while(f<e){this.incrementLightness(i),f=this.getDistanceLuminosityFrom(a);if(this._color===0||this._color===16777215)break}return this},h:function(a){return this._hsl("h",a)},s:function(a){return this._hsl("s",a)},l:function(a){return this._hsl("l",a)},_hsl:function(a,c){var d=this.toHsl();return c===b?d[a]:(a==="h"?d[a]=c%360:d[a]=c<0?0:c>100?100:c,this.fromHsl(d))},darken:function(a){return a=a||5,this.incrementLightness(-a)},lighten:function(a){return a=a||5,this.incrementLightness(a)},incrementLightness:function(a){return this.l(this.l()+a)},saturate:function(a){return a=a||15,this.incrementSaturation(a)},desaturate:function(a){return a=a||15,this.incrementSaturation(-a)},incrementSaturation:function(a){return this.s(this.s()+a)},toGrayscale:function(){return this.h(0)},getComplement:function(){return this.incrementHue(180)},getSplitComplement:function(a){a=a||1;var b=180+a*30;return this.incrementHue(b)},getAnalog:function(a){a=a||1;var b=a*30;return this.incrementHue(b)},getTetrad:function(a){a=a||1;var b=a*60;return this.incrementHue(b)},getTriad:function(a){a=a||1;var b=a*120;return this.incrementHue(b)},incrementHue:function(a){return this.h(this.h()+a)}},a.Color=c}(typeof exports=="object"&&exports||this); 
     5 No newline at end of file 
  • wp-admin/js/wp-color-picker.dev.js

     
     1( function( $ ){ 
     2 
     3        // html stuff 
     4        var _before = '<span class="wp-color-result" />'; 
     5        var _after = '<div class="wp-picker-holder" />'; 
     6        var _wrap = '<div class="wp-picker-container" />'; 
     7        var _button = '<input type="button" class="button hidden" />'; 
     8 
     9        // jQuery UI Widget constructor 
     10        var ColorPicker = { 
     11                options: { 
     12                        defaultColor: false, 
     13                        change: false, 
     14                        clear: false, 
     15                        hide: true 
     16                }, 
     17                _create: function() { 
     18                        // bail early for IE < 8 
     19                        if ( $.browser.msie && parseInt( $.browser.version, 10 ) < 8 ) 
     20                                return; 
     21                        var self = this; 
     22                        var el = self.element; 
     23                        $.extend( self.options, el.data() ); 
     24 
     25                        self.initialValue = el.val(); 
     26 
     27                        // Set up HTML structure, hide things 
     28                        el.addClass( 'wp-color-picker' ).hide().wrap( _wrap ); 
     29                        self.wrap = el.parent(); 
     30                        self.toggler = $( _before ).insertBefore( el ).css( { backgroundColor: self.initialValue } ).attr( "title", wpColorPickerL10n.pick ); 
     31                        self.pickerContainer = $( _after ).insertAfter( el ); 
     32                        self.button = $( _button ); 
     33 
     34                        if ( self.options.defaultColor ) 
     35                                self.button.addClass( 'wp-picker-default' ).val( wpColorPickerL10n.defaultString ); 
     36                        else 
     37                                self.button.addClass( 'wp-picker-clear' ).val( wpColorPickerL10n.clear ); 
     38 
     39                        self.button.insertAfter( el ); 
     40 
     41                        el.iris( { 
     42                                target: self.pickerContainer, 
     43                                hide: true, 
     44                                change: function( event, ui ) { 
     45                                        self.toggler.css( { backgroundColor: ui.color.toString() } ); 
     46                                        // check for a custom cb 
     47                                        if ( $.isFunction( self.options.change ) ) 
     48                                                self.options.change.call( this, event, ui ); 
     49                                } 
     50                        } ); 
     51                        el.val( self.initialValue ); 
     52                        self._addListeners(); 
     53                        if ( ! self.options.hide ) 
     54                                self.toggler.click(); 
     55                }, 
     56                _addListeners: function() { 
     57                        var self = this; 
     58 
     59                        self.toggler.click( function( event ){ 
     60                                event.stopPropagation(); 
     61                                self.element.toggle().iris( 'toggle' ); 
     62                                self.button.toggleClass('hidden'); 
     63                                self.toggler.toggleClass( 'wp-picker-open' ); 
     64 
     65                                // close picker when you click outside it 
     66                                if ( self.toggler.hasClass( 'wp-picker-open' ) ) 
     67                                        $( "body" ).on( 'click', { wrap: self.wrap, toggler: self.toggler }, self._bodyListener ); 
     68                                else 
     69                                        $( "body" ).off( 'click', self._bodyListener ); 
     70                        }); 
     71 
     72                        self.button.click( function( event ) { 
     73                                var me = $(this); 
     74                                if ( me.hasClass( 'wp-picker-clear' ) ) { 
     75                                        self.element.val( '' ); 
     76                                        if ( $.isFunction( self.options.clear ) ) 
     77                                                self.options.clear.call( this, event ); 
     78                                } else if ( me.hasClass( 'wp-picker-default' ) ) { 
     79                                        self.element.val( self.options.defaultColor ).change(); 
     80                                } 
     81                        }); 
     82                }, 
     83                _bodyListener: function( event ) { 
     84                        if ( ! event.data.wrap.find( event.target ).length ) 
     85                                        event.data.toggler.click(); 
     86                } 
     87        } 
     88 
     89        $.widget( 'wp.wpColorPicker', ColorPicker ); 
     90}( jQuery ) ); 
     91 No newline at end of file 
  • wp-admin/js/custom-background.dev.js

     
    1 var farbtastic, pickColor; 
    2  
    31(function($) { 
    42 
    5         var defaultColor = ''; 
    6  
    7         pickColor = function(color) { 
    8                 farbtastic.setColor(color); 
    9                 $('#background-color').val(color); 
    10                 $('#custom-background-image').css('background-color', color); 
    11                 // If we have a default color, and they match, then we need to hide the 'Default' link. 
    12                 // Otherwise, we hide the 'Clear' link when it is empty. 
    13                 if ( ( defaultColor && color === defaultColor ) || ( ! defaultColor && ( '' === color || '#' === color ) ) ) 
    14                         $('#clearcolor').hide(); 
    15                 else 
    16                         $('#clearcolor').show(); 
    17         } 
    18  
    193        $(document).ready(function() { 
     4                var bgImage = $("#custom-background-image"); 
    205 
    21                 defaultColor = $('#defaultcolor').val(); 
    22  
    23                 $('#pickcolor').click(function() { 
    24                         $('#colorPickerDiv').show(); 
    25                         return false; 
     6                $('#background-color').wpColorPicker({ 
     7                        change: function( event, ui ) { 
     8                                bgImage.css('background-color', ui.color.toString()); 
     9                        }, 
     10                        clear: function() { 
     11                                bgImage.css('background-color', ''); 
     12                        } 
    2613                }); 
    2714 
    28                 $('#clearcolor a').click( function(e) { 
    29                         pickColor( defaultColor ); 
    30                         e.preventDefault(); 
    31                 }); 
    32  
    33                 $('#background-color').keyup(function() { 
    34                         var _hex = $('#background-color').val(), hex = _hex; 
    35                         if ( hex.charAt(0) != '#' ) 
    36                                 hex = '#' + hex; 
    37                         hex = hex.replace(/[^#a-fA-F0-9]+/, ''); 
    38                         if ( hex != _hex ) 
    39                                 $('#background-color').val(hex); 
    40                         if ( hex.length == 4 || hex.length == 7 ) 
    41                                 pickColor( hex ); 
    42                 }); 
    43  
    4415                $('input[name="background-position-x"]').change(function() { 
    45                         $('#custom-background-image').css('background-position', $(this).val() + ' top'); 
     16                        bgImage.css('background-position', $(this).val() + ' top'); 
    4617                }); 
    4718 
    4819                $('input[name="background-repeat"]').change(function() { 
    49                         $('#custom-background-image').css('background-repeat', $(this).val()); 
     20                        bgImage.css('background-repeat', $(this).val()); 
    5021                }); 
    51  
    52                 farbtastic = $.farbtastic('#colorPickerDiv', function(color) { 
    53                         pickColor(color); 
    54                 }); 
    55                 pickColor($('#background-color').val()); 
    56  
    57                 $(document).mousedown(function(){ 
    58                         $('#colorPickerDiv').each(function(){ 
    59                                 var display = $(this).css('display'); 
    60                                 if ( display == 'block' ) 
    61                                         $(this).fadeOut(2); 
    62                         }); 
    63                 }); 
    6422        }); 
    6523 
    6624})(jQuery); 
    67  No newline at end of file 
  • wp-admin/css/wp-color-picker.css

     
     1.wp-color-picker { 
     2        width: 80px; 
     3} 
     4.wp-color-result { 
     5        display: inline-block; 
     6        width: 48px; 
     7        height: 21px; 
     8        border: 1px solid #dfdfdf; 
     9        background-color: #f9f9f9; 
     10        margin: 0 6px 1px 0px; 
     11        vertical-align: bottom; 
     12        top: 1px; 
     13        border-radius: 3px; 
     14        position: relative; 
     15        cursor: pointer; 
     16        -webkit-user-select: none; 
     17        -moz-user-select: none; 
     18        -ms-user-select: none; 
     19        user-select: none; 
     20} 
     21.wp-color-result.wp-picker-open { 
     22        top: 0; 
     23} 
     24.wp-color-result:after { 
     25        content: "▾"; 
     26        font-size: 11px; 
     27        line-height: 21px; 
     28        color: #aaa; 
     29        position: absolute; 
     30        width: 16px; 
     31        background-color: #f9f9f9; 
     32        right: 0px; 
     33        top: 0px; 
     34        bottom: 0px; 
     35        border-radius: 0 2px 2px 0; 
     36        border-left: 1px solid #dfdfdf; 
     37        text-align: center; 
     38} 
     39.wp-color-result.wp-picker-open:after { 
     40        content: "▴" 
     41} 
     42.wp-color-result:hover { 
     43        border-color: #aaa; 
     44} 
     45.wp-color-result:hover:after { 
     46        color: #888; 
     47        border-color: #aaa; 
     48} 
     49.wp-picker-container { 
     50        display: inline-block; 
     51} 
     52.wp-picker-container .iris-picker { 
     53        border-color: #dfdfdf; 
     54        margin-top: 6px; 
     55} 
     56.wp-picker-container .button { 
     57        margin-left: 6px; 
     58} 
     59 No newline at end of file 
  • wp-admin/custom-background.php

     
    108108                add_thickbox(); 
    109109                wp_enqueue_script('media-upload'); 
    110110                wp_enqueue_script('custom-background'); 
    111                 wp_enqueue_style('farbtastic'); 
     111                wp_enqueue_style('wp-color-picker'); 
    112112        } 
    113113 
    114114        /** 
     
    327327<tr valign="top"> 
    328328<th scope="row"><?php _e( 'Background Color' ); ?></th> 
    329329<td><fieldset><legend class="screen-reader-text"><span><?php _e( 'Background Color' ); ?></span></legend> 
    330 <?php $show_clear = get_theme_mod('background_color') ? '' : ' style="display:none"'; ?> 
    331 <input type="text" name="background-color" id="background-color" value="#<?php echo esc_attr(get_background_color()) ?>" /> 
    332 <a class="hide-if-no-js" href="#" id="pickcolor"><?php _e('Select a Color'); ?></a> <span<?php echo $show_clear; ?> class="hide-if-no-js" id="clearcolor"> (<a href="#"><?php current_theme_supports( 'custom-background', 'default-color' ) ? _e( 'Default' ) : _e( 'Clear' ); ?></a>)</span> 
    333 <input type="hidden" id="defaultcolor" value="<?php if ( current_theme_supports( 'custom-background', 'default-color' ) ) echo '#' . esc_attr( get_theme_support( 'custom-background', 'default-color' ) ); ?>" /> 
    334 <div id="colorPickerDiv" style="z-index: 100; background:#eee; border:1px solid #ccc; position:absolute; display:none;"></div> 
     330<?php $default_color = current_theme_supports( 'custom-background', 'default-color' ) ? 'data-default-color="#' . esc_attr( get_theme_support( 'custom-background', 'default-color' ) ) . '" ' : ''; ?> 
     331<input type="text" name="background-color" id="background-color" value="#<?php echo esc_attr(get_background_color()) ?>" <?php echo $default_color ?>/> 
    335332</fieldset></td> 
    336333</tr> 
    337334</tbody>