Я решил это в Javascript. Если вы хотите полностью предотвратить это, вы также должны сделать это на стороне сервера, потому что вы можете редактировать виджеты с отключенным Javascript (попробуйте!).
Различные боковые панели проверяются, когда вы перетаскиваете виджеты на них или подальше от них. Если они заполнятся, цвет фона изменится, и вы больше не сможете оставлять на них элементы. Если при запуске боковая панель уже переполнена (поскольку вы ужесточили ограничение), цвет фона становится красным. Вы все еще можете перетащить виджеты из полных виджетов, чтобы они снова стали пустыми.
Пожалуйста, проверьте этот код, чтобы найти способы добавить или удалить виджеты, которые я пропустил. «Волшебство» в коде jQuery происходит от Амана , который ответил на вопрос о переполнении стека , который я опубликовал по этому поводу .
Javascript:
jQuery( function( $ ) {
var sidebarLimits = {
'sidebar-1': 2,
'sidebar-2': 2,
};
var realSidebars = $( '#widgets-right div.widgets-sortables' );
var availableWidgets = $( '#widget-list' ).children( '.widget' );
var checkLength = function( sidebar, delta ) {
var sidebarId = sidebar.id;
if ( undefined === sidebarLimits[sidebarId] ) {
return;
}
// This is a limited sidebar
// Find out how many widgets it already has
var widgets = $( sidebar ).sortable( 'toArray' );
$( sidebar ).toggleClass( 'sidebar-full', sidebarLimits[sidebarId] <= widgets.length + (delta || 0) );
$( sidebar ).toggleClass( 'sidebar-morethanfull', sidebarLimits[sidebarId] < widgets.length + (delta || 0) );
var notFullSidebars = $( 'div.widgets-sortables' ).not( '.sidebar-full' );
availableWidgets.draggable( 'option', 'connectToSortable', notFullSidebars );
realSidebars.sortable( 'option', 'connectWith', notFullSidebars );
}
// Check existing sidebars on startup
realSidebars.map( function() {
checkLength( this );
} );
// Update when dragging to this (sort-receive)
// and away to another sortable (sort-remove)
realSidebars.bind( 'sortreceive sortremove', function( event, ui ) {
checkLength( this );
} );
// Update when dragging back to the "Available widgets" stack
realSidebars.bind( 'sortstop', function( event, ui ) {
if ( ui.item.hasClass( 'deleting' ) ) {
checkLength( this, -1 );
}
} );
// Update when the "Delete" link is clicked
$( 'a.widget-control-remove' ).live( 'click', function() {
checkLength( $( this ).closest( 'div.widgets-sortables' )[0], -1 );
} );
} );
CSS:
.sidebar-full
{
background-color: #cfe1ef !important;
}
.sidebar-morethanfull
{
background-color: #c43 !important;
}
PHP для их загрузки:
$wpse19907_file = $plugin;
add_action( 'admin_enqueue_scripts', 'wpse19907_admin_enqueue_scripts' );
function wpse19907_admin_enqueue_scripts( $hook_suffix )
{
if ( 'widgets.php' == $hook_suffix ) {
wp_enqueue_script( 'wpse-19907', plugins_url( 'wpse-19907.js', $GLOBALS['wpse19907_file'] ), array(), false, true );
wp_enqueue_style( 'wpse-19907', plugins_url( 'wpse-19907.css', $GLOBALS['wpse19907_file'] ) );
}
}
Попытка проверки на стороне сервера (возможно, еще не завершена):
$wpse19907_sidebars_max_widgets = array(
'sidebar-1' => 2,
);
add_action( 'sidebar_admin_setup', 'wpse19907_sidebar_admin_setup' );
function wpse19907_sidebar_admin_setup()
{
if ( ! isset( $_POST['action'] ) || 'save-widget' != $_POST['action'] || empty( $_POST['add_new'] ) ) {
return;
}
// We're adding a new widget to a sidebar
global $wpse19907_sidebars_max_widgets;
$sidebar_id = $_POST['sidebar'];
if ( ! array_key_exists( $sidebar_id, $wpse19907_sidebars_max_widgets ) ) {
return;
}
$sidebar = wp_get_sidebars_widgets();
$sidebar = isset( $sidebars[$sidebar_id] ) ? $sidebars[$sidebar_id] : array();
if ( count( $sidebar ) <= $wpse19907_sidebars_max_widgets[$sidebar_id] ) {
die( 'mx' ); // Length must be shorter than 2, and unique
}
}
чтобы помочь вам с вашим вопросом, у меня есть предложение. Давайте использовать
first-footer-widget-area
подарок в стандартномsidebar-footer.php
файле шаблона Twenty Ten как пример.В качестве хорошей практики и безопасности сначала сделайте резервную копию, чтобы избежать головной боли.
Исходный код шаблона Twenty Ten для представления первого виджета нижнего колонтитула:
Давайте изменим, добавив код с условными выражениями, чтобы ограничить количество виджетов, разрешенных в этой области.
Что делает этот модифицированный код:
посчитайте количество виджетов в этой боковой панели и установите допустимый предел (установленный вами).
Если предел, разрешенный для виджетов в этой области, был достигнут, то будет отображаться сообщение с предупреждением, ограничивающее, в противном случае виджет будет отображаться.
Поэтому я надеюсь, что помог с вашим вопросом.
источник
Интересно В. Не очень много узнал при кратком обзоре, но вот предположение:
print_r( $GLOBALS['wp_registered_sidebars'] );
илиprint_r( $GLOBALS['sidebars'] );
илиprint_r( $GLOBALS['sidebars_widgets'] );
...источник
Вы можете сделать следующие вещи, чтобы определить количество виджетов.
Функция:
$mysidebars = wp_get_sidebars_widgets()
- даст вам список боковых панелей и виджетов, используемых на этих боковых панелях.$total_widgets = count( $mysidebars['my-sidebar-id'] );
- подсчитает общее количество виджетов в my-sidebar-idЯ надеюсь, что это решит ваши сомнения.
источник