Fixed Widget and Sticky Elements for WordPress

Description

Use Fixed Widget to create sticky widgets, sticky blocks, and other elements that stay in the visible screen area when a user scrolls the page up or down.

Sticky widgets are more visible than unfixed widgets and therefore have a significantly higher click-through rate.

That’s why this option is worthwhile for ads or other elements that visitors should interact with. Meanwhile, Google also allows the integration of sticky AdSense ads.

Features

Fixed Widget is completely free of charge.

  • Sticky Widgets Use the Fixed Widget option on any widget and blocks in the sidebar
  • Sticky Elements Choose any element on your site and make it sticky
  • Margin Top allows you to stop sticky elements to cover floating menu bars
  • Margin Bottom pushes sticky elements up before they reach a certain distance towards the bottom window
  • Stop Elements push sticky elements up when they are scrolling into view
  • Stop Blocks defines blocks in your sidebar that push fixed blocks out of the page
  • Minimum Screen Width and Minimum Screen Height allow you to disable sticky behavior on small screens
  • Written in plain JavaScript for better performance

Compatibility

Theme requirements:

  • wp_head() and wp_footer() functions in header.php and footer.php files
  • JavaScript errors could break sticky widgets

Screenshots

  • A fixed widget and a stop widget in action
  • Fixed Widget plugin options
  • Fixed Widget options for blocks in the widget editor
  • Fixed Widget option for legacy widgets

Installation

  1. Follow the standard WordPress plugin installation procedure
  2. Activate the plugin through the plugins menu in WordPress
  3. Go to Appearance -> Widgets, enable the “Fixed Widget” option on any active widget
  4. Fine tune plugin parameters on Appearance -> Fixed Widget page

FAQ

Why is the Fixed Widget plugin not working?

There are several reasons:

  1. JavaScript errors on the page. Commonly caused by buggy plugins. Check JavaScript console of your browser. If you find errors, try to locate and fix its source.
  2. No wp_head() and wp_footer() functions in template. Check header.php and footer.php files of your active theme.
  3. Conflicts with other plugins and scripts
  4. CSS incompatibility

Is it possible to fix multiple widgets?

Yes, it is possible to fix more than one widget even if they are located in different sidebars.

How can I style a fixed element only while it is sticky?

Fixed elements carry the FixedWidget__fixed_widget__pinned class, which allows developers to change the styling only while the element is fixed.

How to prevent overlapping with the footer?

Go to WP admin area, Appearance -> Fixed Widget. Here you can define the top and bottom margins. Set bottom margin value >= footer height. Check the result, please.
If your footer height is changing from page to page it is better to use the Stop ID option. Here you need to provide the HTML tag ID. The position of that HTML element will determine the margin bottom value. For example, let’s take the Twenty Sixteen default theme. The theme’s footer container has an ID=”colophon”. In the Stop Element Selectors option I need to enter #colophon.

How to disable the plugin on mobile devices?

Use the options Minimum Screen Width and Minimum Screen Height to disable sticky features when the browser window is too small. You can also use the visitor conditions of Advanced Ads to target specific devices.

Reviews

November 28, 2022 2 replies
I have used this plugin on my website for the last 5+ years and it always worked very well. Updates were always stress free and never broke any layout. With version 6 I had some layout issues and Thomas helped me fix it. It's really hard to make a plugin compatible with the vast amount of themes out there and I would have totally understood if he didn't want to spend the time to fix my specific issue. But I was in for a pleasant surprise. I recommend this plugin and I wish him all the best. Thank you for your time and efforts. Kind regards, Arun
November 7, 2022 1 reply
Thank you so much for such helpful widget. Very simple to setup and fast configuration.
September 26, 2022
Thank you for such wonderful tabs. Everything simple and effective.
August 31, 2022 1 reply
This plugin surprised us with its efficiency and ease of use. It is very efficient and does not slow down the loading of pages. We hesitated for a long time with other plugins. But I think we made the right choice, the zones are very easy to configure, which is not the case with other fixed widget type plugins. This one is completely free and is not restricted. Kudos to the team
Read all 261 reviews

Contributors & Developers

“Fixed Widget and Sticky Elements for WordPress” is open source software. The following people have contributed to this plugin.

Contributors

“Fixed Widget and Sticky Elements for WordPress” has been translated into 22 locales. Thank you to the translators for their contributions.

Translate “Fixed Widget and Sticky Elements for WordPress” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.

Changelog

6.2.3

  • Fix: fixed widget might increase its height when scrolling

6.2.2

  • Fix: improve bottom offset calculation when scrolling up

6.2.1

  • Fix: widget height increasing
  • Fix: widget scrolling align position
  • Fix: compatibility with existing CSS transition rules

6.2.0

  • Improvement: requires PHP 7.2
  • Fix: various improvements in cases where the fixed widget flickered, or the height was could not be determined correctly

6.1.1

  • Improvement: reposition the fixed widget when the screen is resized, e.g., a mobile device turned into landscape mode
  • Improvement: various optimizations for specific themes and setups reported by users

6.1.0

  • Feature: Add the FixedWidget__fixed_widget__pinned class to the fixed widget while it is sticky and remove it when it is unfixed. This allows users to apply their own styling only during a fixed state.
  • Improvement: rename “Test new version” option into “Improved version” and changed the option description to make it more clear that both script versions will be kept.
  • Improvement: change “Fixed Widget Options” menu item into “Fixed Widget”
  • Improvement: Handle edge cases where the Minimum Width option doesn’t work for specific themes

6.0.7

  • Improvement: Compatibility with relative padding values

6.0.6

  • Improvement: Compatibility with dynamically loaded content pages, i.e., infinite scroll
  • Improvement: Compatibility with widgets that have large offsets
  • Fix: Prevent padding from increasing on scroll

6.0.5

  • Fix: Prevent overlapping of fixed widgets with non-fixed widgets when scrolling up

6.0.4

  • Fix: Prevent fixed widgets overlapping non-fixed elements in certain themes
  • Fix: Class selectors saved under the Custom Elements were wrongly prefixed with ‘#’

6.0.3

  • Improvement: Check lazy elements and stop elements for changing their size and recalculate fixed position
  • Improvement: Lower check interval from 1000 to 500 ms

6.0.2

  • Improvement: Fall back to previous version when the theme does not support the new script – mainly because of using float instead of flex
  • Improvement: Stop Elements work also when they are in a different column or sidebar than the fixed element
  • Improvement: Recalculate Fixed Widget height on scroll

6.0.1

  • Fix: use the previous Stop ID value in the new Stop Elements section

6.0.0

Version 6.0.0 is a full rewrite of the frontend script. It fixes many edge cases like jumping, reloading, or resizing widgets.
The rewrite also resolves bad Cumulative Layout Shifts.

Most changes are available when you enable “Improved version” under Appearance > Fixed Widget.

Please test and let us know if you discover any issues.

  • added new (and optional) script version that uses position: sticky instead of position: fixed
  • the frontend script does not need jQuery anymore
  • removed unneeded options that previously helped resolving edge cases
  • “Stop Elements” and “Custom Fixed Elements” now accept any selector, including IDs, Class, and Type selectors.
  • fixed blocks in sidebars as introduced in WordPress 5.8
  • define stop blocks in sidebars that move up fixed blocks on scrolling
  • improved option descriptions on the admin page
  • improved behavior for elements higher than the screen – they first stick at the top and scroll to the bottom later
  • removed duplicating widget code

5.3.0

  • fixed option not saving when using the Gutenberg plugin to edit sidebars with block editor
  • disabled scripts and output on AMP pages since sticky widgets are not part of the AMP standard
  • removed explicit translation files since all translations are handled through https://translate.wordpress.org/projects/wp-plugins/q2w3-fixed-widget/

5.2.0

  • Added q2w3-fixed-widget-sidebar-options filter for widget options in the frontend.

5.1.9

  • Fixed JavaScript events which were not called in some setups.

5.1.8

  • Fixed JavaScript bug that caused jumping / flickering of fixed widgets.

5.1.7

  • Fixed “a.target.className.indexOf is not a function” bug

5.1.6

  • linguistic corrections
  • cleanup of the options page

5.1.5

  • author change

5.1.4

  • Added filter “q2w3-fixed-widgets”. It allows to filter array of widgets marked as fixed.

5.1.3

  • Now compatible with WP Page Widget plugin

5.1.2

  • Now works fine with Shortcodes Ultimate widgets!

5.1.1

  • Resolves problems with Margin Bottom and Stop ID from version 5.1!

5.1

  • New options load method!
  • Tested with WordPress 4.9

5.0.4

  • Compatibility patch for Better WordPress Minify plugin.

5.0.3

  • Improved solution for “q2w3_sidebar_options is not defined” error.

5.0.2

  • Plugin JavaScript optimisation
  • To resolve “q2w3_sidebar_options is not defined” error wp_add_inline_script function is used. WordPress 4.5 required for this fix!
  • Added option Disable MutationObserver. Use this option only as a backup to restore version 4 behaviour!

5.0.1

  • Fixed problem in multiple sidebars layout

5.0

  • Optimised client side performance. Detection of page changes is now based on MutationObserver API. Widget parameters recount is fired only when needed! Refresh interval option used only for compatibility with old browsers (no MutationObserver API support).
  • Improved compatibility with caching plugins (W3TC, Autoptimize and etc.). No need to exclude jQuery and plugin files from cache!
  • Async/Defer script load method support
  • Added Disable Width and Disable Height options
  • Note for cache plugins users: don’t forget to clear cache after upgrading to version 5! Options format has been changed!

4.1

  • Added Stop ID option. Use it when you cannot specify Margin Bottom value. Solution provided by Julian_Kingman!
  • Now the plugin is aware of the WordPress admin bar presence!
  • Fixed destruction of jQuery(window).load hook. There should be no problems with other jQuery plugins now!
  • Added German translation
  • Updated internationalisation support

4.0.6

  • A small bug fix
  • Added French translation

4.0.5

  • New option “Inherit widget width from the parent container” to better support responsive layouts.
  • JavaScript optimisation.

4.0.4

  • Added option “Auto fix widget id”. It is on by default. If the plugin is working with this option switched off – leave it in off position!

4.0.3

4.0.1

  • Hotfix! Removes problem with duplicated widget code.

4.0

  • Resolved widget jumping
  • Added code to automatically fix “widget id problem”
  • Added new compatibility option (plugin priority)
  • Added complete uninstall (uninstall script launched automatically when you DELETE plugin)
  • Added Spanish translation
  • Removed depricated options

3.0

  • This version brings you a long waited capability to stick widgets located in different sidebars! Enjoy!
  • Fixed conflict with WP Page Widget plugin
  • A few small bugs cleaned
  • Warning! “Disable plugin on mobile devices” and “Disable plugin on tablet devices” options now are depricated and will be removed in the next release. Use “Screen Max Width” option instead!

2.3

  • Now user can disable plugin, when browser window width is less then specified value (check plugin options).

2.2.4

  • This version compatible with jQuery 1.9 and 1.10

2.2.3

  • Little internal improvments
  • Mobile Detect updated to version 2.6.0

2.2.2

  • Fixed PHP Error
  • Mobile Detect updated to version 2.5.8

2.2.1

2.2

  • Now the plugin is able to reflect dynamic page content changes (infinite scroll, ajax basket and other JavaScript stuff)!!!
  • Added new option to plugin settings: Refresh interval. Recommended values between 500 – 2000 milliseconds. Note: setting have impact on the site performance (client side). If you don’t have dynamic content, set Refresh interval = 0.
  • Mobile Detect class updated to version 2.5.7

2.1

  • New option to define custom widget IDs for static sidebars and etc.
  • New option to disable plugin on mobile devices.
  • Fixed JavaScript error when no sidebars exists on a page.

2.0

  • Fixed footer overlapping problem! Now users can customize top and bottom margins for the fixed widgets from the admin area (Appearance -> Fixed Widget).
  • Added localisation support

1.0.3

  • Normalised plugin behaviour when sidebar is longer then main content. Note: possible overlapping with footer is still exists.

1.0.2

  • Fixed problem with widgets displayed only on certain pages.
  • Optimised JavaScript code.

1.0.1

  • Improved compatibility with Webkit based browsers (like Chrome and Safari).
  • Removed unnecessary CSS.

1.0

  • First public release.