blacklight_range_limit 8.3.0 → 8.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/ruby.yml +5 -1
- data/.gitignore +1 -0
- data/Gemfile +8 -0
- data/VERSION +1 -1
- data/app/assets/javascripts/blacklight_range_limit/blacklight_range_limit.esm.js +534 -0
- data/app/assets/javascripts/blacklight_range_limit/blacklight_range_limit.esm.js.map +1 -0
- data/app/assets/javascripts/blacklight_range_limit/blacklight_range_limit.umd.js +542 -0
- data/app/assets/javascripts/blacklight_range_limit/blacklight_range_limit.umd.js.map +1 -0
- data/app/assets/javascripts/blacklight_range_limit.js +7 -5
- data/app/components/blacklight_range_limit/range_facet_component.html.erb +3 -3
- data/app/javascript/blacklight_range_limit/index.js +11 -0
- data/app/{assets/javascripts → javascript}/blacklight_range_limit/range_limit_distro_facets.js +7 -8
- data/app/{assets/javascripts → javascript}/blacklight_range_limit/range_limit_plotting.js +3 -2
- data/app/{assets/javascripts → javascript}/blacklight_range_limit/range_limit_shared.js +40 -1
- data/app/{assets/javascripts → javascript}/blacklight_range_limit/range_limit_slider.js +7 -5
- data/app/javascripts/blacklight_range_limit/index.js +13 -0
- data/blacklight_range_limit.gemspec +1 -1
- data/package-lock.json +50 -0
- data/package.json +8 -5
- data/rollup.config.js +37 -0
- data/spec/components/range_facet_component_spec.rb +3 -2
- data/spec/components/range_form_component_spec.rb +3 -2
- data/spec/spec_helper.rb +0 -1
- metadata +35 -21
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"blacklight_range_limit.esm.js","sources":["../../../javascript/blacklight_range_limit/range_limit_shared.js","../../../javascript/blacklight_range_limit/range_limit_plotting.js","../../../javascript/blacklight_range_limit/range_limit_distro_facets.js","../../../javascript/blacklight_range_limit/range_limit_slider.js","../../../javascript/blacklight_range_limit/index.js"],"sourcesContent":["/**\n * BlacklightRangeLimit module setup.\n */\n'use strict';\n\nconst BlacklightRangeLimit = function (options) {\n this.options = options || {};\n}\n\nBlacklightRangeLimit.display_ratio = 1/(1.618 * 2); // half a golden rectangle, why not\n/* A custom event \"plotDrawn.blacklight.rangeLimit\" will be sent when flot plot\n is (re-)drawn on screen possibly with a new size. target of event will be the DOM element\n containing the plot. Used to resize slider to match. */\nBlacklightRangeLimit.redrawnEvent = \"plotDrawn.blacklight.rangeLimit\";\n\n// takes a string and parses into an integer, but throws away commas first, to avoid truncation when there is a comma\n// use in place of javascript's native parseInt\nBlacklightRangeLimit.parseNum = function parseNum(str) {\n str = String(str).replace(/[^0-9-]/g, '');\n return parseInt(str, 10);\n};\n\nBlacklightRangeLimit.form_selection = function form_selection(form, min, max) {\n var begin_val = BlacklightRangeLimit.parseNum($(form).find(\"input.range_begin\").val());\n if (isNaN(begin_val) || begin_val < min) {\n begin_val = min;\n }\n var end_val = BlacklightRangeLimit.parseNum($(form).find(\"input.range_end\").val());\n if (isNaN(end_val) || end_val > max) {\n end_val = max;\n }\n\n return BlacklightRangeLimit.normalized_selection(begin_val, end_val);\n}\n\n// Add AJAX fetched range facets if needed, and add a chart to em\nBlacklightRangeLimit.checkForNeededFacetsToFetch = function checkForNeededFacetsToFetch() {\n $(\".range_limit .profile .distribution a.load_distribution\").each(function() {\n var container = $(this).parent('div.distribution');\n\n $(container).load($(this).attr('href'), function(response, status) {\n if ($(container).hasClass(\"chart_js\") && status == \"success\" ) {\n BlacklightRangeLimit.turnIntoPlot(container);\n }\n });\n });\n}\n\nBlacklightRangeLimit.function_for_find_segment = function function_for_find_segment(pointer_lookup_arr) {\n return function(x_coord) {\n for (var i = pointer_lookup_arr.length-1 ; i >= 0 ; i--) {\n var hash = pointer_lookup_arr[i];\n if (x_coord >= hash.from)\n return hash;\n }\n return pointer_lookup_arr[0];\n };\n}\n\n// Send endpoint to endpoint+0.99999 to have display\n// more closely approximate limiting behavior esp\n// at small resolutions. (Since we search on whole numbers,\n// inclusive, but flot chart is decimal.)\nBlacklightRangeLimit.normalized_selection = function normalized_selection(min, max) {\n max += 0.99999;\n\n return {xaxis: { 'from':min, 'to':max}}\n}\n\n// Check if Flot is loaded\nBlacklightRangeLimit.domDependenciesMet = function domDependenciesMet() {\n return typeof $.plot != \"undefined\"\n}\n\nBlacklightRangeLimit.modalObserverConfig = {\n attributes: true,\n}\n\nBlacklightRangeLimit.initSliderModalObserver = function(modalSelector) {\n // Use a mutation observer to detect when the modal dialog is open\n const modalObserver = new MutationObserver(function(mutations) {\n mutations.forEach(function(mutation) {\n if (mutation.attributeName !== 'open') {return;}\n if (mutation.target.hasAttribute('open')) {\n $(modalSelector).find(\".range_limit .profile .range.slider_js\").each(function() {\n BlacklightRangeLimit.buildSlider(this);\n });\n }\n });\n });\n modalObserver.observe(document.querySelector(modalSelector), BlacklightRangeLimit.modalObserverConfig);\n}\n\nBlacklightRangeLimit.initPlotModalObserver = function(modalSelector) {\n // Use a mutation observer to detect when the modal dialog is open\n const modalObserver = new MutationObserver(function(mutations) {\n mutations.forEach(function(mutation) {\n if (mutation.attributeName !== 'open') {return;}\n if (mutation.target.hasAttribute('open')) {\n $(modalSelector).find(\".range_limit .profile .distribution.chart_js ul\").each(function() {\n BlacklightRangeLimit.turnIntoPlot($(this).parent());\n });\n\n // Case when there is no currently selected range\n BlacklightRangeLimit.checkForNeededFacetsToFetch();\n }\n });\n });\n modalObserver.observe(document.querySelector(modalSelector), BlacklightRangeLimit.modalObserverConfig);\n}\n\nexport default BlacklightRangeLimit","// second arg, if provided, is a number of ms we're willing to\n// wait for the container to have width before giving up -- we'll\n// set 50ms timers to check back until timeout is expired or the\n// container is finally visible. The timeout is used when we catch\n// bootstrap show event, but the animation hasn't barely begun yet -- but\n// we don't want to wait until it's finished, we want to start rendering\n// as soon as we can.\n\nimport BlacklightRangeLimit from 'range_limit_shared'\n\nBlacklightRangeLimit.turnIntoPlot = function turnIntoPlot(container, wait_for_visible) {\n // flot can only render in a a div with a defined width.\n // for instance, a hidden div can't generally be rendered in (although if you set\n // an explicit width on it, it might work)\n //\n // We'll count on later code that catch bootstrap collapse open to render\n // on show, for currently hidden divs.\n\n // for some reason width sometimes return negative, not sure\n // why but it's some kind of hidden.\n if (container.width() > 0) {\n var height = container.width() * BlacklightRangeLimit.display_ratio;\n\n // Need an explicit height to make flot happy.\n container.height( height )\n\n BlacklightRangeLimit.areaChart($(container));\n\n $(container).trigger(BlacklightRangeLimit.redrawnEvent);\n }\n else if (wait_for_visible > 0) {\n setTimeout(function() {\n BlacklightRangeLimit.turnIntoPlot(container, wait_for_visible - 50);\n }, 50);\n }\n}\n\nBlacklightRangeLimit.parseSegment = function parseSegment(el) {\n if ($(el).find(\"span.single\").first().data('blrlSingle')) {\n var val = BlacklightRangeLimit.parseNum($(el).find(\"span.single\").first().data('blrlSingle'));\n\n return [val, val];\n } else {\n var from = BlacklightRangeLimit.parseNum($(el).find(\"span.from\").first().data('blrlBegin'));\n var to = BlacklightRangeLimit.parseNum($(el).find(\"span.to\").first().data('blrlEnd'));\n\n return [from, to];\n }\n}\n\n// Takes a div holding a ul of distribution segments produced by\n// blacklight_range_limit/_range_facets and makes it into\n// a flot area chart.\nBlacklightRangeLimit.areaChart = function areaChart(container) {\n //flot loaded? And canvas element supported.\n if ( BlacklightRangeLimit.domDependenciesMet() ) {\n\n // Grab the data from the ul div\n var series_data = new Array();\n var pointer_lookup = new Array();\n var x_ticks = new Array();\n var min = BlacklightRangeLimit.parseSegment($(container).find(\"ul li:first-child\").first())[0];\n var max = BlacklightRangeLimit.parseSegment($(container).find(\"ul li:last-child\").first())[1];\n\n $(container).find(\"ul li\").each(function() {\n var segment = BlacklightRangeLimit.parseSegment(this);\n var from = segment[0];\n var to = segment[1];\n\n var count = BlacklightRangeLimit.parseNum($(this).find(\"span.facet-count,span.count\").text());\n var avg = (count / (to - from + 1));\n\n //We use the avg as the y-coord, to make the area of each\n //segment proportional to how many documents it holds.\n series_data.push( [from, avg ] );\n series_data.push( [to+1, avg] );\n\n x_ticks.push(from);\n\n pointer_lookup.push({'from': from, 'to': to, 'count': count, 'label': $(this).find(\".facet-select,.facet_select\").html() });\n });\n\n x_ticks.push( max + 1 );\n\n var plot;\n var config = $(container).closest('.blrl-plot-config').data('plot-config') || $(container).closest('.facet-limit').data('plot-config') || {};\n\n try {\n plot = $.plot($(container), [series_data],\n $.extend(true, config, {\n yaxis: { ticks: [], min: 0, autoscaleMargin: 0.1},\n //xaxis: { ticks: x_ticks },\n xaxis: { tickDecimals: 0 }, // force integer ticks\n series: { lines: { fill: true, steps: true }},\n grid: {clickable: true, hoverable: true, autoHighlight: false, margin: { left: 0, right: 0 }},\n selection: {mode: \"x\"}\n }));\n }\n catch(err) {\n alert(err);\n }\n\n var find_segment_for = BlacklightRangeLimit.function_for_find_segment(pointer_lookup);\n var last_segment = null;\n $(container).tooltip({'html': true, 'placement': 'bottom', 'trigger': 'manual', 'delay': { show: 0, hide: 100}});\n\n $(container).bind(\"plothover\", function (event, pos, item) {\n var segment = find_segment_for(pos.x);\n\n if(segment != last_segment) {\n var title = find_segment_for(pos.x).label + ' (' + BlacklightRangeLimit.parseNum(segment.count) + ')';\n $(container).attr(\"title\", title).tooltip(\"_fixTitle\").tooltip(\"show\");\n\n last_segment = segment;\n }\n });\n\n $(container).bind(\"mouseout\", function() {\n last_segment = null;\n $(container).tooltip('hide');\n });\n $(container).bind(\"plotclick\", function (event, pos, item) {\n if ( plot.getSelection() == null) {\n segment = find_segment_for(pos.x);\n plot.setSelection(BlacklightRangeLimit.normalized_selection(segment.from, segment.to));\n }\n });\n $(container).bind(\"plotselected plotselecting\", function(event, ranges) {\n if (ranges != null ) {\n var from = Math.floor(ranges.xaxis.from);\n var to = Math.floor(ranges.xaxis.to);\n\n var form = $(container).closest(\".limit_content\").find(\"form.range_limit\");\n form.find(\"input.range_begin\").val(from);\n form.find(\"input.range_end\").val(to);\n\n var slider_placeholder = $(container).closest(\".limit_content\").find(\"[data-slider-placeholder]\");\n if (slider_placeholder) {\n slider_placeholder.slider(\"setValue\", [from, to]);\n }\n }\n });\n\n var form = $(container).closest(\".limit_content\").find(\"form.range_limit\");\n form.find(\"input.range_begin, input.range_end\").on('input', function () {\n plot.setSelection( BlacklightRangeLimit.form_selection(form, min, max), true );\n });\n $(container).closest(\".limit_content\").find(\".profile .range\").on(\"slide\", function(event, ui) {\n var values = $(event.target).data(\"slider\").getValue();\n form.find(\"input.range_begin\").val(values[0]);\n form.find(\"input.range_end\").val(values[1]);\n plot.setSelection(BlacklightRangeLimit.normalized_selection(values[0], Math.max(values[0], values[1])), true);\n });\n\n // initially entirely selected, to match slider\n plot.setSelection(BlacklightRangeLimit.normalized_selection(min, max));\n }\n}\n\n// after a collapsible facet contents is fully shown,\n// resize the flot chart to current conditions. This way, if you change\n// browser window size, you can get chart resized to fit by closing and opening\n// again, if needed.\nBlacklightRangeLimit.redrawPlot = function redrawPlot(container) {\n if (container && container.width() > 0) {\n // resize the container's height, since width may have changed.\n container.height( container.width() * BlacklightRangeLimit.display_ratio );\n\n // redraw the chart.\n var plot = container.data(\"plot\");\n if (plot) {\n // how to redraw after possible resize?\n // Cribbed from https://github.com/flot/flot/blob/master/jquery.flot.resize.js\n plot.resize();\n plot.setupGrid();\n plot.draw();\n // plus trigger redraw of the selection, which otherwise ain't always right\n // we'll trigger a fake event on one of the boxes\n var form = $(container).closest(\".limit_content\").find(\"form.range_limit\");\n form.find(\"input.range_begin\").trigger(\"change\");\n\n // send our custom event to trigger redraw of slider\n $(container).trigger(BlacklightRangeLimit.redrawnEvent);\n }\n }\n}\n","/**\n * Closure functions in this file are mainly concerned with initializing, resizing, and updating\n * range limit functionality based off of page load, facet opening, page resizing, and otherwise\n * events.\n */\n\nimport BlacklightRangeLimit from 'range_limit_shared'\n\nBlacklightRangeLimit.initializeDistroFacets = function(modalSelector) {\n // Facets already on the page? Turn em into a chart.\n $(\".range_limit .profile .distribution.chart_js ul\").each(function() {\n BlacklightRangeLimit.turnIntoPlot($(this).parent());\n });\n\n BlacklightRangeLimit.checkForNeededFacetsToFetch();\n\n // Listen for twitter bootstrap collapsible open events, to render flot\n // in previously hidden divs on open, if needed.\n $(\"body\").on(\"show.bs.collapse\", function(event) {\n // Was the target a .facet-content including a .chart-js?\n var container = $(event.target).filter(\".facet-content\").find(\".chart_js\");\n\n // only if it doesn't already have a canvas, it isn't already drawn\n if (container && container.find(\"canvas\").length == 0) {\n // be willing to wait up to 1100ms for container to\n // have width -- right away on show.bs is too soon, but\n // shown.bs is later than we want, we want to start rendering\n // while animation is still in progress.\n BlacklightRangeLimit.turnIntoPlot(container, 1100);\n }\n });\n\n // For Blacklight version < 8, when loaded in a modal\n $(modalSelector).on('shown.bs.modal', function() {\n $(this).find(\".range_limit .profile .distribution.chart_js ul\").each(function() {\n BlacklightRangeLimit.turnIntoPlot($(this).parent());\n });\n\n // Case when there is no currently selected range\n BlacklightRangeLimit.checkForNeededFacetsToFetch();\n });\n\n // Use a mutation observer to detect when the HTML dialog is open\n BlacklightRangeLimit.initPlotModalObserver(modalSelector);\n\n $(\"body\").on(\"shown.bs.collapse\", function(event) {\n var container = $(event.target).filter(\".facet-content\").find(\".chart_js\");\n BlacklightRangeLimit.redrawPlot(container);\n });\n\n // debouce borrowed from underscore\n // Returns a function, that, as long as it continues to be invoked, will not\n // be triggered. The function will be called after it stops being called for\n // N milliseconds. If `immediate` is passed, trigger the function on the\n // leading edge, instead of the trailing.\n const debounce = function(func, wait, immediate) {\n var timeout;\n return function() {\n var context = this, args = arguments;\n var later = function() {\n timeout = null;\n if (!immediate) func.apply(context, args);\n };\n var callNow = immediate && !timeout;\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n if (callNow) func.apply(context, args);\n };\n };\n\n $(window).on(\"resize\", debounce(function() {\n $(\".chart_js\").each(function(i, container) {\n BlacklightRangeLimit.redrawPlot($(container));\n });\n }, 350));\n}","// for Blacklight.onLoad:\nimport BlacklightRangeLimit from 'range_limit_shared'\n\nBlacklightRangeLimit.initializeSlider = function(modalSelector) {\n\n $(\".range_limit .profile .range.slider_js\").each(function() {\n BlacklightRangeLimit.buildSlider(this);\n });\n\n // For Blacklight < 8, when loaded in a modal\n $(modalSelector).on('shown.bs.modal', function() {\n $(this).find(\".range_limit .profile .range.slider_js\").each(function() {\n BlacklightRangeLimit.buildSlider(this);\n });\n });\n\n // For Blacklight 8, use a mutation observer to detect when the HTML dialog is open\n BlacklightRangeLimit.initSliderModalObserver(modalSelector);\n\n // catch event for redrawing chart, to redraw slider to match width\n $(\"body\").on(\"plotDrawn.blacklight.rangeLimit\", function(event) {\n var area = $(event.target).closest(\".limit_content.range_limit\");\n var plot = area.find(\".chart_js\").data(\"plot\");\n var slider_el = area.find(\".slider\");\n\n if (plot && slider_el) {\n slider_el.width(plot.width());\n slider_el.css(\"display\", \"block\")\n }\n });\n}\n\n// returns two element array min/max as numbers. If there is a limit applied,\n// it's boundaries are are limits. Otherwise, min/max in current result\n// set as sniffed from HTML. Pass in a DOM element for a div.range\n// Will return NaN as min or max in case of error or other weirdness.\nBlacklightRangeLimit.min_max = function min_max(range_element) {\n var current_limit = $(range_element).closest(\".limit_content.range_limit\").find(\".current\")\n let min, max\n min = max = BlacklightRangeLimit.parseNum(current_limit.find(\".single\").data('blrlSingle'))\n if ( isNaN(min)) {\n min = BlacklightRangeLimit.parseNum(current_limit.find(\".from\").first().data('blrlBegin'));\n max = BlacklightRangeLimit.parseNum(current_limit.find(\".to\").first().data('blrlEnd'));\n }\n\n if (isNaN(min) || isNaN(max)) {\n //no current limit, take from results min max included in spans\n min = BlacklightRangeLimit.parseNum($(range_element).find(\".min\").first().text());\n max = BlacklightRangeLimit.parseNum($(range_element).find(\".max\").first().text());\n }\n return [min, max]\n}\n\n\n// Check to see if a value is an Integer\n// see: http://stackoverflow.com/questions/3885817/how-to-check-if-a-number-is-float-or-integer\nBlacklightRangeLimit.isInt = function isInt(n) {\n return n % 1 === 0;\n}\n\nBlacklightRangeLimit.buildSlider = function buildSlider(thisContext) {\n var range_element = $(thisContext);\n\n var boundaries = BlacklightRangeLimit.min_max(thisContext);\n var min = boundaries[0];\n var max = boundaries[1];\n\n if (BlacklightRangeLimit.isInt(min) && BlacklightRangeLimit.isInt(max)) {\n $(thisContext).contents().wrapAll('<div class=\"sr-only visually-hidden\" />');\n\n var range_element = $(thisContext);\n var form = $(range_element).closest(\".range_limit\").find(\"form.range_limit\");\n var begin_el = form.find(\"input.range_begin\");\n var end_el = form.find(\"input.range_end\");\n\n var placeholder_input = $('<input type=\"hidden\" data-slider-placeholder=\"true\" />').appendTo(range_element);\n\n // make sure slider is loaded\n if (placeholder_input.slider !== undefined) {\n placeholder_input.slider({\n min: min,\n max: max,\n value: [min, max],\n tooltip: \"hide\"\n });\n\n // try to make slider width/orientation match chart's\n var container = range_element.closest(\".range_limit\");\n var plot_el = container.find(\".chart_js\");\n var plot = plot_el.data(\"plot\");\n var slider_el = container.find(\".slider\");\n\n if (plot_el) {\n plot_el.attr('aria-hidden', 'true');\n }\n\n if (slider_el) {\n slider_el.attr('aria-hidden', 'true');\n }\n\n if (plot && slider_el) {\n slider_el.width(plot.width());\n slider_el.css(\"display\", \"block\")\n } else if (slider_el) {\n slider_el.css(\"width\", \"100%\");\n }\n }\n\n // Slider change should update text input values.\n var parent = $(thisContext).parent();\n var form = $(parent).closest(\".limit_content\").find(\"form.range_limit\");\n $(parent).closest(\".limit_content\").find(\".profile .range\").on(\"slide\", function(event, ui) {\n var values = $(event.target).data(\"slider\").getValue();\n form.find(\"input.range_begin\").val(values[0]);\n form.find(\"input.range_end\").val(values[1]);\n });\n }\n\n begin_el.val(min);\n end_el.val(max);\n\n begin_el.on('input', function() {\n var val = BlacklightRangeLimit.parseNum(this.value);\n if (isNaN(val) || val < min) {\n //for weird data, set slider at min\n val = min;\n }\n var values = placeholder_input.data(\"slider\").getValue();\n values[0] = val;\n placeholder_input.slider(\"setValue\", values);\n });\n\n end_el.on('input', function() {\n var val = BlacklightRangeLimit.parseNum(this.value);\n if (isNaN(val) || val > max) {\n //weird entry, set slider to max\n val = max;\n }\n var values = placeholder_input.data(\"slider\").getValue();\n values[1] = val;\n placeholder_input.slider(\"setValue\", values);\n });\n\n begin_el.change(function() {\n var val1 = BlacklightRangeLimit.parseNum(begin_el.val());\n var val2 = BlacklightRangeLimit.parseNum(end_el.val());\n\n if (val2 < val1) {\n begin_el.val(val2);\n end_el.val(val1);\n }\n });\n\n end_el.change(function() {\n var val1 = BlacklightRangeLimit.parseNum(begin_el.val());\n var val2 = BlacklightRangeLimit.parseNum(end_el.val());\n\n if (val2 < val1) {\n begin_el.val(val2);\n end_el.val(val1);\n }\n });\n }\n","import BlacklightRangeLimit from 'range_limit_shared'\nimport 'range_limit_plotting'\nimport 'range_limit_distro_facets'\nimport 'range_limit_slider'\n\nBlacklightRangeLimit.initialize = function(modalSelector) {\n BlacklightRangeLimit.initializeDistroFacets(modalSelector)\n BlacklightRangeLimit.initializeSlider(modalSelector)\n}\n\nexport default BlacklightRangeLimit"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,542 @@
|
|
1
|
+
(function (global, factory) {
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
3
|
+
typeof define === 'function' && define.amd ? define(factory) :
|
4
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.BlacklightRangeLimit = factory());
|
5
|
+
})(this, (function () { 'use strict';
|
6
|
+
|
7
|
+
/**
|
8
|
+
* BlacklightRangeLimit module setup.
|
9
|
+
*/
|
10
|
+
|
11
|
+
const BlacklightRangeLimit = function (options) {
|
12
|
+
this.options = options || {};
|
13
|
+
};
|
14
|
+
|
15
|
+
BlacklightRangeLimit.display_ratio = 1/(1.618 * 2); // half a golden rectangle, why not
|
16
|
+
/* A custom event "plotDrawn.blacklight.rangeLimit" will be sent when flot plot
|
17
|
+
is (re-)drawn on screen possibly with a new size. target of event will be the DOM element
|
18
|
+
containing the plot. Used to resize slider to match. */
|
19
|
+
BlacklightRangeLimit.redrawnEvent = "plotDrawn.blacklight.rangeLimit";
|
20
|
+
|
21
|
+
// takes a string and parses into an integer, but throws away commas first, to avoid truncation when there is a comma
|
22
|
+
// use in place of javascript's native parseInt
|
23
|
+
BlacklightRangeLimit.parseNum = function parseNum(str) {
|
24
|
+
str = String(str).replace(/[^0-9-]/g, '');
|
25
|
+
return parseInt(str, 10);
|
26
|
+
};
|
27
|
+
|
28
|
+
BlacklightRangeLimit.form_selection = function form_selection(form, min, max) {
|
29
|
+
var begin_val = BlacklightRangeLimit.parseNum($(form).find("input.range_begin").val());
|
30
|
+
if (isNaN(begin_val) || begin_val < min) {
|
31
|
+
begin_val = min;
|
32
|
+
}
|
33
|
+
var end_val = BlacklightRangeLimit.parseNum($(form).find("input.range_end").val());
|
34
|
+
if (isNaN(end_val) || end_val > max) {
|
35
|
+
end_val = max;
|
36
|
+
}
|
37
|
+
|
38
|
+
return BlacklightRangeLimit.normalized_selection(begin_val, end_val);
|
39
|
+
};
|
40
|
+
|
41
|
+
// Add AJAX fetched range facets if needed, and add a chart to em
|
42
|
+
BlacklightRangeLimit.checkForNeededFacetsToFetch = function checkForNeededFacetsToFetch() {
|
43
|
+
$(".range_limit .profile .distribution a.load_distribution").each(function() {
|
44
|
+
var container = $(this).parent('div.distribution');
|
45
|
+
|
46
|
+
$(container).load($(this).attr('href'), function(response, status) {
|
47
|
+
if ($(container).hasClass("chart_js") && status == "success" ) {
|
48
|
+
BlacklightRangeLimit.turnIntoPlot(container);
|
49
|
+
}
|
50
|
+
});
|
51
|
+
});
|
52
|
+
};
|
53
|
+
|
54
|
+
BlacklightRangeLimit.function_for_find_segment = function function_for_find_segment(pointer_lookup_arr) {
|
55
|
+
return function(x_coord) {
|
56
|
+
for (var i = pointer_lookup_arr.length-1 ; i >= 0 ; i--) {
|
57
|
+
var hash = pointer_lookup_arr[i];
|
58
|
+
if (x_coord >= hash.from)
|
59
|
+
return hash;
|
60
|
+
}
|
61
|
+
return pointer_lookup_arr[0];
|
62
|
+
};
|
63
|
+
};
|
64
|
+
|
65
|
+
// Send endpoint to endpoint+0.99999 to have display
|
66
|
+
// more closely approximate limiting behavior esp
|
67
|
+
// at small resolutions. (Since we search on whole numbers,
|
68
|
+
// inclusive, but flot chart is decimal.)
|
69
|
+
BlacklightRangeLimit.normalized_selection = function normalized_selection(min, max) {
|
70
|
+
max += 0.99999;
|
71
|
+
|
72
|
+
return {xaxis: { 'from':min, 'to':max}}
|
73
|
+
};
|
74
|
+
|
75
|
+
// Check if Flot is loaded
|
76
|
+
BlacklightRangeLimit.domDependenciesMet = function domDependenciesMet() {
|
77
|
+
return typeof $.plot != "undefined"
|
78
|
+
};
|
79
|
+
|
80
|
+
BlacklightRangeLimit.modalObserverConfig = {
|
81
|
+
attributes: true,
|
82
|
+
};
|
83
|
+
|
84
|
+
BlacklightRangeLimit.initSliderModalObserver = function(modalSelector) {
|
85
|
+
// Use a mutation observer to detect when the modal dialog is open
|
86
|
+
const modalObserver = new MutationObserver(function(mutations) {
|
87
|
+
mutations.forEach(function(mutation) {
|
88
|
+
if (mutation.attributeName !== 'open') {return;}
|
89
|
+
if (mutation.target.hasAttribute('open')) {
|
90
|
+
$(modalSelector).find(".range_limit .profile .range.slider_js").each(function() {
|
91
|
+
BlacklightRangeLimit.buildSlider(this);
|
92
|
+
});
|
93
|
+
}
|
94
|
+
});
|
95
|
+
});
|
96
|
+
modalObserver.observe(document.querySelector(modalSelector), BlacklightRangeLimit.modalObserverConfig);
|
97
|
+
};
|
98
|
+
|
99
|
+
BlacklightRangeLimit.initPlotModalObserver = function(modalSelector) {
|
100
|
+
// Use a mutation observer to detect when the modal dialog is open
|
101
|
+
const modalObserver = new MutationObserver(function(mutations) {
|
102
|
+
mutations.forEach(function(mutation) {
|
103
|
+
if (mutation.attributeName !== 'open') {return;}
|
104
|
+
if (mutation.target.hasAttribute('open')) {
|
105
|
+
$(modalSelector).find(".range_limit .profile .distribution.chart_js ul").each(function() {
|
106
|
+
BlacklightRangeLimit.turnIntoPlot($(this).parent());
|
107
|
+
});
|
108
|
+
|
109
|
+
// Case when there is no currently selected range
|
110
|
+
BlacklightRangeLimit.checkForNeededFacetsToFetch();
|
111
|
+
}
|
112
|
+
});
|
113
|
+
});
|
114
|
+
modalObserver.observe(document.querySelector(modalSelector), BlacklightRangeLimit.modalObserverConfig);
|
115
|
+
};
|
116
|
+
|
117
|
+
// second arg, if provided, is a number of ms we're willing to
|
118
|
+
|
119
|
+
BlacklightRangeLimit.turnIntoPlot = function turnIntoPlot(container, wait_for_visible) {
|
120
|
+
// flot can only render in a a div with a defined width.
|
121
|
+
// for instance, a hidden div can't generally be rendered in (although if you set
|
122
|
+
// an explicit width on it, it might work)
|
123
|
+
//
|
124
|
+
// We'll count on later code that catch bootstrap collapse open to render
|
125
|
+
// on show, for currently hidden divs.
|
126
|
+
|
127
|
+
// for some reason width sometimes return negative, not sure
|
128
|
+
// why but it's some kind of hidden.
|
129
|
+
if (container.width() > 0) {
|
130
|
+
var height = container.width() * BlacklightRangeLimit.display_ratio;
|
131
|
+
|
132
|
+
// Need an explicit height to make flot happy.
|
133
|
+
container.height( height );
|
134
|
+
|
135
|
+
BlacklightRangeLimit.areaChart($(container));
|
136
|
+
|
137
|
+
$(container).trigger(BlacklightRangeLimit.redrawnEvent);
|
138
|
+
}
|
139
|
+
else if (wait_for_visible > 0) {
|
140
|
+
setTimeout(function() {
|
141
|
+
BlacklightRangeLimit.turnIntoPlot(container, wait_for_visible - 50);
|
142
|
+
}, 50);
|
143
|
+
}
|
144
|
+
};
|
145
|
+
|
146
|
+
BlacklightRangeLimit.parseSegment = function parseSegment(el) {
|
147
|
+
if ($(el).find("span.single").first().data('blrlSingle')) {
|
148
|
+
var val = BlacklightRangeLimit.parseNum($(el).find("span.single").first().data('blrlSingle'));
|
149
|
+
|
150
|
+
return [val, val];
|
151
|
+
} else {
|
152
|
+
var from = BlacklightRangeLimit.parseNum($(el).find("span.from").first().data('blrlBegin'));
|
153
|
+
var to = BlacklightRangeLimit.parseNum($(el).find("span.to").first().data('blrlEnd'));
|
154
|
+
|
155
|
+
return [from, to];
|
156
|
+
}
|
157
|
+
};
|
158
|
+
|
159
|
+
// Takes a div holding a ul of distribution segments produced by
|
160
|
+
// blacklight_range_limit/_range_facets and makes it into
|
161
|
+
// a flot area chart.
|
162
|
+
BlacklightRangeLimit.areaChart = function areaChart(container) {
|
163
|
+
//flot loaded? And canvas element supported.
|
164
|
+
if ( BlacklightRangeLimit.domDependenciesMet() ) {
|
165
|
+
|
166
|
+
// Grab the data from the ul div
|
167
|
+
var series_data = new Array();
|
168
|
+
var pointer_lookup = new Array();
|
169
|
+
var x_ticks = new Array();
|
170
|
+
var min = BlacklightRangeLimit.parseSegment($(container).find("ul li:first-child").first())[0];
|
171
|
+
var max = BlacklightRangeLimit.parseSegment($(container).find("ul li:last-child").first())[1];
|
172
|
+
|
173
|
+
$(container).find("ul li").each(function() {
|
174
|
+
var segment = BlacklightRangeLimit.parseSegment(this);
|
175
|
+
var from = segment[0];
|
176
|
+
var to = segment[1];
|
177
|
+
|
178
|
+
var count = BlacklightRangeLimit.parseNum($(this).find("span.facet-count,span.count").text());
|
179
|
+
var avg = (count / (to - from + 1));
|
180
|
+
|
181
|
+
//We use the avg as the y-coord, to make the area of each
|
182
|
+
//segment proportional to how many documents it holds.
|
183
|
+
series_data.push( [from, avg ] );
|
184
|
+
series_data.push( [to+1, avg] );
|
185
|
+
|
186
|
+
x_ticks.push(from);
|
187
|
+
|
188
|
+
pointer_lookup.push({'from': from, 'to': to, 'count': count, 'label': $(this).find(".facet-select,.facet_select").html() });
|
189
|
+
});
|
190
|
+
|
191
|
+
x_ticks.push( max + 1 );
|
192
|
+
|
193
|
+
var plot;
|
194
|
+
var config = $(container).closest('.blrl-plot-config').data('plot-config') || $(container).closest('.facet-limit').data('plot-config') || {};
|
195
|
+
|
196
|
+
try {
|
197
|
+
plot = $.plot($(container), [series_data],
|
198
|
+
$.extend(true, config, {
|
199
|
+
yaxis: { ticks: [], min: 0, autoscaleMargin: 0.1},
|
200
|
+
//xaxis: { ticks: x_ticks },
|
201
|
+
xaxis: { tickDecimals: 0 }, // force integer ticks
|
202
|
+
series: { lines: { fill: true, steps: true }},
|
203
|
+
grid: {clickable: true, hoverable: true, autoHighlight: false, margin: { left: 0, right: 0 }},
|
204
|
+
selection: {mode: "x"}
|
205
|
+
}));
|
206
|
+
}
|
207
|
+
catch(err) {
|
208
|
+
alert(err);
|
209
|
+
}
|
210
|
+
|
211
|
+
var find_segment_for = BlacklightRangeLimit.function_for_find_segment(pointer_lookup);
|
212
|
+
var last_segment = null;
|
213
|
+
$(container).tooltip({'html': true, 'placement': 'bottom', 'trigger': 'manual', 'delay': { show: 0, hide: 100}});
|
214
|
+
|
215
|
+
$(container).bind("plothover", function (event, pos, item) {
|
216
|
+
var segment = find_segment_for(pos.x);
|
217
|
+
|
218
|
+
if(segment != last_segment) {
|
219
|
+
var title = find_segment_for(pos.x).label + ' (' + BlacklightRangeLimit.parseNum(segment.count) + ')';
|
220
|
+
$(container).attr("title", title).tooltip("_fixTitle").tooltip("show");
|
221
|
+
|
222
|
+
last_segment = segment;
|
223
|
+
}
|
224
|
+
});
|
225
|
+
|
226
|
+
$(container).bind("mouseout", function() {
|
227
|
+
last_segment = null;
|
228
|
+
$(container).tooltip('hide');
|
229
|
+
});
|
230
|
+
$(container).bind("plotclick", function (event, pos, item) {
|
231
|
+
if ( plot.getSelection() == null) {
|
232
|
+
segment = find_segment_for(pos.x);
|
233
|
+
plot.setSelection(BlacklightRangeLimit.normalized_selection(segment.from, segment.to));
|
234
|
+
}
|
235
|
+
});
|
236
|
+
$(container).bind("plotselected plotselecting", function(event, ranges) {
|
237
|
+
if (ranges != null ) {
|
238
|
+
var from = Math.floor(ranges.xaxis.from);
|
239
|
+
var to = Math.floor(ranges.xaxis.to);
|
240
|
+
|
241
|
+
var form = $(container).closest(".limit_content").find("form.range_limit");
|
242
|
+
form.find("input.range_begin").val(from);
|
243
|
+
form.find("input.range_end").val(to);
|
244
|
+
|
245
|
+
var slider_placeholder = $(container).closest(".limit_content").find("[data-slider-placeholder]");
|
246
|
+
if (slider_placeholder) {
|
247
|
+
slider_placeholder.slider("setValue", [from, to]);
|
248
|
+
}
|
249
|
+
}
|
250
|
+
});
|
251
|
+
|
252
|
+
var form = $(container).closest(".limit_content").find("form.range_limit");
|
253
|
+
form.find("input.range_begin, input.range_end").on('input', function () {
|
254
|
+
plot.setSelection( BlacklightRangeLimit.form_selection(form, min, max), true );
|
255
|
+
});
|
256
|
+
$(container).closest(".limit_content").find(".profile .range").on("slide", function(event, ui) {
|
257
|
+
var values = $(event.target).data("slider").getValue();
|
258
|
+
form.find("input.range_begin").val(values[0]);
|
259
|
+
form.find("input.range_end").val(values[1]);
|
260
|
+
plot.setSelection(BlacklightRangeLimit.normalized_selection(values[0], Math.max(values[0], values[1])), true);
|
261
|
+
});
|
262
|
+
|
263
|
+
// initially entirely selected, to match slider
|
264
|
+
plot.setSelection(BlacklightRangeLimit.normalized_selection(min, max));
|
265
|
+
}
|
266
|
+
};
|
267
|
+
|
268
|
+
// after a collapsible facet contents is fully shown,
|
269
|
+
// resize the flot chart to current conditions. This way, if you change
|
270
|
+
// browser window size, you can get chart resized to fit by closing and opening
|
271
|
+
// again, if needed.
|
272
|
+
BlacklightRangeLimit.redrawPlot = function redrawPlot(container) {
|
273
|
+
if (container && container.width() > 0) {
|
274
|
+
// resize the container's height, since width may have changed.
|
275
|
+
container.height( container.width() * BlacklightRangeLimit.display_ratio );
|
276
|
+
|
277
|
+
// redraw the chart.
|
278
|
+
var plot = container.data("plot");
|
279
|
+
if (plot) {
|
280
|
+
// how to redraw after possible resize?
|
281
|
+
// Cribbed from https://github.com/flot/flot/blob/master/jquery.flot.resize.js
|
282
|
+
plot.resize();
|
283
|
+
plot.setupGrid();
|
284
|
+
plot.draw();
|
285
|
+
// plus trigger redraw of the selection, which otherwise ain't always right
|
286
|
+
// we'll trigger a fake event on one of the boxes
|
287
|
+
var form = $(container).closest(".limit_content").find("form.range_limit");
|
288
|
+
form.find("input.range_begin").trigger("change");
|
289
|
+
|
290
|
+
// send our custom event to trigger redraw of slider
|
291
|
+
$(container).trigger(BlacklightRangeLimit.redrawnEvent);
|
292
|
+
}
|
293
|
+
}
|
294
|
+
};
|
295
|
+
|
296
|
+
/**
|
297
|
+
* Closure functions in this file are mainly concerned with initializing, resizing, and updating
|
298
|
+
* range limit functionality based off of page load, facet opening, page resizing, and otherwise
|
299
|
+
* events.
|
300
|
+
*/
|
301
|
+
|
302
|
+
BlacklightRangeLimit.initializeDistroFacets = function(modalSelector) {
|
303
|
+
// Facets already on the page? Turn em into a chart.
|
304
|
+
$(".range_limit .profile .distribution.chart_js ul").each(function() {
|
305
|
+
BlacklightRangeLimit.turnIntoPlot($(this).parent());
|
306
|
+
});
|
307
|
+
|
308
|
+
BlacklightRangeLimit.checkForNeededFacetsToFetch();
|
309
|
+
|
310
|
+
// Listen for twitter bootstrap collapsible open events, to render flot
|
311
|
+
// in previously hidden divs on open, if needed.
|
312
|
+
$("body").on("show.bs.collapse", function(event) {
|
313
|
+
// Was the target a .facet-content including a .chart-js?
|
314
|
+
var container = $(event.target).filter(".facet-content").find(".chart_js");
|
315
|
+
|
316
|
+
// only if it doesn't already have a canvas, it isn't already drawn
|
317
|
+
if (container && container.find("canvas").length == 0) {
|
318
|
+
// be willing to wait up to 1100ms for container to
|
319
|
+
// have width -- right away on show.bs is too soon, but
|
320
|
+
// shown.bs is later than we want, we want to start rendering
|
321
|
+
// while animation is still in progress.
|
322
|
+
BlacklightRangeLimit.turnIntoPlot(container, 1100);
|
323
|
+
}
|
324
|
+
});
|
325
|
+
|
326
|
+
// For Blacklight version < 8, when loaded in a modal
|
327
|
+
$(modalSelector).on('shown.bs.modal', function() {
|
328
|
+
$(this).find(".range_limit .profile .distribution.chart_js ul").each(function() {
|
329
|
+
BlacklightRangeLimit.turnIntoPlot($(this).parent());
|
330
|
+
});
|
331
|
+
|
332
|
+
// Case when there is no currently selected range
|
333
|
+
BlacklightRangeLimit.checkForNeededFacetsToFetch();
|
334
|
+
});
|
335
|
+
|
336
|
+
// Use a mutation observer to detect when the HTML dialog is open
|
337
|
+
BlacklightRangeLimit.initPlotModalObserver(modalSelector);
|
338
|
+
|
339
|
+
$("body").on("shown.bs.collapse", function(event) {
|
340
|
+
var container = $(event.target).filter(".facet-content").find(".chart_js");
|
341
|
+
BlacklightRangeLimit.redrawPlot(container);
|
342
|
+
});
|
343
|
+
|
344
|
+
// debouce borrowed from underscore
|
345
|
+
// Returns a function, that, as long as it continues to be invoked, will not
|
346
|
+
// be triggered. The function will be called after it stops being called for
|
347
|
+
// N milliseconds. If `immediate` is passed, trigger the function on the
|
348
|
+
// leading edge, instead of the trailing.
|
349
|
+
const debounce = function(func, wait, immediate) {
|
350
|
+
var timeout;
|
351
|
+
return function() {
|
352
|
+
var context = this, args = arguments;
|
353
|
+
var later = function() {
|
354
|
+
timeout = null;
|
355
|
+
if (!immediate) func.apply(context, args);
|
356
|
+
};
|
357
|
+
var callNow = immediate && !timeout;
|
358
|
+
clearTimeout(timeout);
|
359
|
+
timeout = setTimeout(later, wait);
|
360
|
+
if (callNow) func.apply(context, args);
|
361
|
+
};
|
362
|
+
};
|
363
|
+
|
364
|
+
$(window).on("resize", debounce(function() {
|
365
|
+
$(".chart_js").each(function(i, container) {
|
366
|
+
BlacklightRangeLimit.redrawPlot($(container));
|
367
|
+
});
|
368
|
+
}, 350));
|
369
|
+
};
|
370
|
+
|
371
|
+
// for Blacklight.onLoad:
|
372
|
+
|
373
|
+
BlacklightRangeLimit.initializeSlider = function(modalSelector) {
|
374
|
+
|
375
|
+
$(".range_limit .profile .range.slider_js").each(function() {
|
376
|
+
BlacklightRangeLimit.buildSlider(this);
|
377
|
+
});
|
378
|
+
|
379
|
+
// For Blacklight < 8, when loaded in a modal
|
380
|
+
$(modalSelector).on('shown.bs.modal', function() {
|
381
|
+
$(this).find(".range_limit .profile .range.slider_js").each(function() {
|
382
|
+
BlacklightRangeLimit.buildSlider(this);
|
383
|
+
});
|
384
|
+
});
|
385
|
+
|
386
|
+
// For Blacklight 8, use a mutation observer to detect when the HTML dialog is open
|
387
|
+
BlacklightRangeLimit.initSliderModalObserver(modalSelector);
|
388
|
+
|
389
|
+
// catch event for redrawing chart, to redraw slider to match width
|
390
|
+
$("body").on("plotDrawn.blacklight.rangeLimit", function(event) {
|
391
|
+
var area = $(event.target).closest(".limit_content.range_limit");
|
392
|
+
var plot = area.find(".chart_js").data("plot");
|
393
|
+
var slider_el = area.find(".slider");
|
394
|
+
|
395
|
+
if (plot && slider_el) {
|
396
|
+
slider_el.width(plot.width());
|
397
|
+
slider_el.css("display", "block");
|
398
|
+
}
|
399
|
+
});
|
400
|
+
};
|
401
|
+
|
402
|
+
// returns two element array min/max as numbers. If there is a limit applied,
|
403
|
+
// it's boundaries are are limits. Otherwise, min/max in current result
|
404
|
+
// set as sniffed from HTML. Pass in a DOM element for a div.range
|
405
|
+
// Will return NaN as min or max in case of error or other weirdness.
|
406
|
+
BlacklightRangeLimit.min_max = function min_max(range_element) {
|
407
|
+
var current_limit = $(range_element).closest(".limit_content.range_limit").find(".current");
|
408
|
+
let min, max;
|
409
|
+
min = max = BlacklightRangeLimit.parseNum(current_limit.find(".single").data('blrlSingle'));
|
410
|
+
if ( isNaN(min)) {
|
411
|
+
min = BlacklightRangeLimit.parseNum(current_limit.find(".from").first().data('blrlBegin'));
|
412
|
+
max = BlacklightRangeLimit.parseNum(current_limit.find(".to").first().data('blrlEnd'));
|
413
|
+
}
|
414
|
+
|
415
|
+
if (isNaN(min) || isNaN(max)) {
|
416
|
+
//no current limit, take from results min max included in spans
|
417
|
+
min = BlacklightRangeLimit.parseNum($(range_element).find(".min").first().text());
|
418
|
+
max = BlacklightRangeLimit.parseNum($(range_element).find(".max").first().text());
|
419
|
+
}
|
420
|
+
return [min, max]
|
421
|
+
};
|
422
|
+
|
423
|
+
|
424
|
+
// Check to see if a value is an Integer
|
425
|
+
// see: http://stackoverflow.com/questions/3885817/how-to-check-if-a-number-is-float-or-integer
|
426
|
+
BlacklightRangeLimit.isInt = function isInt(n) {
|
427
|
+
return n % 1 === 0;
|
428
|
+
};
|
429
|
+
|
430
|
+
BlacklightRangeLimit.buildSlider = function buildSlider(thisContext) {
|
431
|
+
var range_element = $(thisContext);
|
432
|
+
|
433
|
+
var boundaries = BlacklightRangeLimit.min_max(thisContext);
|
434
|
+
var min = boundaries[0];
|
435
|
+
var max = boundaries[1];
|
436
|
+
|
437
|
+
if (BlacklightRangeLimit.isInt(min) && BlacklightRangeLimit.isInt(max)) {
|
438
|
+
$(thisContext).contents().wrapAll('<div class="sr-only visually-hidden" />');
|
439
|
+
|
440
|
+
var range_element = $(thisContext);
|
441
|
+
var form = $(range_element).closest(".range_limit").find("form.range_limit");
|
442
|
+
var begin_el = form.find("input.range_begin");
|
443
|
+
var end_el = form.find("input.range_end");
|
444
|
+
|
445
|
+
var placeholder_input = $('<input type="hidden" data-slider-placeholder="true" />').appendTo(range_element);
|
446
|
+
|
447
|
+
// make sure slider is loaded
|
448
|
+
if (placeholder_input.slider !== undefined) {
|
449
|
+
placeholder_input.slider({
|
450
|
+
min: min,
|
451
|
+
max: max,
|
452
|
+
value: [min, max],
|
453
|
+
tooltip: "hide"
|
454
|
+
});
|
455
|
+
|
456
|
+
// try to make slider width/orientation match chart's
|
457
|
+
var container = range_element.closest(".range_limit");
|
458
|
+
var plot_el = container.find(".chart_js");
|
459
|
+
var plot = plot_el.data("plot");
|
460
|
+
var slider_el = container.find(".slider");
|
461
|
+
|
462
|
+
if (plot_el) {
|
463
|
+
plot_el.attr('aria-hidden', 'true');
|
464
|
+
}
|
465
|
+
|
466
|
+
if (slider_el) {
|
467
|
+
slider_el.attr('aria-hidden', 'true');
|
468
|
+
}
|
469
|
+
|
470
|
+
if (plot && slider_el) {
|
471
|
+
slider_el.width(plot.width());
|
472
|
+
slider_el.css("display", "block");
|
473
|
+
} else if (slider_el) {
|
474
|
+
slider_el.css("width", "100%");
|
475
|
+
}
|
476
|
+
}
|
477
|
+
|
478
|
+
// Slider change should update text input values.
|
479
|
+
var parent = $(thisContext).parent();
|
480
|
+
var form = $(parent).closest(".limit_content").find("form.range_limit");
|
481
|
+
$(parent).closest(".limit_content").find(".profile .range").on("slide", function(event, ui) {
|
482
|
+
var values = $(event.target).data("slider").getValue();
|
483
|
+
form.find("input.range_begin").val(values[0]);
|
484
|
+
form.find("input.range_end").val(values[1]);
|
485
|
+
});
|
486
|
+
}
|
487
|
+
|
488
|
+
begin_el.val(min);
|
489
|
+
end_el.val(max);
|
490
|
+
|
491
|
+
begin_el.on('input', function() {
|
492
|
+
var val = BlacklightRangeLimit.parseNum(this.value);
|
493
|
+
if (isNaN(val) || val < min) {
|
494
|
+
//for weird data, set slider at min
|
495
|
+
val = min;
|
496
|
+
}
|
497
|
+
var values = placeholder_input.data("slider").getValue();
|
498
|
+
values[0] = val;
|
499
|
+
placeholder_input.slider("setValue", values);
|
500
|
+
});
|
501
|
+
|
502
|
+
end_el.on('input', function() {
|
503
|
+
var val = BlacklightRangeLimit.parseNum(this.value);
|
504
|
+
if (isNaN(val) || val > max) {
|
505
|
+
//weird entry, set slider to max
|
506
|
+
val = max;
|
507
|
+
}
|
508
|
+
var values = placeholder_input.data("slider").getValue();
|
509
|
+
values[1] = val;
|
510
|
+
placeholder_input.slider("setValue", values);
|
511
|
+
});
|
512
|
+
|
513
|
+
begin_el.change(function() {
|
514
|
+
var val1 = BlacklightRangeLimit.parseNum(begin_el.val());
|
515
|
+
var val2 = BlacklightRangeLimit.parseNum(end_el.val());
|
516
|
+
|
517
|
+
if (val2 < val1) {
|
518
|
+
begin_el.val(val2);
|
519
|
+
end_el.val(val1);
|
520
|
+
}
|
521
|
+
});
|
522
|
+
|
523
|
+
end_el.change(function() {
|
524
|
+
var val1 = BlacklightRangeLimit.parseNum(begin_el.val());
|
525
|
+
var val2 = BlacklightRangeLimit.parseNum(end_el.val());
|
526
|
+
|
527
|
+
if (val2 < val1) {
|
528
|
+
begin_el.val(val2);
|
529
|
+
end_el.val(val1);
|
530
|
+
}
|
531
|
+
});
|
532
|
+
};
|
533
|
+
|
534
|
+
BlacklightRangeLimit.initialize = function(modalSelector) {
|
535
|
+
BlacklightRangeLimit.initializeDistroFacets(modalSelector);
|
536
|
+
BlacklightRangeLimit.initializeSlider(modalSelector);
|
537
|
+
};
|
538
|
+
|
539
|
+
return BlacklightRangeLimit;
|
540
|
+
|
541
|
+
}));
|
542
|
+
//# sourceMappingURL=blacklight_range_limit.umd.js.map
|