190 lines
5.8 KiB
JavaScript
190 lines
5.8 KiB
JavaScript
/**
|
|
* @file
|
|
* JavaScript behaviors for admin pages.
|
|
*/
|
|
|
|
(function ($, Drupal, debounce) {
|
|
|
|
'use strict';
|
|
|
|
/**
|
|
* Filters the webform element list by a text input search string.
|
|
*
|
|
* The text input will have the selector `input.webform-form-filter-text`.
|
|
*
|
|
* The target element to do searching in will be in the selector
|
|
* `input.webform-form-filter-text[data-element]`
|
|
*
|
|
* The text source where the text should be found will have the selector
|
|
* `.webform-form-filter-text-source`
|
|
*
|
|
* @type {Drupal~behavior}
|
|
*
|
|
* @prop {Drupal~behaviorAttach} attach
|
|
* Attaches the behavior for the webform element filtering.
|
|
*/
|
|
Drupal.behaviors.webformFilterByText = {
|
|
attach: function (context, settings) {
|
|
$('input.webform-form-filter-text', context).once('webform-form-filter-text').each(function () {
|
|
var $input = $(this);
|
|
var $table = $($input.data('element'));
|
|
var $summary = $($input.data('summary'));
|
|
var $noResults = $($input.data('no-results'));
|
|
var $details = $table.closest('details');
|
|
var sourceSelector = $input.data('source') || '.webform-form-filter-text-source';
|
|
var parentSelector = $input.data('parent') || 'tr';
|
|
var $filterRows;
|
|
|
|
var hasDetails = $details.length;
|
|
var totalItems;
|
|
var args = {
|
|
'@item': $input.data('item-single') || Drupal.t('item'),
|
|
'@items': $input.data('item-plural') || Drupal.t('items'),
|
|
'@total': null
|
|
};
|
|
|
|
if ($table.length) {
|
|
$filterRows = $table.find(sourceSelector);
|
|
$input
|
|
.attr('autocomplete', 'off')
|
|
.on('keyup', debounce(filterElementList, 200))
|
|
.keyup();
|
|
// Make sure the filter input is always focused.
|
|
setTimeout(function () {$input.focus();});
|
|
}
|
|
|
|
/**
|
|
* Filters the webform element list.
|
|
*
|
|
* @param {jQuery.Event} e
|
|
* The jQuery event for the keyup event that triggered the filter.
|
|
*/
|
|
function filterElementList(e) {
|
|
var query = $(e.target).val().toLowerCase();
|
|
|
|
// Filter if the length of the query is at least 2 characters.
|
|
if (query.length >= 2) {
|
|
// Reset count.
|
|
totalItems = 0;
|
|
if ($details.length) {
|
|
$details.hide();
|
|
}
|
|
$filterRows.each(toggleEntry);
|
|
|
|
// Announce filter changes.
|
|
// @see Drupal.behaviors.blockFilterByText
|
|
Drupal.announce(Drupal.formatPlural(
|
|
totalItems,
|
|
'1 @item is available in the modified list.',
|
|
'@total @items are available in the modified list.',
|
|
args
|
|
));
|
|
}
|
|
else {
|
|
totalItems = $filterRows.length;
|
|
$filterRows.each(function (index) {
|
|
$(this).closest(parentSelector).show();
|
|
if ($details.length) {
|
|
$details.show();
|
|
}
|
|
});
|
|
}
|
|
|
|
// Set total.
|
|
args['@total'] = totalItems;
|
|
|
|
// Hide/show no results.
|
|
$noResults[totalItems ? 'hide' : 'show']();
|
|
|
|
// Update summary.
|
|
if ($summary.length) {
|
|
$summary.html(Drupal.formatPlural(
|
|
totalItems,
|
|
'1 @item',
|
|
'@total @items',
|
|
args
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Shows or hides the webform element entry based on the query.
|
|
*
|
|
* @param {number} index
|
|
* The index in the loop, as provided by `jQuery.each`
|
|
* @param {HTMLElement} label
|
|
* The label of the webform.
|
|
*/
|
|
function toggleEntry(index, label) {
|
|
var $label = $(label);
|
|
var $row = $label.closest(parentSelector);
|
|
var textMatch = $label.text().toLowerCase().indexOf(query) !== -1;
|
|
$row.toggle(textMatch);
|
|
if (textMatch) {
|
|
totalItems++;
|
|
if (hasDetails) {
|
|
$row.closest('details').show();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Filter webform autocomplete handler.
|
|
*
|
|
* @type {Drupal~behavior}
|
|
*/
|
|
Drupal.behaviors.webformFilterAutocomplete = {
|
|
attach: function (context) {
|
|
$('.webform-filter-form input.form-autocomplete', context).once('webform-autocomplete')
|
|
.each(function () {
|
|
// If input value is an autocomplete match, reset the input to its
|
|
// default value.
|
|
if (/\(([^)]+)\)$/.test(this.value)) {
|
|
this.value = this.defaultValue;
|
|
}
|
|
|
|
// From: http://stackoverflow.com/questions/5366068/jquery-ui-autocomplete-submit-onclick-result
|
|
$(this).bind('autocompleteselect', function (event, ui) {
|
|
if (ui.item) {
|
|
$(this).val(ui.item.value);
|
|
this.form.submit();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Allow table rows to be hyperlinked.
|
|
*
|
|
* @type {Drupal~behavior}
|
|
*/
|
|
Drupal.behaviors.webformTableRowHref = {
|
|
attach: function (context) {
|
|
// Only attach the click event handler to the entire table and determine
|
|
// which row triggers the event.
|
|
$('.webform-results-table', context).once('webform-results-table').click(function (event) {
|
|
if (event.target.tagName === 'A' || event.target.tagName === 'BUTTON') {
|
|
return true;
|
|
}
|
|
|
|
if ($(event.target).parents('a[href]').length) {
|
|
return true;
|
|
}
|
|
|
|
var $tr = $(event.target).parents('tr[data-webform-href]');
|
|
if (!$tr.length) {
|
|
return true;
|
|
}
|
|
|
|
window.location = $tr.attr('data-webform-href');
|
|
return false;
|
|
});
|
|
}
|
|
};
|
|
|
|
})(jQuery, Drupal, Drupal.debounce);
|