|
27
|
1 |
//this code solves this problem: http://stackoverflow.com/questions/5955343/ |
|
|
2 |
|
|
|
3 |
(function( $, undefined ) { |
|
|
4 |
|
|
|
5 |
$.widget("ui.dragslider", $.ui.slider, { |
|
|
6 |
|
|
|
7 |
options: $.extend({},$.ui.slider.prototype.options,{rangeDrag:false}), |
|
|
8 |
|
|
|
9 |
_create: function() { |
|
|
10 |
$.ui.slider.prototype._create.apply(this,arguments); |
|
|
11 |
this._rangeCapture = false; |
|
|
12 |
}, |
|
|
13 |
|
|
|
14 |
_mouseCapture: function( event ) { |
|
|
15 |
var o = this.options; |
|
|
16 |
|
|
|
17 |
if ( o.disabled ) return false; |
|
|
18 |
|
|
|
19 |
if(event.target == this.range.get(0) && o.rangeDrag == true && o.range == true) { |
|
|
20 |
this._rangeCapture = true; |
|
|
21 |
this._rangeStart = null; |
|
|
22 |
} |
|
|
23 |
else { |
|
|
24 |
this._rangeCapture = false; |
|
|
25 |
} |
|
|
26 |
|
|
|
27 |
$.ui.slider.prototype._mouseCapture.apply(this,arguments); |
|
|
28 |
|
|
|
29 |
if(this._rangeCapture == true) { |
|
|
30 |
this.handles.removeClass("ui-state-active").blur(); |
|
|
31 |
} |
|
|
32 |
|
|
|
33 |
return true; |
|
|
34 |
}, |
|
|
35 |
|
|
|
36 |
_mouseStop: function( event ) { |
|
|
37 |
this._rangeStart = null; |
|
|
38 |
return $.ui.slider.prototype._mouseStop.apply(this,arguments); |
|
|
39 |
}, |
|
|
40 |
|
|
|
41 |
_slide: function( event, index, newVal ) { |
|
|
42 |
if(!this._rangeCapture) { |
|
|
43 |
return $.ui.slider.prototype._slide.apply(this,arguments); |
|
|
44 |
} |
|
|
45 |
|
|
|
46 |
if(this._rangeStart == null) { |
|
|
47 |
this._rangeStart = newVal; |
|
|
48 |
} |
|
|
49 |
|
|
|
50 |
var oldValLeft = this.options.values[0], |
|
|
51 |
oldValRight = this.options.values[1], |
|
|
52 |
slideDist = newVal - this._rangeStart, |
|
|
53 |
newValueLeft = oldValLeft + slideDist, |
|
|
54 |
newValueRight = oldValRight + slideDist, |
|
|
55 |
allowed; |
|
|
56 |
|
|
|
57 |
if ( this.options.values && this.options.values.length ) { |
|
|
58 |
if(newValueRight > this._valueMax() && slideDist > 0) { |
|
|
59 |
slideDist -= (newValueRight-this._valueMax()); |
|
|
60 |
newValueLeft = oldValLeft + slideDist; |
|
|
61 |
newValueRight = oldValRight + slideDist; |
|
|
62 |
} |
|
|
63 |
|
|
|
64 |
if(newValueLeft < this._valueMin()) { |
|
|
65 |
slideDist += (this._valueMin()-newValueLeft); |
|
|
66 |
newValueLeft = oldValLeft + slideDist; |
|
|
67 |
newValueRight = oldValRight + slideDist; |
|
|
68 |
} |
|
|
69 |
|
|
|
70 |
if ( slideDist != 0 ) { |
|
|
71 |
newValues = this.values(); |
|
|
72 |
newValues[ 0 ] = newValueLeft; |
|
|
73 |
newValues[ 1 ] = newValueRight; |
|
|
74 |
|
|
|
75 |
// A slide can be canceled by returning false from the slide callback |
|
|
76 |
allowed = this._trigger( "slide", event, { |
|
|
77 |
handle: this.handles[ index ], |
|
|
78 |
value: slideDist, |
|
|
79 |
values: newValues |
|
|
80 |
} ); |
|
|
81 |
|
|
|
82 |
if ( allowed !== false ) { |
|
|
83 |
this.values( 0, newValueLeft, true ); |
|
|
84 |
this.values( 1, newValueRight, true ); |
|
|
85 |
} |
|
|
86 |
this._rangeStart = newVal; |
|
|
87 |
} |
|
|
88 |
} |
|
|
89 |
|
|
|
90 |
|
|
|
91 |
|
|
|
92 |
}, |
|
|
93 |
|
|
|
94 |
|
|
|
95 |
/* |
|
|
96 |
//only for testing purpose |
|
|
97 |
value: function(input) { |
|
|
98 |
console.log("this is working!"); |
|
|
99 |
$.ui.slider.prototype.value.apply(this,arguments); |
|
|
100 |
} |
|
|
101 |
*/ |
|
|
102 |
}); |
|
|
103 |
|
|
|
104 |
})(jQuery); |