aboutsummaryrefslogtreecommitdiffstats
path: root/admin/themes/default/js/doubleSlider.js
blob: 490331febeed25b4c7ed3fd7cbd9ab1208a7f08d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
(function($){

/**
 * OPTIONS:
 * values {mixed[]}
 * selected {object} min and max
 * text {string}
 */
$.fn.pwgDoubleSlider = function(options) {
  var that = this;
  
  function onChange(e, ui) {
    that.find('[data-input=min]').val(options.values[ui.values[0]]);
    that.find('[data-input=max]').val(options.values[ui.values[1]]);

    that.find('.slider-info').html(sprintf(
      options.text,
      options.values[ui.values[0]],
      options.values[ui.values[1]]
    ));
  }

  var slider = this.find('.slider-slider').slider({
    range: true,
    min: 0,
    max: options.values.length - 1,
    values: [
      options.values.indexOf(options.selected.min),
      options.values.indexOf(options.selected.max)
    ],
    slide: onChange,
    change: onChange
  });

  this.find('.slider-choice').on('click', function(){
    slider.slider('values', 0, options.values.indexOf($(this).data('min')));
    slider.slider('values', 1, options.values.indexOf($(this).data('max')));
  });

  return this;
};

}(jQuery));