145 lines
5.8 KiB
JavaScript
145 lines
5.8 KiB
JavaScript
/**
|
|
* @file
|
|
* Block behaviors.
|
|
*/
|
|
|
|
(function ($, window) {
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* Provide the summary information for the block settings vertical tabs.
|
|
*
|
|
* @type {Drupal~behavior}
|
|
*/
|
|
Drupal.behaviors.blockSettingsSummary = {
|
|
attach: function () {
|
|
// The drupalSetSummary method required for this behavior is not available
|
|
// on the Blocks administration page, so we need to make sure this
|
|
// behavior is processed only if drupalSetSummary is defined.
|
|
if (typeof jQuery.fn.drupalSetSummary === 'undefined') {
|
|
return;
|
|
}
|
|
|
|
function checkboxesSummary(context) {
|
|
var vals = [];
|
|
var $checkboxes = $(context).find('input[type="checkbox"]:checked + label');
|
|
var il = $checkboxes.length;
|
|
for (var i = 0; i < il; i++) {
|
|
vals.push($($checkboxes[i]).html());
|
|
}
|
|
if (!vals.length) {
|
|
vals.push(Drupal.t('Not restricted'));
|
|
}
|
|
return vals.join(', ');
|
|
}
|
|
|
|
$('[data-drupal-selector="edit-visibility-node-type"], [data-drupal-selector="edit-visibility-language"], [data-drupal-selector="edit-visibility-user-role"]').drupalSetSummary(checkboxesSummary);
|
|
|
|
$('[data-drupal-selector="edit-visibility-request-path"]').drupalSetSummary(function (context) {
|
|
var $pages = $(context).find('textarea[name="visibility[request_path][pages]"]');
|
|
if (!$pages.val()) {
|
|
return Drupal.t('Not restricted');
|
|
}
|
|
else {
|
|
return Drupal.t('Restricted to certain pages');
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Move a block in the blocks table from one region to another via select list.
|
|
*
|
|
* This behavior is dependent on the tableDrag behavior, since it uses the
|
|
* objects initialized in that behavior to update the row.
|
|
*
|
|
* @type {Drupal~behavior}
|
|
*/
|
|
Drupal.behaviors.blockDrag = {
|
|
attach: function (context, settings) {
|
|
// tableDrag is required and we should be on the blocks admin page.
|
|
if (typeof Drupal.tableDrag === 'undefined' || typeof Drupal.tableDrag.blocks === 'undefined') {
|
|
return;
|
|
}
|
|
|
|
var table = $('#blocks');
|
|
// Get the blocks tableDrag object.
|
|
var tableDrag = Drupal.tableDrag.blocks;
|
|
// Add a handler for when a row is swapped, update empty regions.
|
|
tableDrag.row.prototype.onSwap = function (swappedRow) {
|
|
checkEmptyRegions(table, this);
|
|
};
|
|
|
|
// Add a handler so when a row is dropped, update fields dropped into new regions.
|
|
tableDrag.onDrop = function () {
|
|
var dragObject = this;
|
|
var $rowElement = $(dragObject.rowObject.element);
|
|
// Use "region-message" row instead of "region" row because
|
|
// "region-{region_name}-message" is less prone to regexp match errors.
|
|
var regionRow = $rowElement.prevAll('tr.region-message').get(0);
|
|
var regionName = regionRow.className.replace(/([^ ]+[ ]+)*region-([^ ]+)-message([ ]+[^ ]+)*/, '$2');
|
|
var regionField = $rowElement.find('select.block-region-select');
|
|
// Check whether the newly picked region is available for this block.
|
|
if (regionField.find('option[value=' + regionName + ']').length === 0) {
|
|
// If not, alert the user and keep the block in its old region setting.
|
|
window.alert(Drupal.t('The block cannot be placed in this region.'));
|
|
// Simulate that there was a selected element change, so the row is put
|
|
// back to from where the user tried to drag it.
|
|
regionField.trigger('change');
|
|
}
|
|
else if ($rowElement.prev('tr').is('.region-message')) {
|
|
var weightField = $rowElement.find('select.block-weight');
|
|
var oldRegionName = weightField[0].className.replace(/([^ ]+[ ]+)*block-weight-([^ ]+)([ ]+[^ ]+)*/, '$2');
|
|
|
|
if (!regionField.is('.block-region-' + regionName)) {
|
|
regionField.removeClass('block-region-' + oldRegionName).addClass('block-region-' + regionName);
|
|
weightField.removeClass('block-weight-' + oldRegionName).addClass('block-weight-' + regionName);
|
|
regionField.val(regionName);
|
|
}
|
|
}
|
|
};
|
|
|
|
// Add the behavior to each region select list.
|
|
$(context).find('select.block-region-select').once('block-region-select').each(function () {
|
|
$(this).on('change', function (event) {
|
|
// Make our new row and select field.
|
|
var row = $(this).closest('tr');
|
|
var select = $(this);
|
|
tableDrag.rowObject = new tableDrag.row(row);
|
|
|
|
// Find the correct region and insert the row as the last in the region.
|
|
table.find('.region-' + select[0].value + '-message').nextUntil('.region-message').eq(-1).before(row);
|
|
|
|
// Modify empty regions with added or removed fields.
|
|
checkEmptyRegions(table, row);
|
|
// Remove focus from selectbox.
|
|
select.trigger('blur');
|
|
});
|
|
});
|
|
|
|
var checkEmptyRegions = function (table, rowObject) {
|
|
table.find('tr.region-message').each(function () {
|
|
var $this = $(this);
|
|
// If the dragged row is in this region, but above the message row, swap it down one space.
|
|
if ($this.prev('tr').get(0) === rowObject.element) {
|
|
// Prevent a recursion problem when using the keyboard to move rows up.
|
|
if ((rowObject.method !== 'keyboard' || rowObject.direction === 'down')) {
|
|
rowObject.swap('after', this);
|
|
}
|
|
}
|
|
// This region has become empty.
|
|
if ($this.next('tr').is(':not(.draggable)') || $this.next('tr').length === 0) {
|
|
$this.removeClass('region-populated').addClass('region-empty');
|
|
}
|
|
// This region has become populated.
|
|
else if ($this.is('.region-empty')) {
|
|
$this.removeClass('region-empty').addClass('region-populated');
|
|
}
|
|
});
|
|
};
|
|
}
|
|
};
|
|
|
|
})(jQuery, window);
|