first import
This commit is contained in:
112
sites/all/modules/custom_search/js/custom_search.js
Normal file
112
sites/all/modules/custom_search/js/custom_search.js
Normal file
@@ -0,0 +1,112 @@
|
||||
(function($) {
|
||||
Drupal.behaviors.custom_search = {
|
||||
attach: function(context) {
|
||||
|
||||
if (!Drupal.settings.custom_search.solr) {
|
||||
// Check if the search box is not empty on submit
|
||||
$('form.search-form', context).submit(function(){
|
||||
var box = $(this).find('input.custom-search-box');
|
||||
if (box.val() != undefined && box.val() == '') {
|
||||
$(this).find('input.custom-search-box').addClass('error');
|
||||
return false;
|
||||
}
|
||||
// If basic search is hidden, copy or value to the keys
|
||||
if ($(this).find('#edit-keys').parents('div.element-invisible').attr('class') == 'element-invisible') {
|
||||
$(this).find('#edit-keys').val($(this).find('#edit-or').val());
|
||||
$(this).find('#edit-or').val('');
|
||||
}
|
||||
return true;
|
||||
});
|
||||
}
|
||||
|
||||
// Search from target
|
||||
$('form.search-form').attr('target', Drupal.settings.custom_search.form_target);
|
||||
|
||||
// Displays Popup.
|
||||
$('form.search-form input.custom-search-box', context).bind('click focus', function(e){
|
||||
$this = $(this);
|
||||
$parentForm = $this.parents('form');
|
||||
// check if there's something in the popup and displays it
|
||||
var popup = $parentForm.find('fieldset.custom_search-popup');
|
||||
if (popup.find('input,select').length && !popup.hasClass('opened')) popup.fadeIn().addClass('opened');
|
||||
e.stopPropagation();
|
||||
});
|
||||
$(document).bind('click focus', function(){
|
||||
$('fieldset.custom_search-popup').hide().removeClass('opened');
|
||||
});
|
||||
|
||||
// Handle checkboxes
|
||||
$('.custom-search-selector input:checkbox', context).each(function(){
|
||||
var el = $(this);
|
||||
if (el.val() == 'c-all') {
|
||||
el.change(function(){
|
||||
$(this).parents('.custom-search-selector').find('input:checkbox[value!=c-all]').attr('checked', false);
|
||||
});
|
||||
}
|
||||
else {
|
||||
if (el.val().substr(0,2) == 'c-') {
|
||||
el.change(function(){
|
||||
$('.custom-search-selector input:checkbox').each(function(){
|
||||
if ($(this).val().substr(0,2) == 'o-') $(this).attr('checked', false);
|
||||
});
|
||||
$(this).parents('.custom-search-selector').find('input:checkbox[value=c-all]').attr('checked', false);
|
||||
});
|
||||
} else {
|
||||
el.change(function(){
|
||||
$(this).parents('.custom-search-selector').find('input:checkbox[value!='+el.val()+']').attr('checked', false);
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
// Reselect types and terms in advanced search
|
||||
var edit_keys = $('#edit-keys').val();
|
||||
if(edit_keys) {
|
||||
// types
|
||||
var pos = edit_keys.indexOf('type:');
|
||||
if (pos) {
|
||||
var pos2 = edit_keys.indexOf(' ',pos);
|
||||
if (pos2==-1) pos2 = edit_keys.length;
|
||||
var types = edit_keys.substring(pos+5,pos2);
|
||||
types = types.split(',');
|
||||
for (var i=0; i<types.length; i++) {
|
||||
$('.search-form input:checkbox[value='+types[i]+']').attr('checked', true);
|
||||
}
|
||||
}
|
||||
// terms
|
||||
var pos = edit_keys.indexOf('term:');
|
||||
if (pos) {
|
||||
var pos2 = edit_keys.indexOf(' ',pos);
|
||||
if (pos2==-1) pos2 = edit_keys.length;
|
||||
var terms = edit_keys.substring(pos+5,pos2);
|
||||
terms = terms.split(',');
|
||||
for (var i=0; i<terms.length; i++) {
|
||||
$('#edit-term option[value='+terms[i]+']').attr('selected', true);
|
||||
}
|
||||
}
|
||||
// languages
|
||||
var pos = edit_keys.indexOf('language:');
|
||||
if (pos) {
|
||||
var pos2 = edit_keys.indexOf(' ',pos);
|
||||
if (pos2==-1) pos2 = edit_keys.length;
|
||||
var languages = edit_keys.substring(pos+9,pos2);
|
||||
languages = languages.split(',');
|
||||
for (var i=0; i<languages.length; i++) {
|
||||
$('.search-advanced #edit-language-'+languages[i]).attr('checked', true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
var popup = $('fieldset.custom_search-popup:not(.custom_search-processed)', context).addClass("custom_search-processed");
|
||||
popup.click(function(e){
|
||||
e.stopPropagation();
|
||||
})
|
||||
popup.append('<a class="custom_search-popup-close" href="#">' + Drupal.t('Close') + '</a>');
|
||||
$('a.custom_search-popup-close').click(function(e){
|
||||
$('fieldset.custom_search-popup.opened').hide().removeClass('opened');
|
||||
e.preventDefault();
|
||||
});
|
||||
|
||||
}
|
||||
}
|
||||
})(jQuery);
|
108
sites/all/modules/custom_search/js/custom_search_sort.js
Normal file
108
sites/all/modules/custom_search/js/custom_search_sort.js
Normal file
@@ -0,0 +1,108 @@
|
||||
(function ($) {
|
||||
|
||||
/**
|
||||
* 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.
|
||||
*/
|
||||
Drupal.behaviors.customSearchSort = {
|
||||
attach: function (context, settings) {
|
||||
// tableDrag is required and we should be on the blocks admin page.
|
||||
if (typeof Drupal.tableDrag == 'undefined' || typeof Drupal.tableDrag.elements == 'undefined') {
|
||||
return;
|
||||
}
|
||||
|
||||
var table = $('table#elements');
|
||||
var tableDrag = Drupal.tableDrag.elements; // Get the blocks tableDrag object.
|
||||
|
||||
// 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 () {
|
||||
dragObject = this;
|
||||
// Use "region-message" row instead of "region" row because
|
||||
// "region-{region_name}-message" is less prone to regexp match errors.
|
||||
var regionRow = $(dragObject.rowObject.element).prevAll('tr.region-message').get(0);
|
||||
var regionName = regionRow.className.replace(/([^ ]+[ ]+)*region-([^ ]+)-message([ ]+[^ ]+)*/, '$2');
|
||||
var regionField = $('select.region-select', dragObject.rowObject.element);
|
||||
// Check whether the newly picked region is available for this block.
|
||||
if ($('option[value=' + regionName + ']', regionField).length == 0) {
|
||||
// If not, alert the user and keep the block in its old region setting.
|
||||
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.change();
|
||||
}
|
||||
else if ($(dragObject.rowObject.element).prev('tr').is('.region-message')) {
|
||||
var weightField = $('select.sort-select', dragObject.rowObject.element);
|
||||
var oldRegionName = weightField[0].className.replace(/([^ ]+[ ]+)*sort-select-([^ ]+)([ ]+[^ ]+)*/, '$2');
|
||||
|
||||
if (!regionField.is('.region-select-' + regionName)) {
|
||||
regionField.removeClass('region-select-' + oldRegionName).addClass('region-select-' + regionName);
|
||||
weightField.removeClass('sort-select-' + oldRegionName).addClass('sort-select-' + regionName);
|
||||
regionField.val(regionName);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
// Add the behavior to each region select list.
|
||||
$('select.region-select', context).once('region-select', function () {
|
||||
$(this).change(function (event) {
|
||||
// Make our new row and select field.
|
||||
var row = $(this).parents('tr:first');
|
||||
var select = $(this);
|
||||
tableDrag.rowObject = new tableDrag.row(row);
|
||||
|
||||
// Find the correct region and insert the row as the first in the region.
|
||||
$('tr.region-message', table).each(function () {
|
||||
if ($(this).is('.region-' + select[0].value + '-message')) {
|
||||
// Add the new row and remove the old one.
|
||||
$(this).after(row);
|
||||
// Manually update weights and restripe.
|
||||
tableDrag.updateFields(row.get(0));
|
||||
tableDrag.rowObject.changed = true;
|
||||
if (tableDrag.oldRowElement) {
|
||||
$(tableDrag.oldRowElement).removeClass('drag-previous');
|
||||
}
|
||||
tableDrag.oldRowElement = row.get(0);
|
||||
tableDrag.restripeTable();
|
||||
tableDrag.rowObject.markChanged();
|
||||
tableDrag.oldRowElement = row;
|
||||
$(row).addClass('drag-previous');
|
||||
}
|
||||
});
|
||||
|
||||
// Modify empty regions with added or removed fields.
|
||||
checkEmptyRegions(table, row);
|
||||
// Remove focus from selectbox.
|
||||
select.get(0).blur();
|
||||
});
|
||||
});
|
||||
|
||||
var checkEmptyRegions = function (table, rowObject) {
|
||||
$('tr.region-message', table).each(function () {
|
||||
// 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').size() == 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);
|
Reference in New Issue
Block a user