( function( api ) { /** * Get luminance from a HEX color. * * @param {string} hex - The hex color. * * @return {number} - Returns the luminance, number between 0 and 255. */ function twentytwentyoneGetHexLum( hex ) { var rgb = twentytwentyoneGetRgbFromHex( hex ); return Math.round( ( 0.2126 * rgb.r ) + ( 0.7152 * rgb.g ) + ( 0.0722 * rgb.b ) ); } /** * Get RGB from HEX. * * @param {string} hex - The hex color. * * @return {Object} - Returns an object {r, g, b} */ function twentytwentyoneGetRgbFromHex( hex ) { var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i, result; // Expand shorthand form (e.g. "03F") to full form (e.g. "0033FF"). hex = hex.replace( shorthandRegex, function( m, r, g, b ) { return r.toString() + r.toString() + g.toString() + g.toString() + b.toString() + b.toString(); } ); result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec( hex ); return result ? { r: parseInt( result[1], 16 ), g: parseInt( result[2], 16 ), b: parseInt( result[3], 16 ) } : null; } // Add listener for the "background_color" control. api( 'background_color', function( value ) { value.bind( function( to ) { var lum = twentytwentyoneGetHexLum( to ), isDark = 127 > lum, textColor = ! isDark ? 'var(--global--color-dark-gray)' : 'var(--global--color-light-gray)', tableColor = ! isDark ? 'var(--global--color-light-gray)' : 'var(--global--color-dark-gray)'; // Modify the body class depending on whether this is a dark background or not. if ( isDark ) { if ( ! document.body.classList.contains( 'has-background-dark' ) ) { document.body.classList.add( 'has-background-dark' ); } } else { document.body.classList.remove( 'has-background-dark' ); } document.documentElement.style.setProperty( '--global--color-primary', textColor ); document.documentElement.style.setProperty( '--global--color-secondary', textColor ); document.documentElement.style.setProperty( '--global--color-background', to ); document.documentElement.style.setProperty( '--button--color-background', textColor ); document.documentElement.style.setProperty( '--button--color-text', to ); document.documentElement.style.setProperty( '--button--color-text-hover', textColor ); document.documentElement.style.setProperty( '--table--stripes-border-color', tableColor ); document.documentElement.style.setProperty( '--table--stripes-background-color', tableColor ); } ); } ); }( wp.customize, _ ) );