You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.4 KiB
69 lines
2.4 KiB
(function ($, Drupal, once) { |
|
'use strict'; |
|
|
|
Drupal.behaviors.preserveAdvancedSearchParams = { |
|
attach: function (context, settings) { |
|
|
|
console.log('preserve-advanced-search.js loaded'); |
|
|
|
// Extract a[] params from the current page URL |
|
const rawSearch = window.location.search; |
|
const aParams = rawSearch |
|
.substring(1) |
|
.split('&') |
|
.filter(part => part.startsWith('a%5B') || part.startsWith('a[')) |
|
.join('&'); |
|
|
|
console.log('[AdvSearch] aParams found:', aParams); |
|
|
|
// Nothing to preserve — bail out |
|
if (!aParams) return; |
|
|
|
// Target the <ul> that has data-drupal-facet-id |
|
// then find the .facet-slider inside it which is the noUiSlider element |
|
once('preserve-advsearch-slider', '[data-drupal-facet-id]', context) |
|
.forEach(function (el) { |
|
const facetId = el.dataset.drupalFacetId; |
|
const sliderEl = el.querySelector('.facet-slider'); |
|
|
|
console.log('[AdvSearch] Found facet:', facetId, 'slider el:', sliderEl); |
|
|
|
if (!sliderEl || !sliderEl.noUiSlider) { |
|
console.warn('[AdvSearch] No noUiSlider instance found on', sliderEl); |
|
return; |
|
} |
|
|
|
// Get the facet settings from drupalSettings |
|
const facetSettings = settings.facets && settings.facets[facetId]; |
|
console.log('[AdvSearch] facetSettings:', facetSettings); |
|
|
|
if (!facetSettings) { |
|
console.warn('[AdvSearch] No drupalSettings.facets entry for:', facetId); |
|
return; |
|
} |
|
|
|
// Remove original change listener and replace with patched version |
|
sliderEl.noUiSlider.off('change'); |
|
sliderEl.noUiSlider.on('change', function (values, handle, unencoded) { |
|
let newUrl; |
|
|
|
if (facetSettings.range) { |
|
newUrl = facetSettings.url |
|
.replace('__range_slider_min__', Math.round(unencoded[0])) |
|
.replace('__range_slider_max__', Math.round(unencoded[1])); |
|
} else { |
|
newUrl = facetSettings.urls['f_' + values[0]]; |
|
} |
|
|
|
console.log('[AdvSearch] Navigating to:', newUrl + '&' + aParams); |
|
|
|
const separator = newUrl.includes('?') ? '&' : '?'; |
|
window.location.href = newUrl + separator + aParams; |
|
}); |
|
|
|
console.log('[AdvSearch] Slider change handler patched successfully'); |
|
}); |
|
} |
|
}; |
|
|
|
})(jQuery, Drupal, once);
|
|
|