Skip to content

WordPress plugin for lab features and a testbed for improvements to Widgets and the Customizer.

Notifications You must be signed in to change notification settings

xwp/wp-customize-widgets-plus

Folders and files

NameName
Last commit message
Last commit date
Dec 18, 2015
Jul 1, 2015
Apr 2, 2016
Nov 8, 2015
Oct 7, 2016
Oct 7, 2016
Apr 30, 2015
Sep 16, 2015
May 12, 2015
May 9, 2015
Apr 3, 2016
Jun 3, 2015
May 1, 2015
Apr 2, 2016
Oct 19, 2015
Oct 19, 2015
Jun 3, 2015

Repository files navigation

Customize Widgets Plus

Lab features and a testbed for improvements to Widgets and the Customizer.

Contributors: westonruter, xwp, newscorpau
Tags: customizer, customize, widgets
Requires at least: trunk
Tested up to: trunk
Stable tag: trunk (master)
License: GPLv2 or later

Build Status

Description

This plugin consists of lab features and a testbed for improvements to Widgets and the Customizer.

Requires PHP 5.3+.

Development of this plugin is done on GitHub. Pull requests welcome. Please see issues reported there before going to the plugin forum.

Current features:

Non-Autoloaded Widget Options

Widgets are stored in options (normally). Multi-widgets store all of their instances in one big serialized array specific to that type. When there are many widgets of a given type, the size of the serialized array can grow very large. What's more is that WP_Widget does not explicitly add_option(... 'no' ) before calling update_option(), and so all of the settings get added with autoloading. This is very bad when using Memcached Object Cache specifically because it can result in the total alloptions cache key to become larger than 1MB and result in Memcached failing to store the value in the cache. On WordPress.com the result is a "Matt's fault" error which has to be fixed by the VIP team. Widget settings should not be stored in serialized arrays to begin with; each widget instance should be stored in a custom post type. But until this is done we should stop autoloading options. See also #26876 and #23909.

Widget Number Incrementing

Implements fixes for Core issue #32183 (Widget ID auto-increments conflict for concurrent users). The stored widget_number option provides a centralized auto-increment number for whenever a widget is instantiated, even widgets in the Customizer that are not yet saved.

Efficient Multidimensional Setting Sanitizing

Settings for multidimensional options and theme_mods are extremely inefficient to sanitize in Core because all of the Customizer settings registered for the subsets of the option or theme_mod need filters that are added to the entire value, meaning sanitizing one single setting will result in all filters for all other settings in that option/theme_mod will also get applied. This functionality seeks to improve this as much as possible, especially for widgets which are the worst offenders. Implements partial fix for #32103.

HTTPS Resource Proxy

When FORCE_SSL_ADMIN is enabled (such as on WordPress.com), the Customizer will load the site into the preview iframe using HTTPS as well. If, however, external resources are being referenced which are not HTTPS, they will fail to load due to the browser's security model raise mixed content warnings. This functionality will attempt to rewrite any HTTP URLs to be HTTPS ones via a WordPress-based proxy.

Widget Posts

Store widget instances in posts instead of options. Requires trunk due to patch committed in #32474. More details forthcoming...

Deferred Widget Embedding

Backports #33898 and #33901 which are now in trunk for WordPress 4.4.

Changelog

0.2

Add Widget Posts module. See changelog.

0.1

Initial release.

About

WordPress plugin for lab features and a testbed for improvements to Widgets and the Customizer.

Resources

Stars

Watchers

Forks

Packages

No packages published