materialize-sass 0.99.0 → 0.100.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (60) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +2 -2
  3. data/app/assets/javascripts/materialize.js +6015 -5060
  4. data/app/assets/javascripts/materialize/animation.js +4 -5
  5. data/app/assets/javascripts/materialize/buttons.js +24 -38
  6. data/app/assets/javascripts/materialize/cards.js +13 -21
  7. data/app/assets/javascripts/materialize/carousel.js +122 -110
  8. data/app/assets/javascripts/materialize/character_counter.js +14 -22
  9. data/app/assets/javascripts/materialize/chips.js +41 -44
  10. data/app/assets/javascripts/materialize/collapsible.js +41 -46
  11. data/app/assets/javascripts/materialize/date_picker/picker.date.js +965 -1167
  12. data/app/assets/javascripts/materialize/date_picker/picker.js +546 -634
  13. data/app/assets/javascripts/materialize/date_picker/picker.time.js +166 -212
  14. data/app/assets/javascripts/materialize/dropdown.js +53 -68
  15. data/app/assets/javascripts/materialize/extras/nouislider.js +3 -1
  16. data/app/assets/javascripts/materialize/extras/nouislider.min.js +1 -1
  17. data/app/assets/javascripts/materialize/forms.js +156 -154
  18. data/app/assets/javascripts/materialize/global.js +34 -43
  19. data/app/assets/javascripts/materialize/hammer.min.js +424 -1
  20. data/app/assets/javascripts/materialize/initial.js +3 -3
  21. data/app/assets/javascripts/materialize/jquery.easing.1.4.js +120 -142
  22. data/app/assets/javascripts/materialize/jquery.hammer.js +9 -9
  23. data/app/assets/javascripts/materialize/materialbox.js +81 -107
  24. data/app/assets/javascripts/materialize/modal.js +373 -162
  25. data/app/assets/javascripts/materialize/parallax.js +11 -15
  26. data/app/assets/javascripts/materialize/pushpin.js +2 -5
  27. data/app/assets/javascripts/materialize/scrollFire.js +9 -11
  28. data/app/assets/javascripts/materialize/scrollspy.js +84 -92
  29. data/app/assets/javascripts/materialize/sideNav.js +128 -139
  30. data/app/assets/javascripts/materialize/slider.js +83 -112
  31. data/app/assets/javascripts/materialize/tabs.js +196 -196
  32. data/app/assets/javascripts/materialize/tapTarget.js +170 -173
  33. data/app/assets/javascripts/materialize/toasts.js +330 -112
  34. data/app/assets/javascripts/materialize/tooltip.js +134 -145
  35. data/app/assets/javascripts/materialize/transitions.js +43 -49
  36. data/app/assets/javascripts/materialize/velocity.min.js +623 -2
  37. data/app/assets/javascripts/materialize/waves.js +42 -47
  38. data/app/assets/stylesheets/materialize/components/_buttons.scss +1 -1
  39. data/app/assets/stylesheets/materialize/components/_carousel.scss +4 -5
  40. data/app/assets/stylesheets/materialize/components/_chips.scss +1 -0
  41. data/app/assets/stylesheets/materialize/components/_collapsible.scss +4 -7
  42. data/app/assets/stylesheets/materialize/components/_color.scss +1 -1
  43. data/app/assets/stylesheets/materialize/components/_global.scss +8 -14
  44. data/app/assets/stylesheets/materialize/components/_navbar.scss +0 -1
  45. data/app/assets/stylesheets/materialize/components/_tabs.scss +1 -7
  46. data/app/assets/stylesheets/materialize/components/_toast.scss +6 -12
  47. data/app/assets/stylesheets/materialize/components/_variables.scss +55 -43
  48. data/app/assets/stylesheets/materialize/components/date_picker/_default.scss +1 -0
  49. data/app/assets/stylesheets/materialize/components/forms/_checkboxes.scss +2 -12
  50. data/app/assets/stylesheets/materialize/components/forms/_file-input.scss +6 -0
  51. data/app/assets/stylesheets/materialize/components/forms/_input-fields.scss +67 -37
  52. data/app/assets/stylesheets/materialize/components/forms/_radio-buttons.scss +1 -3
  53. data/app/assets/stylesheets/materialize/components/forms/_select.scss +72 -11
  54. data/app/assets/stylesheets/materialize/components/forms/_switches.scss +2 -4
  55. data/app/assets/stylesheets/materialize/extras/nouislider.css +8 -1
  56. data/lib/materialize-sass/version.rb +1 -1
  57. metadata +2 -5
  58. data/app/assets/javascripts/materialize/init.js +0 -214
  59. data/app/assets/javascripts/materialize/jquery.timeago.min.js +0 -1
  60. data/app/assets/javascripts/materialize/prism.js +0 -8
@@ -2,7 +2,7 @@
2
2
 
3
3
  var methods = {
4
4
 
5
- init : function(options) {
5
+ init: function (options) {
6
6
  var defaults = {
7
7
  indicators: true,
8
8
  height: 400,
@@ -11,7 +11,7 @@
11
11
  };
12
12
  options = $.extend(defaults, options);
13
13
 
14
- return this.each(function() {
14
+ return this.each(function () {
15
15
 
16
16
  // For each slider, we want to keep track of
17
17
  // which slide is active and its associated content
@@ -20,26 +20,25 @@
20
20
  var $slides = $slider.find('> li');
21
21
  var $active_index = $slider.find('.active').index();
22
22
  var $active, $indicators, $interval;
23
- if ($active_index != -1) { $active = $slides.eq($active_index); }
23
+ if ($active_index != -1) {
24
+ $active = $slides.eq($active_index);
25
+ }
24
26
 
25
27
  // Transitions the caption depending on alignment
26
28
  function captionTransition(caption, duration) {
27
29
  if (caption.hasClass("center-align")) {
28
- caption.velocity({opacity: 0, translateY: -100}, {duration: duration, queue: false});
29
- }
30
- else if (caption.hasClass("right-align")) {
31
- caption.velocity({opacity: 0, translateX: 100}, {duration: duration, queue: false});
32
- }
33
- else if (caption.hasClass("left-align")) {
34
- caption.velocity({opacity: 0, translateX: -100}, {duration: duration, queue: false});
30
+ caption.velocity({ opacity: 0, translateY: -100 }, { duration: duration, queue: false });
31
+ } else if (caption.hasClass("right-align")) {
32
+ caption.velocity({ opacity: 0, translateX: 100 }, { duration: duration, queue: false });
33
+ } else if (caption.hasClass("left-align")) {
34
+ caption.velocity({ opacity: 0, translateX: -100 }, { duration: duration, queue: false });
35
35
  }
36
36
  }
37
37
 
38
38
  // This function will transition the slide to any index of the next slide
39
39
  function moveToSlide(index) {
40
40
  // Wrap around indices.
41
- if (index >= $slides.length) index = 0;
42
- else if (index < 0) index = $slides.length -1;
41
+ if (index >= $slides.length) index = 0;else if (index < 0) index = $slides.length - 1;
43
42
 
44
43
  $active_index = $slider.find('.active').index();
45
44
 
@@ -49,23 +48,21 @@
49
48
  $caption = $active.find('.caption');
50
49
 
51
50
  $active.removeClass('active');
52
- $active.velocity({opacity: 0}, {duration: options.transition, queue: false, easing: 'easeOutQuad',
53
- complete: function() {
54
- $slides.not('.active').velocity({opacity: 0, translateX: 0, translateY: 0}, {duration: 0, queue: false});
55
- } });
51
+ $active.velocity({ opacity: 0 }, { duration: options.transition, queue: false, easing: 'easeOutQuad',
52
+ complete: function () {
53
+ $slides.not('.active').velocity({ opacity: 0, translateX: 0, translateY: 0 }, { duration: 0, queue: false });
54
+ } });
56
55
  captionTransition($caption, options.transition);
57
56
 
58
-
59
57
  // Update indicators
60
58
  if (options.indicators) {
61
59
  $indicators.eq($active_index).removeClass('active');
62
60
  }
63
61
 
64
- $slides.eq(index).velocity({opacity: 1}, {duration: options.transition, queue: false, easing: 'easeOutQuad'});
65
- $slides.eq(index).find('.caption').velocity({opacity: 1, translateX: 0, translateY: 0}, {duration: options.transition, delay: options.transition, queue: false, easing: 'easeOutQuad'});
62
+ $slides.eq(index).velocity({ opacity: 1 }, { duration: options.transition, queue: false, easing: 'easeOutQuad' });
63
+ $slides.eq(index).find('.caption').velocity({ opacity: 1, translateX: 0, translateY: 0 }, { duration: options.transition, delay: options.transition, queue: false, easing: 'easeOutQuad' });
66
64
  $slides.eq(index).addClass('active');
67
65
 
68
-
69
66
  // Update indicators
70
67
  if (options.indicators) {
71
68
  $indicators.eq(index).addClass('active');
@@ -79,14 +76,12 @@
79
76
  if (options.indicators) {
80
77
  // Add height if indicators are present
81
78
  $this.height(options.height + 40);
82
- }
83
- else {
79
+ } else {
84
80
  $this.height(options.height);
85
81
  }
86
82
  $slider.height(options.height);
87
83
  }
88
84
 
89
-
90
85
  // Set initial positions of captions
91
86
  $slides.find('.caption').each(function () {
92
87
  captionTransition($(this), 0);
@@ -96,7 +91,7 @@
96
91
  $slides.find('img').each(function () {
97
92
  var placeholderBase64 = '';
98
93
  if ($(this).attr('src') !== placeholderBase64) {
99
- $(this).css('background-image', 'url("' + $(this).attr('src') + '")' );
94
+ $(this).css('background-image', 'url("' + $(this).attr('src') + '")');
100
95
  $(this).attr('src', placeholderBase64);
101
96
  }
102
97
  });
@@ -104,7 +99,7 @@
104
99
  // dynamically add indicators
105
100
  if (options.indicators) {
106
101
  $indicators = $('<ul class="indicators"></ul>');
107
- $slides.each(function( index ) {
102
+ $slides.each(function (index) {
108
103
  var $indicator = $('<li class="indicator-item"></li>');
109
104
 
110
105
  // Handle clicks on indicators
@@ -115,16 +110,13 @@
115
110
 
116
111
  // reset interval
117
112
  clearInterval($interval);
118
- $interval = setInterval(
119
- function(){
120
- $active_index = $slider.find('.active').index();
121
- if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
122
- else $active_index += 1;
123
-
124
- moveToSlide($active_index);
113
+ $interval = setInterval(function () {
114
+ $active_index = $slider.find('.active').index();
115
+ if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
116
+ else $active_index += 1;
125
117
 
126
- }, options.transition + options.interval
127
- );
118
+ moveToSlide($active_index);
119
+ }, options.transition + options.interval);
128
120
  });
129
121
  $indicators.append($indicator);
130
122
  });
@@ -134,9 +126,8 @@
134
126
 
135
127
  if ($active) {
136
128
  $active.show();
137
- }
138
- else {
139
- $slides.first().addClass('active').velocity({opacity: 1}, {duration: options.transition, queue: false, easing: 'easeOutQuad'});
129
+ } else {
130
+ $slides.first().addClass('active').velocity({ opacity: 1 }, { duration: options.transition, queue: false, easing: 'easeOutQuad' });
140
131
 
141
132
  $active_index = 0;
142
133
  $active = $slides.eq($active_index);
@@ -148,19 +139,15 @@
148
139
  }
149
140
 
150
141
  // Adjust height to current slide
151
- $active.find('img').each(function() {
152
- $active.find('.caption').velocity({opacity: 1, translateX: 0, translateY: 0}, {duration: options.transition, queue: false, easing: 'easeOutQuad'});
142
+ $active.find('img').each(function () {
143
+ $active.find('.caption').velocity({ opacity: 1, translateX: 0, translateY: 0 }, { duration: options.transition, queue: false, easing: 'easeOutQuad' });
153
144
  });
154
145
 
155
146
  // auto scroll
156
- $interval = setInterval(
157
- function(){
158
- $active_index = $slider.find('.active').index();
159
- moveToSlide($active_index + 1);
160
-
161
- }, options.transition + options.interval
162
- );
163
-
147
+ $interval = setInterval(function () {
148
+ $active_index = $slider.find('.active').index();
149
+ moveToSlide($active_index + 1);
150
+ }, options.transition + options.interval);
164
151
 
165
152
  // HammerJS, Swipe navigation
166
153
 
@@ -170,8 +157,8 @@
170
157
  var swipeRight = false;
171
158
 
172
159
  $this.hammer({
173
- prevent_default: false
174
- }).on('pan', function(e) {
160
+ prevent_default: false
161
+ }).on('pan', function (e) {
175
162
  if (e.gesture.pointerType === "touch") {
176
163
 
177
164
  // reset interval
@@ -185,17 +172,17 @@
185
172
  $curr_slide = $slider.find('.active');
186
173
  if (Math.abs(velocityX) > Math.abs(velocityY)) {
187
174
  $curr_slide.velocity({ translateX: x
188
- }, {duration: 50, queue: false, easing: 'easeOutQuad'});
175
+ }, { duration: 50, queue: false, easing: 'easeOutQuad' });
189
176
  }
190
177
 
191
178
  // Swipe Left
192
- if (direction === 4 && (x > ($this.innerWidth() / 2) || velocityX < -0.65)) {
179
+ if (direction === 4 && (x > $this.innerWidth() / 2 || velocityX < -0.65)) {
193
180
  swipeRight = true;
194
181
  }
195
182
  // Swipe Right
196
- else if (direction === 2 && (x < (-1 * $this.innerWidth() / 2) || velocityX > 0.65)) {
197
- swipeLeft = true;
198
- }
183
+ else if (direction === 2 && (x < -1 * $this.innerWidth() / 2 || velocityX > 0.65)) {
184
+ swipeLeft = true;
185
+ }
199
186
 
200
187
  // Make Slide Behind active slide visible
201
188
  var next_slide;
@@ -205,7 +192,7 @@
205
192
  next_slide = $slides.first();
206
193
  }
207
194
  next_slide.velocity({ opacity: 1
208
- }, {duration: 300, queue: false, easing: 'easeOutQuad'});
195
+ }, { duration: 300, queue: false, easing: 'easeOutQuad' });
209
196
  }
210
197
  if (swipeRight) {
211
198
  next_slide = $curr_slide.prev();
@@ -213,112 +200,96 @@
213
200
  next_slide = $slides.last();
214
201
  }
215
202
  next_slide.velocity({ opacity: 1
216
- }, {duration: 300, queue: false, easing: 'easeOutQuad'});
203
+ }, { duration: 300, queue: false, easing: 'easeOutQuad' });
217
204
  }
218
-
219
-
220
205
  }
221
-
222
- }).on('panend', function(e) {
206
+ }).on('panend', function (e) {
223
207
  if (e.gesture.pointerType === "touch") {
224
208
 
225
209
  $curr_slide = $slider.find('.active');
226
210
  panning = false;
227
211
  curr_index = $slider.find('.active').index();
228
212
 
229
- if (!swipeRight && !swipeLeft || $slides.length <=1) {
213
+ if (!swipeRight && !swipeLeft || $slides.length <= 1) {
230
214
  // Return to original spot
231
215
  $curr_slide.velocity({ translateX: 0
232
- }, {duration: 300, queue: false, easing: 'easeOutQuad'});
233
- }
234
- else if (swipeLeft) {
216
+ }, { duration: 300, queue: false, easing: 'easeOutQuad' });
217
+ } else if (swipeLeft) {
235
218
  moveToSlide(curr_index + 1);
236
- $curr_slide.velocity({translateX: -1 * $this.innerWidth() }, {duration: 300, queue: false, easing: 'easeOutQuad',
237
- complete: function() {
238
- $curr_slide.velocity({opacity: 0, translateX: 0}, {duration: 0, queue: false});
239
- } });
240
- }
241
- else if (swipeRight) {
219
+ $curr_slide.velocity({ translateX: -1 * $this.innerWidth() }, { duration: 300, queue: false, easing: 'easeOutQuad',
220
+ complete: function () {
221
+ $curr_slide.velocity({ opacity: 0, translateX: 0 }, { duration: 0, queue: false });
222
+ } });
223
+ } else if (swipeRight) {
242
224
  moveToSlide(curr_index - 1);
243
- $curr_slide.velocity({translateX: $this.innerWidth() }, {duration: 300, queue: false, easing: 'easeOutQuad',
244
- complete: function() {
245
- $curr_slide.velocity({opacity: 0, translateX: 0}, {duration: 0, queue: false});
246
- } });
225
+ $curr_slide.velocity({ translateX: $this.innerWidth() }, { duration: 300, queue: false, easing: 'easeOutQuad',
226
+ complete: function () {
227
+ $curr_slide.velocity({ opacity: 0, translateX: 0 }, { duration: 0, queue: false });
228
+ } });
247
229
  }
248
230
  swipeLeft = false;
249
231
  swipeRight = false;
250
232
 
251
233
  // Restart interval
252
234
  clearInterval($interval);
253
- $interval = setInterval(
254
- function(){
255
- $active_index = $slider.find('.active').index();
256
- if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
257
- else $active_index += 1;
258
-
259
- moveToSlide($active_index);
235
+ $interval = setInterval(function () {
236
+ $active_index = $slider.find('.active').index();
237
+ if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
238
+ else $active_index += 1;
260
239
 
261
- }, options.transition + options.interval
262
- );
240
+ moveToSlide($active_index);
241
+ }, options.transition + options.interval);
263
242
  }
264
243
  });
265
244
 
266
- $this.on('sliderPause', function() {
245
+ $this.on('sliderPause', function () {
267
246
  clearInterval($interval);
268
247
  });
269
248
 
270
- $this.on('sliderStart', function() {
249
+ $this.on('sliderStart', function () {
271
250
  clearInterval($interval);
272
- $interval = setInterval(
273
- function(){
274
- $active_index = $slider.find('.active').index();
275
- if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
276
- else $active_index += 1;
277
-
278
- moveToSlide($active_index);
251
+ $interval = setInterval(function () {
252
+ $active_index = $slider.find('.active').index();
253
+ if ($slides.length == $active_index + 1) $active_index = 0; // loop to start
254
+ else $active_index += 1;
279
255
 
280
- }, options.transition + options.interval
281
- );
256
+ moveToSlide($active_index);
257
+ }, options.transition + options.interval);
282
258
  });
283
259
 
284
- $this.on('sliderNext', function() {
260
+ $this.on('sliderNext', function () {
285
261
  $active_index = $slider.find('.active').index();
286
262
  moveToSlide($active_index + 1);
287
263
  });
288
264
 
289
- $this.on('sliderPrev', function() {
265
+ $this.on('sliderPrev', function () {
290
266
  $active_index = $slider.find('.active').index();
291
267
  moveToSlide($active_index - 1);
292
268
  });
293
-
294
269
  });
295
-
296
-
297
-
298
270
  },
299
- pause : function() {
271
+ pause: function () {
300
272
  $(this).trigger('sliderPause');
301
273
  },
302
- start : function() {
274
+ start: function () {
303
275
  $(this).trigger('sliderStart');
304
276
  },
305
- next : function() {
277
+ next: function () {
306
278
  $(this).trigger('sliderNext');
307
279
  },
308
- prev : function() {
280
+ prev: function () {
309
281
  $(this).trigger('sliderPrev');
310
282
  }
311
283
  };
312
284
 
313
-
314
- $.fn.slider = function(methodOrOptions) {
315
- if ( methods[methodOrOptions] ) {
316
- return methods[ methodOrOptions ].apply( this, Array.prototype.slice.call( arguments, 1 ));
317
- } else if ( typeof methodOrOptions === 'object' || ! methodOrOptions ) {
285
+ $.fn.slider = function (methodOrOptions) {
286
+ if (methods[methodOrOptions]) {
287
+ return methods[methodOrOptions].apply(this, Array.prototype.slice.call(arguments, 1));
288
+ } else if (typeof methodOrOptions === 'object' || !methodOrOptions) {
318
289
  // Default to "init"
319
- return methods.init.apply( this, arguments );
290
+ return methods.init.apply(this, arguments);
320
291
  } else {
321
- $.error( 'Method ' + methodOrOptions + ' does not exist on jQuery.tooltip' );
292
+ $.error('Method ' + methodOrOptions + ' does not exist on jQuery.tooltip');
322
293
  }
323
294
  }; // Plugin end
324
- }( jQuery ));
295
+ })(jQuery);
@@ -1,243 +1,243 @@
1
1
  (function ($) {
2
2
 
3
3
  var methods = {
4
- init : function(options) {
4
+ init: function (options) {
5
5
  var defaults = {
6
6
  onShow: null,
7
7
  swipeable: false,
8
- responsiveThreshold: Infinity, // breakpoint for swipeable
8
+ responsiveThreshold: Infinity // breakpoint for swipeable
9
9
  };
10
10
  options = $.extend(defaults, options);
11
11
  var namespace = Materialize.objectSelectorString($(this));
12
12
 
13
- return this.each(function(i) {
14
-
15
- var uniqueNamespace = namespace+i;
16
-
17
- // For each set of tabs, we want to keep track of
18
- // which tab is active and its associated content
19
- var $this = $(this),
20
- window_width = $(window).width();
21
-
22
- var $active, $content, $links = $this.find('li.tab a'),
23
- $tabs_width = $this.width(),
24
- $tabs_content = $(),
25
- $tabs_wrapper,
26
- $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length,
27
- $indicator,
28
- index = prev_index = 0,
29
- clicked = false,
30
- clickedTimeout,
31
- transition = 300;
32
-
33
-
34
- // Finds right attribute for indicator based on active tab.
35
- // el: jQuery Object
36
- var calcRightPos = function(el) {
37
- return Math.ceil($tabs_width - el.position().left - el.outerWidth() - $this.scrollLeft());
38
- };
13
+ return this.each(function (i) {
14
+
15
+ var uniqueNamespace = namespace + i;
16
+
17
+ // For each set of tabs, we want to keep track of
18
+ // which tab is active and its associated content
19
+ var $this = $(this),
20
+ window_width = $(window).width();
21
+
22
+ var $active,
23
+ $content,
24
+ $links = $this.find('li.tab a'),
25
+ $tabs_width = $this.width(),
26
+ $tabs_content = $(),
27
+ $tabs_wrapper,
28
+ $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length,
29
+ $indicator,
30
+ index = prev_index = 0,
31
+ clicked = false,
32
+ clickedTimeout,
33
+ transition = 300;
34
+
35
+ // Finds right attribute for indicator based on active tab.
36
+ // el: jQuery Object
37
+ var calcRightPos = function (el) {
38
+ return Math.ceil($tabs_width - el.position().left - el[0].getBoundingClientRect().width - $this.scrollLeft());
39
+ };
40
+
41
+ // Finds left attribute for indicator based on active tab.
42
+ // el: jQuery Object
43
+ var calcLeftPos = function (el) {
44
+ return Math.floor(el.position().left + $this.scrollLeft());
45
+ };
46
+
47
+ // Animates Indicator to active tab.
48
+ // prev_index: Number
49
+ var animateIndicator = function (prev_index) {
50
+ if (index - prev_index >= 0) {
51
+ $indicator.velocity({ "right": calcRightPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad' });
52
+ $indicator.velocity({ "left": calcLeftPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad', delay: 90 });
53
+ } else {
54
+ $indicator.velocity({ "left": calcLeftPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad' });
55
+ $indicator.velocity({ "right": calcRightPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad', delay: 90 });
56
+ }
57
+ };
39
58
 
40
- // Finds left attribute for indicator based on active tab.
41
- // el: jQuery Object
42
- var calcLeftPos = function(el) {
43
- return Math.floor(el.position().left + $this.scrollLeft());
44
- };
59
+ // Change swipeable according to responsive threshold
60
+ if (options.swipeable) {
61
+ if (window_width > options.responsiveThreshold) {
62
+ options.swipeable = false;
63
+ }
64
+ }
45
65
 
46
- // Animates Indicator to active tab.
47
- // prev_index: Number
48
- var animateIndicator = function(prev_index) {
49
- if ((index - prev_index) >= 0) {
50
- $indicator.velocity({"right": calcRightPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad'});
51
- $indicator.velocity({"left": calcLeftPos($active) }, {duration: transition, queue: false, easing: 'easeOutQuad', delay: 90});
66
+ // If the location.hash matches one of the links, use that as the active tab.
67
+ $active = $($links.filter('[href="' + location.hash + '"]'));
52
68
 
53
- } else {
54
- $indicator.velocity({"left": calcLeftPos($active) }, { duration: transition, queue: false, easing: 'easeOutQuad'});
55
- $indicator.velocity({"right": calcRightPos($active) }, {duration: transition, queue: false, easing: 'easeOutQuad', delay: 90});
69
+ // If no match is found, use the first link or any with class 'active' as the initial active tab.
70
+ if ($active.length === 0) {
71
+ $active = $(this).find('li.tab a.active').first();
56
72
  }
57
- };
58
-
59
- // Change swipeable according to responsive threshold
60
- if (options.swipeable) {
61
- if (window_width > options.responsiveThreshold) {
62
- options.swipeable = false;
73
+ if ($active.length === 0) {
74
+ $active = $(this).find('li.tab a').first();
63
75
  }
64
- }
65
-
66
-
67
- // If the location.hash matches one of the links, use that as the active tab.
68
- $active = $($links.filter('[href="'+location.hash+'"]'));
69
-
70
- // If no match is found, use the first link or any with class 'active' as the initial active tab.
71
- if ($active.length === 0) {
72
- $active = $(this).find('li.tab a.active').first();
73
- }
74
- if ($active.length === 0) {
75
- $active = $(this).find('li.tab a').first();
76
- }
77
-
78
- $active.addClass('active');
79
- index = $links.index($active);
80
- if (index < 0) {
81
- index = 0;
82
- }
83
-
84
- if ($active[0] !== undefined) {
85
- $content = $($active[0].hash);
86
- $content.addClass('active');
87
- }
88
-
89
- // append indicator then set indicator width to tab width
90
- if (!$this.find('.indicator').length) {
91
- $this.append('<li class="indicator"></li>');
92
- }
93
- $indicator = $this.find('.indicator');
94
-
95
- // we make sure that the indicator is at the end of the tabs
96
- $this.append($indicator);
97
-
98
- if ($this.is(":visible")) {
99
- // $indicator.css({"right": $tabs_width - ((index + 1) * $tab_width)});
100
- // $indicator.css({"left": index * $tab_width});
101
- setTimeout(function() {
102
- $indicator.css({"right": calcRightPos($active) });
103
- $indicator.css({"left": calcLeftPos($active) });
104
- }, 0);
105
- }
106
- $(window).off('resize.tabs-'+uniqueNamespace).on('resize.tabs-'+uniqueNamespace, function () {
107
- $tabs_width = $this.width();
108
- $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length;
76
+
77
+ $active.addClass('active');
78
+ index = $links.index($active);
109
79
  if (index < 0) {
110
80
  index = 0;
111
81
  }
112
- if ($tab_width !== 0 && $tabs_width !== 0) {
113
- $indicator.css({"right": calcRightPos($active) });
114
- $indicator.css({"left": calcLeftPos($active) });
82
+
83
+ if ($active[0] !== undefined) {
84
+ $content = $($active[0].hash);
85
+ $content.addClass('active');
115
86
  }
116
- });
117
87
 
118
- // Initialize Tabs Content.
119
- if (options.swipeable) {
120
- // TODO: Duplicate calls with swipeable? handle multiple div wrapping.
121
- $links.each(function () {
122
- var $curr_content = $(Materialize.escapeHash(this.hash));
123
- $curr_content.addClass('carousel-item');
124
- $tabs_content = $tabs_content.add($curr_content);
88
+ // append indicator then set indicator width to tab width
89
+ if (!$this.find('.indicator').length) {
90
+ $this.append('<li class="indicator"></li>');
91
+ }
92
+ $indicator = $this.find('.indicator');
93
+
94
+ // we make sure that the indicator is at the end of the tabs
95
+ $this.append($indicator);
96
+
97
+ if ($this.is(":visible")) {
98
+ // $indicator.css({"right": $tabs_width - ((index + 1) * $tab_width)});
99
+ // $indicator.css({"left": index * $tab_width});
100
+ setTimeout(function () {
101
+ $indicator.css({ "right": calcRightPos($active) });
102
+ $indicator.css({ "left": calcLeftPos($active) });
103
+ }, 0);
104
+ }
105
+ $(window).off('resize.tabs-' + uniqueNamespace).on('resize.tabs-' + uniqueNamespace, function () {
106
+ $tabs_width = $this.width();
107
+ $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length;
108
+ if (index < 0) {
109
+ index = 0;
110
+ }
111
+ if ($tab_width !== 0 && $tabs_width !== 0) {
112
+ $indicator.css({ "right": calcRightPos($active) });
113
+ $indicator.css({ "left": calcLeftPos($active) });
114
+ }
125
115
  });
126
- $tabs_wrapper = $tabs_content.wrapAll('<div class="tabs-content carousel"></div>');
127
- $tabs_content.css('display', '');
128
- $('.tabs-content.carousel').carousel({
129
- fullWidth: true,
130
- noWrap: true,
131
- onCycleTo: function(item) {
132
- if (!clicked) {
133
- var prev_index = index;
134
- index = $tabs_wrapper.index(item);
135
- $active = $links.eq(index);
136
- animateIndicator(prev_index);
137
- if (typeof(options.onShow) === "function") {
138
- options.onShow.call($this[0], $content);
116
+
117
+ // Initialize Tabs Content.
118
+ if (options.swipeable) {
119
+ // TODO: Duplicate calls with swipeable? handle multiple div wrapping.
120
+ $links.each(function () {
121
+ var $curr_content = $(Materialize.escapeHash(this.hash));
122
+ $curr_content.addClass('carousel-item');
123
+ $tabs_content = $tabs_content.add($curr_content);
124
+ });
125
+ $tabs_wrapper = $tabs_content.wrapAll('<div class="tabs-content carousel"></div>');
126
+ $tabs_content.css('display', '');
127
+ $('.tabs-content.carousel').carousel({
128
+ fullWidth: true,
129
+ noWrap: true,
130
+ onCycleTo: function (item) {
131
+ if (!clicked) {
132
+ var prev_index = index;
133
+ index = $tabs_wrapper.index(item);
134
+ $active.removeClass('active');
135
+ $active = $links.eq(index);
136
+ $active.addClass('active');
137
+ animateIndicator(prev_index);
138
+ if (typeof options.onShow === "function") {
139
+ options.onShow.call($this[0], $content);
140
+ }
139
141
  }
140
142
  }
141
- },
142
- });
143
- } else {
144
- // Hide the remaining content
145
- $links.not($active).each(function () {
146
- $(Materialize.escapeHash(this.hash)).hide();
147
- });
148
- }
149
-
150
-
151
- // Bind the click event handler
152
- $this.off('click.tabs').on('click.tabs', 'a', function(e) {
153
- if ($(this).parent().hasClass('disabled')) {
154
- e.preventDefault();
155
- return;
156
- }
157
-
158
- // Act as regular link if target attribute is specified.
159
- if (!!$(this).attr("target")) {
160
- return;
143
+ });
144
+ } else {
145
+ // Hide the remaining content
146
+ $links.not($active).each(function () {
147
+ $(Materialize.escapeHash(this.hash)).hide();
148
+ });
161
149
  }
162
150
 
163
- clicked = true;
164
- $tabs_width = $this.width();
165
- $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length;
166
-
167
- // Make the old tab inactive.
168
- $active.removeClass('active');
169
- var $oldContent = $content
170
-
171
- // Update the variables with the new link and content
172
- $active = $(this);
173
- $content = $(Materialize.escapeHash(this.hash));
174
- $links = $this.find('li.tab a');
175
- var activeRect = $active.position();
151
+ // Bind the click event handler
152
+ $this.off('click.tabs').on('click.tabs', 'a', function (e) {
153
+ if ($(this).parent().hasClass('disabled')) {
154
+ e.preventDefault();
155
+ return;
156
+ }
176
157
 
177
- // Make the tab active.
178
- $active.addClass('active');
179
- prev_index = index;
180
- index = $links.index($(this));
181
- if (index < 0) {
182
- index = 0;
183
- }
184
- // Change url to current tab
185
- // window.location.hash = $active.attr('href');
158
+ // Act as regular link if target attribute is specified.
159
+ if (!!$(this).attr("target")) {
160
+ return;
161
+ }
186
162
 
187
- // Swap content
188
- if (options.swipeable) {
189
- if ($tabs_content.length) {
190
- $tabs_content.carousel('set', index, function() {
191
- if (typeof(options.onShow) === "function") {
192
- options.onShow.call($this[0], $content);
193
- }
194
- });
163
+ clicked = true;
164
+ $tabs_width = $this.width();
165
+ $tab_width = Math.max($tabs_width, $this[0].scrollWidth) / $links.length;
166
+
167
+ // Make the old tab inactive.
168
+ $active.removeClass('active');
169
+ var $oldContent = $content;
170
+
171
+ // Update the variables with the new link and content
172
+ $active = $(this);
173
+ $content = $(Materialize.escapeHash(this.hash));
174
+ $links = $this.find('li.tab a');
175
+ var activeRect = $active.position();
176
+
177
+ // Make the tab active.
178
+ $active.addClass('active');
179
+ prev_index = index;
180
+ index = $links.index($(this));
181
+ if (index < 0) {
182
+ index = 0;
195
183
  }
196
- } else {
197
- if ($content !== undefined) {
198
- $content.show();
199
- $content.addClass('active');
200
- if (typeof(options.onShow) === "function") {
201
- options.onShow.call(this, $content);
184
+ // Change url to current tab
185
+ // window.location.hash = $active.attr('href');
186
+
187
+ // Swap content
188
+ if (options.swipeable) {
189
+ if ($tabs_content.length) {
190
+ $tabs_content.carousel('set', index, function () {
191
+ if (typeof options.onShow === "function") {
192
+ options.onShow.call($this[0], $content);
193
+ }
194
+ });
195
+ }
196
+ } else {
197
+ if ($content !== undefined) {
198
+ $content.show();
199
+ $content.addClass('active');
200
+ if (typeof options.onShow === "function") {
201
+ options.onShow.call(this, $content);
202
+ }
202
203
  }
203
- }
204
204
 
205
- if ($oldContent !== undefined &&
206
- !$oldContent.is($content)) {
207
- $oldContent.hide();
208
- $oldContent.removeClass('active');
205
+ if ($oldContent !== undefined && !$oldContent.is($content)) {
206
+ $oldContent.hide();
207
+ $oldContent.removeClass('active');
208
+ }
209
209
  }
210
- }
211
210
 
212
- // Reset clicked state
213
- clickedTimeout = setTimeout(function(){ clicked = false; }, transition);
211
+ // Reset clicked state
212
+ clickedTimeout = setTimeout(function () {
213
+ clicked = false;
214
+ }, transition);
214
215
 
215
- // Update indicator
216
- animateIndicator(prev_index);
216
+ // Update indicator
217
+ animateIndicator(prev_index);
217
218
 
218
- // Prevent the anchor's default click action
219
- e.preventDefault();
219
+ // Prevent the anchor's default click action
220
+ e.preventDefault();
221
+ });
220
222
  });
221
- });
222
-
223
223
  },
224
- select_tab : function( id ) {
224
+ select_tab: function (id) {
225
225
  this.find('a[href="#' + id + '"]').trigger('click');
226
226
  }
227
227
  };
228
228
 
229
- $.fn.tabs = function(methodOrOptions) {
230
- if ( methods[methodOrOptions] ) {
231
- return methods[ methodOrOptions ].apply( this, Array.prototype.slice.call( arguments, 1 ));
232
- } else if ( typeof methodOrOptions === 'object' || ! methodOrOptions ) {
229
+ $.fn.tabs = function (methodOrOptions) {
230
+ if (methods[methodOrOptions]) {
231
+ return methods[methodOrOptions].apply(this, Array.prototype.slice.call(arguments, 1));
232
+ } else if (typeof methodOrOptions === 'object' || !methodOrOptions) {
233
233
  // Default to "init"
234
- return methods.init.apply( this, arguments );
234
+ return methods.init.apply(this, arguments);
235
235
  } else {
236
- $.error( 'Method ' + methodOrOptions + ' does not exist on jQuery.tabs' );
236
+ $.error('Method ' + methodOrOptions + ' does not exist on jQuery.tabs');
237
237
  }
238
238
  };
239
239
 
240
- $(document).on('ready turbolinks:load', function(){
240
+ $(document).on('ready turbolinks:load', function () {
241
241
  $('ul.tabs').tabs();
242
242
  });
243
- }( jQuery ));
243
+ })(jQuery);