question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Admin bar integration and W3 Total Cache Minify conflict

See original GitHub issue

Bug Description

After 1.7.0, a user in the forums reported that Site Kit’s admin bar integration and the minify option in the W3 Total Cache plugin conflict causing display issues in the admin bar integration: Broken admin bar with W3TC Minify

In some themes, like WoodMart, CSS display issues also appear when viewing the site while logged in:

Woodmart- Site Kit and W3TC conflict

Disabling W3 Total Cache’s minify option resolves the issue in both cases (admin bar and broken site CSS). For the theme issue, disabling Site Kit’s admin bar via the following filter also restores the correct display of the site (while W3TC minify is enabled):

add_filter( 'googlesitekit_show_admin_bar_menu', '__return_false', 1000 );

Steps to reproduce

  1. Setup Site Kit and W3 Total Cache with minify option enabled (Performance > General Settings > Minify > Enable) with defaults selected.
  2. View a page of the site with stats (to show admin bar integration) while logged in
  3. See broken admin bar integration
  4. Activate WoodMart theme, see broken display of site additionally.

Screenshots

Correct display with default theme (W3TC minify disabled) Twentyninteen- W3TC disabled

Correct display with Woodmart theme (W3TC minify disabled)

Woodmart- W3TC minify disabled

Additional Context

  • PHP Version: 7.3.16
  • OS: MacOS
  • Browser: Chrome
  • Plugin Version: 1.7.0
  • Device: MacBook Air

Related support topic: https://wordpress.org/support/topic/new-update-breaking-my-site-css-on-admin-side/


Do not alter or remove anything below. The following sections will be managed by moderators only.

Acceptance criteria

  • Admin bar should display correctly with Woodmart theme and W3 Total Cache Minify enabled.

Implementation Brief

  • Using Admin_Bar/Admin_Bar.php

  • Edit the register method and add a filter add_filter() with the following:

    • filter hook name w3tc_minify_css_enable
    • callback function which returns false
    • priority of 10
    • accepted arguments of 1
  • Add a comment to explain why this filter has been added with @since n.e.x.t to add the version number when it was introduced

  • Using assets/sass/components/adminbar/_googlesitekit-wp-adminbar.scss,

    • Update the background image styles of the .googlesitekit-wp-adminbar.hover .googlesitekit-wp-adminbar__icon selector along with the other selectors having the same styles to have the SVG background image as a base64 encoded string.
    background-image: url("");
    

QA Brief

  • Setup Site Kit and W3 Total Cache with minify option enabled (Performance > General Settings > Minify > Enable) with defaults selected.
  • View a page of the site with stats (to show admin bar integration) while logged in
  • The admin bar should not be broken.
  • Additionally, test with the WoodMart theme to see if the admin bar renders correctly.

Changelog entry

  • Fix admin bar styles conflict with W3 Total Cache Minify functionality.

Issue Analytics

  • State:closed
  • Created 3 years ago
  • Comments:11 (3 by maintainers)

github_iconTop GitHub Comments

6reactions
asvinbcommented, Jul 14, 2021

@Hazlitte @eugene-manuilov @aaemnnosttv After spending some hours on that, I finally managed to find out the culprit in our CSS which is not playing nicely with minify. It’s the following line: https://github.com/google/site-kit-wp/blob/develop/assets/sass/components/adminbar/_googlesitekit-wp-adminbar.scss#L82

So without minification, the SVG (html decoded) markup is as follows:

<svg width="43" height="44" viewBox="0 0 43 44" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><path d="M42.5 18H22v8.5h11.8C32.7 31.9 28.1 35 22 35c-7.2 0-13-5.8-13-13S14.8 9 22 9c3.1 0 5.9 1.1 8.1 2.9l6.4-6.4C32.6 2.1 27.6 0 22 0 9.8 0 0 9.8 0 22s9.8 22 22 22c11 0 21-8 21-22 0-1.3-.2-2.7-.5-4z" id="a"/></defs><g fill="none" fill-rule="evenodd"><mask id="b" fill="#fff"><use xlink:href="#a"/></mask><path fill="#FBBC05" mask="url(#b)" d="M-2 35V9l17 13z"/><path fill="#34A853" mask="url(#b)" d="M-2 35l30-23 7.9 1L46-2v48H-2z"/><path fill="#4285F4" mask="url(#b)" d="M46 46L15 22l-4-3L46 9z"/><path fill="#EA4335" mask="url(#b)" d="M-2 9l17 13 7-6.1L46 12V-2H-2z"/></g></svg>

but the minified version is as follows:

<svg width="43" height="44" viewBox="0 0 43 44" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><path d="M42.5 18H22v8.5h11.8C32.7 31.9 28.1 35 22 35c-7.2 0-13-5.8-13-13S14.8 9 22 9c3.1 0 5.9 1.1 8.1 2.9l6.4-6.4C32.6 2.1 27.6 0 22 0 9.8 0 0 9.8 0 22s9.8 22 22 22c11 0 21-8 21-22 0-1.3-.2-2.7-.5-4z" id="a"/></defs><g fill="none" fill-rule="evenodd"><mask id="b" fill="#fff"><use xlink:href="#a"/></mask><path fill="#FBBC05" mask="url(#")" d="M-2 35V9l17 13z"/><path fill="#34A853" mask="url(#b)" d="M-2 35l30-23 7.9 1L46-2v48H-2z"/><path fill="#4285F4" mask="url(#b)" d="M46 46L15 22l-4-3L46 9z"/><path fill="#EA4335" mask="url(#b)" d="M-2 9l17 13 7-6.1L46 12V-2H-2z"/></g></svg>

There is a small diff between those 2 SVGs: Un minified:

fill="#FBBC05" mask="url(#b)"

Minified:

fill="#FBBC05" mask="url(#")"

Basically minify is replacing #b by #" and it’s messing the overall CSS output. So in the IB, I’ve suggested we base64 encode the SVG to prevent that. I tested it locally and it works fine.

1reaction
wpdarrencommented, Jul 22, 2021

QA Update: Pass ✅

Verified:

  • With Site Kit and W3 Total Cache with minify option enabled. When I view a page with stats, the admin bar is not broken.
  • Also tested with the WoodMart theme and the admin bar renders correctly.

image

Read more comments on GitHub >

github_iconTop Results From Across the Web

Error with plugin – do I have plugins that conflict?
I keep getting this error: The Page Cache add-in file advanced-cache.php is not a W3 Total Cache drop-in. It should be removed. Advanced ......
Read more >
General Support - W3TC (W3 Total Cache) Compatibility
Head to WP Admin → Performance → General Settings. ... If the problem persists, turn Minify off. As a next measure, go to...
Read more >
How to Configure W3 Total Cache Settings - Kinsta
After installing W3 Total Cache, you'll see a “Performance” tab in the sidebar of your WordPress admin dashboard. Clicking on the “Performance” ...
Read more >
Topic: Issues with W3 Total Cache and Buddypress on Multisite
I was hoping to get anyone else using total cache and BPMU to drop any known issues and fixes here. I've started using...
Read more >
Having problems with W3 Total Cache? Common fixes.
How To Uninstall W3 Total Cache WordPress Plugin · Step 1: Turn Off All Caching, Minifying and Other Options · Step 2: Deactivate...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found