materialize-sass 1.0.0.alpha4 → 1.0.0.beta

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d663fb262bda28a9d3a301ff8b967e730b79d54befd25c33ee449c914a5209c5
4
- data.tar.gz: 46a85c9259899296f1d0a55ee55cce924ebe3488b467b61e1ba677abbc481cde
3
+ metadata.gz: 4755204505bc3a5591234d26b238680d84484c3f938769b3f91facb5a5d07271
4
+ data.tar.gz: 9d78d633753c4a7dc26a2f263de490b25eae9219e00612bd27d9dd96c1230641
5
5
  SHA512:
6
- metadata.gz: 5f9201a2252c0d1be8a9c886f64219ea53594a9c26c03bc542bb979c4108c9775794c6a8a4280d052faea073ff7c1c9d5a9a9a5a352afa5f183213dc3386e7ed
7
- data.tar.gz: 661af14ace10a0779f7acdc0ed2c85e47e90d4713092aeaa837c80d9a9b9c5c37242940fab83234609b6a2277423c4c1f01f34031eee9c0ade6e2c745e32b643
6
+ metadata.gz: 2bce13964ed4bc9135583c28101ca1f1b97982a7bb1453bdcb9e056cc8bc4d69c32f28da44060387af99cfef922e536635b913e3d900b183be2258233284ceee
7
+ data.tar.gz: 455515535558551160a31c826d2fdec6c768b50ff59ee59cfc8e928d3eeb2ebeb17ac263d2f1eac739e61bea5f8e3ad73f9cace339b11344df1cbf1b9ee938a1
data/README.md CHANGED
@@ -7,7 +7,7 @@ example: http://materialize.labs.my/
7
7
  source: https://github.com/mkhairi/materialize-rails
8
8
 
9
9
  # Notices
10
- This master branch now v1.0.0.alpha4
10
+ This master branch now v1.0.0.beta
11
11
 
12
12
  Documentation for previous releases (v0.100.*) are available [this branch.](https://github.com/mkhairi/materialize-sass/tree/v0.100)
13
13
 
@@ -16,7 +16,7 @@ Documentation for previous releases (v0.100.*) are available [this branch.](http
16
16
  In your Gemfile you need to add the `materialize-sass` gem:
17
17
 
18
18
  ```ruby
19
- gem 'materialize-sass', '~> 1.0.0.alpha4'
19
+ gem 'materialize-sass', '~> 1.0.0.beta'
20
20
  ```
21
21
 
22
22
 
@@ -53,7 +53,7 @@ $ rm app/assets/stylesheets/application.css
53
53
  Since materialize color scheme are declared in color.scss you should import the color.scss first. then you can override color variable just like this:
54
54
 
55
55
  ```scss
56
- @import "materialize/components/color";
56
+ @import "materialize/components/color-variables";
57
57
  $primary-color: color("blue", "lighten-2") !default;
58
58
  $secondary-color: color("yellow", "base") !default;
59
59
  @import 'materialize';
data/Rakefile CHANGED
@@ -32,8 +32,7 @@ namespace :javascripts do
32
32
  task :turbolinks_init do
33
33
  files = Dir.glob('assets/javascripts/materialize/**/*.js').reject { |file| file.end_with?(".min.js") and File.file?(file) }
34
34
  files.each do |file|
35
- selected_files = %w(buttons.js cards.js character_counter.js chips.js collapsible.js
36
- dropdown.js forms.js materialbox.js scrollspy.js tabs.js tooltip.js transitions.js)
35
+ selected_files = %w(forms.js chips.js)
37
36
  file_name = File.basename file
38
37
  #only selected file
39
38
  if selected_files.include?(file_name)
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * Materialize v1.0.0-alpha.4 (http://materializecss.com)
2
+ * Materialize v1.0.0-beta (http://materializecss.com)
3
3
  * Copyright 2014-2017 Materialize
4
4
  * MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE)
5
5
  */
@@ -1144,6 +1144,41 @@ M.initializeJqueryWrapper = function (plugin, pluginName, classRef) {
1144
1144
  };
1145
1145
  };
1146
1146
 
1147
+ /**
1148
+ * Automatically initialize components
1149
+ * @param {Element} context DOM Element to search within for components
1150
+ */
1151
+ M.AutoInit = function (context) {
1152
+ // Use document.body if no context is given
1153
+ var root = !!context ? context : document.body;
1154
+
1155
+ var registry = {
1156
+ Autocomplete: root.querySelectorAll('.autocomplete:not(.no-autoinit)'),
1157
+ Carousel: root.querySelectorAll('.carousel:not(.no-autoinit)'),
1158
+ Chips: root.querySelectorAll('.chips:not(.no-autoinit)'),
1159
+ Collapsible: root.querySelectorAll('.collapsible:not(.no-autoinit)'),
1160
+ Datepicker: root.querySelectorAll('.datepicker:not(.no-autoinit)'),
1161
+ Dropdown: root.querySelectorAll('.dropdown-trigger:not(.no-autoinit)'),
1162
+ Materialbox: root.querySelectorAll('.materialboxed:not(.no-autoinit)'),
1163
+ Modal: root.querySelectorAll('.modal:not(.no-autoinit)'),
1164
+ Parallax: root.querySelectorAll('.parallax:not(.no-autoinit)'),
1165
+ Pushpin: root.querySelectorAll('.pushpin:not(.no-autoinit)'),
1166
+ ScrollSpy: root.querySelectorAll('.scrollspy:not(.no-autoinit)'),
1167
+ FormSelect: root.querySelectorAll('select:not(.no-autoinit)'),
1168
+ Sidenav: root.querySelectorAll('.sidenav:not(.no-autoinit)'),
1169
+ Tabs: root.querySelectorAll('.tabs:not(.no-autoinit)'),
1170
+ TapTarget: root.querySelectorAll('.tap-target:not(.no-autoinit)'),
1171
+ Timepicker: root.querySelectorAll('.timepicker:not(.no-autoinit)'),
1172
+ Tooltip: root.querySelectorAll('.tooltipped:not(.no-autoinit)'),
1173
+ FloatingActionButton: root.querySelectorAll('.fixed-action-btn:not(.no-autoinit)')
1174
+ };
1175
+
1176
+ for (var pluginName in registry) {
1177
+ var plugin = M[pluginName];
1178
+ plugin.init(registry[pluginName]);
1179
+ }
1180
+ };
1181
+
1147
1182
  /**
1148
1183
  * Generate approximated selector string for a jQuery object
1149
1184
  * @param {jQuery} obj jQuery object to be parsed
@@ -1878,6 +1913,10 @@ $jscomp.polyfill = function (e, r, p, m) {
1878
1913
  */
1879
1914
  _this3.options = $.extend({}, Collapsible.defaults, options);
1880
1915
 
1916
+ // Setup tab indices
1917
+ _this3.$headers = _this3.$el.children('li').children('.collapsible-header');
1918
+ _this3.$headers.attr('tabindex', 0);
1919
+
1881
1920
  _this3._setupEventHandlers();
1882
1921
 
1883
1922
  // Open first active
@@ -1911,8 +1950,14 @@ $jscomp.polyfill = function (e, r, p, m) {
1911
1950
  }, {
1912
1951
  key: "_setupEventHandlers",
1913
1952
  value: function _setupEventHandlers() {
1953
+ var _this4 = this;
1954
+
1914
1955
  this._handleCollapsibleClickBound = this._handleCollapsibleClick.bind(this);
1956
+ this._handleCollapsibleKeydownBound = this._handleCollapsibleKeydown.bind(this);
1915
1957
  this.el.addEventListener('click', this._handleCollapsibleClickBound);
1958
+ this.$headers.each(function (header) {
1959
+ header.addEventListener('keydown', _this4._handleCollapsibleKeydownBound);
1960
+ });
1916
1961
  }
1917
1962
 
1918
1963
  /**
@@ -1951,6 +1996,19 @@ $jscomp.polyfill = function (e, r, p, m) {
1951
1996
  }
1952
1997
  }
1953
1998
 
1999
+ /**
2000
+ * Handle Collapsible Keydown
2001
+ * @param {Event} e
2002
+ */
2003
+
2004
+ }, {
2005
+ key: "_handleCollapsibleKeydown",
2006
+ value: function _handleCollapsibleKeydown(e) {
2007
+ if (e.keyCode === 13) {
2008
+ this._handleCollapsibleClickBound(e);
2009
+ }
2010
+ }
2011
+
1954
2012
  /**
1955
2013
  * Animate in collapsible slide
1956
2014
  * @param {Number} index - 0th index of slide
@@ -1959,7 +2017,7 @@ $jscomp.polyfill = function (e, r, p, m) {
1959
2017
  }, {
1960
2018
  key: "_animateIn",
1961
2019
  value: function _animateIn(index) {
1962
- var _this4 = this;
2020
+ var _this5 = this;
1963
2021
 
1964
2022
  var $collapsibleLi = this.$el.children('li').eq(index);
1965
2023
  if ($collapsibleLi.length) {
@@ -1998,8 +2056,8 @@ $jscomp.polyfill = function (e, r, p, m) {
1998
2056
  });
1999
2057
 
2000
2058
  // onOpenEnd callback
2001
- if (typeof _this4.options.onOpenEnd === 'function') {
2002
- _this4.options.onOpenEnd.call(_this4, $collapsibleLi[0]);
2059
+ if (typeof _this5.options.onOpenEnd === 'function') {
2060
+ _this5.options.onOpenEnd.call(_this5, $collapsibleLi[0]);
2003
2061
  }
2004
2062
  }
2005
2063
  });
@@ -2014,7 +2072,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2014
2072
  }, {
2015
2073
  key: "_animateOut",
2016
2074
  value: function _animateOut(index) {
2017
- var _this5 = this;
2075
+ var _this6 = this;
2018
2076
 
2019
2077
  var $collapsibleLi = this.$el.children('li').eq(index);
2020
2078
  if ($collapsibleLi.length) {
@@ -2037,8 +2095,8 @@ $jscomp.polyfill = function (e, r, p, m) {
2037
2095
  });
2038
2096
 
2039
2097
  // onCloseEnd callback
2040
- if (typeof _this5.options.onCloseEnd === 'function') {
2041
- _this5.options.onCloseEnd.call(_this5, $collapsibleLi[0]);
2098
+ if (typeof _this6.options.onCloseEnd === 'function') {
2099
+ _this6.options.onCloseEnd.call(_this6, $collapsibleLi[0]);
2042
2100
  }
2043
2101
  }
2044
2102
  });
@@ -2053,7 +2111,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2053
2111
  }, {
2054
2112
  key: "open",
2055
2113
  value: function open(index) {
2056
- var _this6 = this;
2114
+ var _this7 = this;
2057
2115
 
2058
2116
  var $collapsibleLi = this.$el.children('li').eq(index);
2059
2117
  if ($collapsibleLi.length && !$collapsibleLi[0].classList.contains('active')) {
@@ -2069,7 +2127,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2069
2127
  var $activeLis = this.$el.children('li.active');
2070
2128
  $activeLis.each(function (el) {
2071
2129
  var index = $collapsibleLis.index($(el));
2072
- _this6.close(index);
2130
+ _this7.close(index);
2073
2131
  });
2074
2132
  }
2075
2133
 
@@ -2137,6 +2195,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2137
2195
 
2138
2196
  var _defaults = {
2139
2197
  alignment: 'left',
2198
+ autoFocus: true,
2140
2199
  constrainWidth: true,
2141
2200
  container: null,
2142
2201
  coverTrigger: true,
@@ -2160,19 +2219,20 @@ $jscomp.polyfill = function (e, r, p, m) {
2160
2219
  function Dropdown(el, options) {
2161
2220
  _classCallCheck(this, Dropdown);
2162
2221
 
2163
- var _this7 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options));
2222
+ var _this8 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options));
2164
2223
 
2165
- _this7.el.M_Dropdown = _this7;
2166
- Dropdown._dropdowns.push(_this7);
2224
+ _this8.el.M_Dropdown = _this8;
2225
+ Dropdown._dropdowns.push(_this8);
2167
2226
 
2168
- _this7.id = M.getIdFromTrigger(el);
2169
- _this7.dropdownEl = document.getElementById(_this7.id);
2170
- _this7.$dropdownEl = $(_this7.dropdownEl);
2227
+ _this8.id = M.getIdFromTrigger(el);
2228
+ _this8.dropdownEl = document.getElementById(_this8.id);
2229
+ _this8.$dropdownEl = $(_this8.dropdownEl);
2171
2230
 
2172
2231
  /**
2173
2232
  * Options for the dropdown
2174
2233
  * @member Dropdown#options
2175
2234
  * @prop {String} [alignment='left'] - Edge which the dropdown is aligned to
2235
+ * @prop {Boolean} [autoFocus=true] - Automatically focus dropdown el for keyboard
2176
2236
  * @prop {Boolean} [constrainWidth=true] - Constrain width to width of the button
2177
2237
  * @prop {Element} container - Container element to attach dropdown to (optional)
2178
2238
  * @prop {Boolean} [coverTrigger=true] - Place dropdown over trigger
@@ -2185,31 +2245,44 @@ $jscomp.polyfill = function (e, r, p, m) {
2185
2245
  * @prop {Function} onCloseStart - Function called when dropdown starts closing
2186
2246
  * @prop {Function} onCloseEnd - Function called when dropdown finishes closing
2187
2247
  */
2188
- _this7.options = $.extend({}, Dropdown.defaults, options);
2248
+ _this8.options = $.extend({}, Dropdown.defaults, options);
2189
2249
 
2190
2250
  /**
2191
2251
  * Describes open/close state of dropdown
2192
2252
  * @type {Boolean}
2193
2253
  */
2194
- _this7.isOpen = false;
2254
+ _this8.isOpen = false;
2195
2255
 
2196
- _this7.focusedIndex = -1;
2197
- _this7.filterQuery = [];
2256
+ /**
2257
+ * Describes if dropdown content is scrollable
2258
+ * @type {Boolean}
2259
+ */
2260
+ _this8.isScrollable = false;
2261
+
2262
+ /**
2263
+ * Describes if touch moving on dropdown content
2264
+ * @type {Boolean}
2265
+ */
2266
+ _this8.isTouchMoving = false;
2267
+
2268
+ _this8.focusedIndex = -1;
2269
+ _this8.filterQuery = [];
2198
2270
 
2199
2271
  // Move dropdown-content after dropdown-trigger
2200
- if (!!_this7.options.container) {
2201
- $(_this7.options.container).append(_this7.dropdownEl);
2272
+ if (!!_this8.options.container) {
2273
+ $(_this8.options.container).append(_this8.dropdownEl);
2202
2274
  } else {
2203
- _this7.$el.after(_this7.dropdownEl);
2275
+ _this8.$el.after(_this8.dropdownEl);
2204
2276
  }
2205
2277
 
2206
- _this7._makeDropdownFocusable();
2207
- _this7._resetFilterQueryBound = _this7._resetFilterQuery.bind(_this7);
2208
- _this7._handleDocumentClickBound = _this7._handleDocumentClick.bind(_this7);
2209
- _this7._handleDropdownKeydownBound = _this7._handleDropdownKeydown.bind(_this7);
2210
- _this7._handleTriggerKeydownBound = _this7._handleTriggerKeydown.bind(_this7);
2211
- _this7._setupEventHandlers();
2212
- return _this7;
2278
+ _this8._makeDropdownFocusable();
2279
+ _this8._resetFilterQueryBound = _this8._resetFilterQuery.bind(_this8);
2280
+ _this8._handleDocumentClickBound = _this8._handleDocumentClick.bind(_this8);
2281
+ _this8._handleDocumentTouchmoveBound = _this8._handleDocumentTouchmove.bind(_this8);
2282
+ _this8._handleDropdownKeydownBound = _this8._handleDropdownKeydown.bind(_this8);
2283
+ _this8._handleTriggerKeydownBound = _this8._handleTriggerKeydown.bind(_this8);
2284
+ _this8._setupEventHandlers();
2285
+ return _this8;
2213
2286
  }
2214
2287
 
2215
2288
  _createClass(Dropdown, [{
@@ -2275,6 +2348,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2275
2348
  // Use capture phase event handler to prevent click
2276
2349
  document.body.addEventListener('click', this._handleDocumentClickBound, true);
2277
2350
  document.body.addEventListener('touchend', this._handleDocumentClickBound);
2351
+ document.body.addEventListener('touchmove', this._handleDocumentTouchmoveBound);
2278
2352
  this.dropdownEl.addEventListener('keydown', this._handleDropdownKeydownBound);
2279
2353
  }
2280
2354
  }, {
@@ -2283,6 +2357,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2283
2357
  // Use capture phase event handler to prevent click
2284
2358
  document.body.removeEventListener('click', this._handleDocumentClickBound, true);
2285
2359
  document.body.removeEventListener('touchend', this._handleDocumentClickBound);
2360
+ document.body.removeEventListener('touchmove', this._handleDocumentTouchmoveBound);
2286
2361
  this.dropdownEl.removeEventListener('keydown', this._handleDropdownKeydownBound);
2287
2362
  }
2288
2363
  }, {
@@ -2316,18 +2391,20 @@ $jscomp.polyfill = function (e, r, p, m) {
2316
2391
  }, {
2317
2392
  key: "_handleDocumentClick",
2318
2393
  value: function _handleDocumentClick(e) {
2319
- var _this8 = this;
2394
+ var _this9 = this;
2320
2395
 
2321
2396
  var $target = $(e.target);
2322
- if (this.options.closeOnClick && $target.closest('.dropdown-content').length) {
2397
+ if (this.options.closeOnClick && $target.closest('.dropdown-content').length && !this.isTouchMoving) {
2398
+ // isTouchMoving to check if scrolling on mobile.
2323
2399
  setTimeout(function () {
2324
- _this8.close();
2400
+ _this9.close();
2325
2401
  }, 0);
2326
2402
  } else if ($target.closest('.dropdown-trigger').length || !$target.closest('.dropdown-content').length) {
2327
2403
  setTimeout(function () {
2328
- _this8.close();
2404
+ _this9.close();
2329
2405
  }, 0);
2330
2406
  }
2407
+ this.isTouchMoving = false;
2331
2408
  }
2332
2409
  }, {
2333
2410
  key: "_handleTriggerKeydown",
@@ -2339,6 +2416,20 @@ $jscomp.polyfill = function (e, r, p, m) {
2339
2416
  }
2340
2417
  }
2341
2418
 
2419
+ /**
2420
+ * Handle Document Touchmove
2421
+ * @param {Event} e
2422
+ */
2423
+
2424
+ }, {
2425
+ key: "_handleDocumentTouchmove",
2426
+ value: function _handleDocumentTouchmove(e) {
2427
+ var $target = $(e.target);
2428
+ if ($target.closest('.dropdown-content').length) {
2429
+ this.isTouchMoving = true;
2430
+ }
2431
+ }
2432
+
2342
2433
  /**
2343
2434
  * Handle Dropdown Keydown
2344
2435
  * @param {Event} e
@@ -2355,8 +2446,21 @@ $jscomp.polyfill = function (e, r, p, m) {
2355
2446
  } else if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) && this.isOpen) {
2356
2447
  e.preventDefault();
2357
2448
  var direction = e.which === M.keys.ARROW_DOWN ? 1 : -1;
2358
- this.focusedIndex = Math.max(Math.min(this.focusedIndex + direction, this.dropdownEl.children.length - 1), 0);
2359
- this._focusFocusedItem();
2449
+ var newFocusedIndex = this.focusedIndex;
2450
+ var foundNewIndex = false;
2451
+ do {
2452
+ newFocusedIndex = newFocusedIndex + direction;
2453
+
2454
+ if (!!this.dropdownEl.children[newFocusedIndex] && this.dropdownEl.children[newFocusedIndex].tabIndex !== -1) {
2455
+ foundNewIndex = true;
2456
+ break;
2457
+ }
2458
+ } while (newFocusedIndex < this.dropdownEl.children.length && newFocusedIndex >= 0);
2459
+
2460
+ if (foundNewIndex) {
2461
+ this.focusedIndex = newFocusedIndex;
2462
+ this._focusFocusedItem();
2463
+ }
2360
2464
 
2361
2465
  // ENTER selects choice on focused item
2362
2466
  } else if (e.which === M.keys.ENTER && this.isOpen) {
@@ -2419,16 +2523,20 @@ $jscomp.polyfill = function (e, r, p, m) {
2419
2523
  }, {
2420
2524
  key: "_makeDropdownFocusable",
2421
2525
  value: function _makeDropdownFocusable() {
2422
- if (this.dropdownEl.tabIndex === -1) {
2423
- this.dropdownEl.tabIndex = 0;
2424
- }
2526
+ // Needed for arrow key navigation
2527
+ this.dropdownEl.tabIndex = 0;
2425
2528
 
2426
- $(this.dropdownEl).children().attr('tabindex', 0);
2529
+ // Only set tabindex if it hasn't been set by user
2530
+ $(this.dropdownEl).children().each(function (el) {
2531
+ if (!el.getAttribute('tabindex')) {
2532
+ el.setAttribute('tabindex', 0);
2533
+ }
2534
+ });
2427
2535
  }
2428
2536
  }, {
2429
2537
  key: "_focusFocusedItem",
2430
2538
  value: function _focusFocusedItem() {
2431
- if (this.focusedIndex >= 0 && this.focusedIndex < this.dropdownEl.children.length) {
2539
+ if (this.focusedIndex >= 0 && this.focusedIndex < this.dropdownEl.children.length && this.options.autoFocus) {
2432
2540
  this.dropdownEl.children[this.focusedIndex].focus();
2433
2541
  }
2434
2542
  }
@@ -2458,10 +2566,16 @@ $jscomp.polyfill = function (e, r, p, m) {
2458
2566
  var verticalAlignment = 'top';
2459
2567
  var horizontalAlignment = this.options.alignment;
2460
2568
  idealYPos += this.options.coverTrigger ? 0 : triggerBRect.height;
2569
+
2570
+ // Reset isScrollable
2571
+ this.isScrollable = false;
2572
+
2461
2573
  if (!alignments.top) {
2462
2574
  if (alignments.bottom) {
2463
2575
  verticalAlignment = 'bottom';
2464
2576
  } else {
2577
+ this.isScrollable = true;
2578
+
2465
2579
  // Determine which side has most space and cutoff at correct height
2466
2580
  if (alignments.spaceOnTop > alignments.spaceOnBottom) {
2467
2581
  verticalAlignment = 'bottom';
@@ -2513,15 +2627,8 @@ $jscomp.polyfill = function (e, r, p, m) {
2513
2627
 
2514
2628
  }, {
2515
2629
  key: "_animateIn",
2516
- value: function _animateIn(positionInfo) {
2517
- var _this9 = this;
2518
-
2519
- // Place dropdown
2520
- this.dropdownEl.style.left = positionInfo.x + 'px';
2521
- this.dropdownEl.style.top = positionInfo.y + 'px';
2522
- this.dropdownEl.style.height = positionInfo.height + 'px';
2523
- this.dropdownEl.style.width = positionInfo.width + 'px';
2524
- this.dropdownEl.style.transformOrigin = (positionInfo.horizontalAlignment === 'left' ? '0' : '100%') + " " + (positionInfo.verticalAlignment === 'top' ? '0' : '100%');
2630
+ value: function _animateIn() {
2631
+ var _this10 = this;
2525
2632
 
2526
2633
  anim.remove(this.dropdownEl);
2527
2634
  anim({
@@ -2535,12 +2642,14 @@ $jscomp.polyfill = function (e, r, p, m) {
2535
2642
  duration: this.options.inDuration,
2536
2643
  easing: 'easeOutQuint',
2537
2644
  complete: function (anim) {
2538
- _this9.dropdownEl.focus();
2645
+ if (_this10.options.autoFocus) {
2646
+ _this10.dropdownEl.focus();
2647
+ }
2539
2648
 
2540
2649
  // onOpenEnd callback
2541
- if (typeof _this9.options.onOpenEnd === 'function') {
2650
+ if (typeof _this10.options.onOpenEnd === 'function') {
2542
2651
  var elem = anim.animatables[0].target;
2543
- _this9.options.onOpenEnd.call(elem, _this9.el);
2652
+ _this10.options.onOpenEnd.call(elem, _this10.el);
2544
2653
  }
2545
2654
  }
2546
2655
  });
@@ -2553,7 +2662,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2553
2662
  }, {
2554
2663
  key: "_animateOut",
2555
2664
  value: function _animateOut() {
2556
- var _this10 = this;
2665
+ var _this11 = this;
2557
2666
 
2558
2667
  anim.remove(this.dropdownEl);
2559
2668
  anim({
@@ -2567,17 +2676,36 @@ $jscomp.polyfill = function (e, r, p, m) {
2567
2676
  duration: this.options.outDuration,
2568
2677
  easing: 'easeOutQuint',
2569
2678
  complete: function (anim) {
2570
- _this10._resetDropdownStyles();
2679
+ _this11._resetDropdownStyles();
2571
2680
 
2572
2681
  // onCloseEnd callback
2573
- if (typeof _this10.options.onCloseEnd === 'function') {
2682
+ if (typeof _this11.options.onCloseEnd === 'function') {
2574
2683
  var elem = anim.animatables[0].target;
2575
- _this10.options.onCloseEnd.call(_this10, _this10.el);
2684
+ _this11.options.onCloseEnd.call(_this11, _this11.el);
2576
2685
  }
2577
2686
  }
2578
2687
  });
2579
2688
  }
2580
2689
 
2690
+ /**
2691
+ * Place dropdown
2692
+ */
2693
+
2694
+ }, {
2695
+ key: "_placeDropdown",
2696
+ value: function _placeDropdown() {
2697
+ // Set width before calculating positionInfo
2698
+ var idealWidth = this.options.constrainWidth ? this.el.getBoundingClientRect().width : this.dropdownEl.getBoundingClientRect().width;
2699
+ this.dropdownEl.style.width = idealWidth + 'px';
2700
+
2701
+ var positionInfo = this._getDropdownPosition();
2702
+ this.dropdownEl.style.left = positionInfo.x + 'px';
2703
+ this.dropdownEl.style.top = positionInfo.y + 'px';
2704
+ this.dropdownEl.style.height = positionInfo.height + 'px';
2705
+ this.dropdownEl.style.width = positionInfo.width + 'px';
2706
+ this.dropdownEl.style.transformOrigin = (positionInfo.horizontalAlignment === 'left' ? '0' : '100%') + " " + (positionInfo.verticalAlignment === 'top' ? '0' : '100%');
2707
+ }
2708
+
2581
2709
  /**
2582
2710
  * Open Dropdown
2583
2711
  */
@@ -2599,12 +2727,8 @@ $jscomp.polyfill = function (e, r, p, m) {
2599
2727
  this._resetDropdownStyles();
2600
2728
  this.dropdownEl.style.display = 'block';
2601
2729
 
2602
- // Set width before calculating positionInfo
2603
- var idealWidth = this.options.constrainWidth ? this.el.getBoundingClientRect().width : this.dropdownEl.getBoundingClientRect().width;
2604
- this.dropdownEl.style.width = idealWidth + 'px';
2605
-
2606
- var positionInfo = this._getDropdownPosition();
2607
- this._animateIn(positionInfo);
2730
+ this._placeDropdown();
2731
+ this._animateIn();
2608
2732
  this._setupTemporaryEventHandlers();
2609
2733
  }
2610
2734
 
@@ -2628,7 +2752,29 @@ $jscomp.polyfill = function (e, r, p, m) {
2628
2752
 
2629
2753
  this._animateOut();
2630
2754
  this._removeTemporaryEventHandlers();
2631
- this.el.focus();
2755
+
2756
+ if (this.options.autoFocus) {
2757
+ this.el.focus();
2758
+ }
2759
+ }
2760
+
2761
+ /**
2762
+ * Recalculate dimensions
2763
+ */
2764
+
2765
+ }, {
2766
+ key: "recalculateDimensions",
2767
+ value: function recalculateDimensions() {
2768
+ if (this.isOpen) {
2769
+ this.$dropdownEl.css({
2770
+ width: '',
2771
+ height: '',
2772
+ left: '',
2773
+ top: '',
2774
+ 'transform-origin': ''
2775
+ });
2776
+ this._placeDropdown();
2777
+ }
2632
2778
  }
2633
2779
  }], [{
2634
2780
  key: "init",
@@ -2681,6 +2827,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2681
2827
  onOpenEnd: null,
2682
2828
  onCloseStart: null,
2683
2829
  onCloseEnd: null,
2830
+ preventScrolling: true,
2684
2831
  dismissible: true,
2685
2832
  startingTop: '4%',
2686
2833
  endingTop: '10%'
@@ -2703,9 +2850,9 @@ $jscomp.polyfill = function (e, r, p, m) {
2703
2850
  function Modal(el, options) {
2704
2851
  _classCallCheck(this, Modal);
2705
2852
 
2706
- var _this11 = _possibleConstructorReturn(this, (Modal.__proto__ || Object.getPrototypeOf(Modal)).call(this, Modal, el, options));
2853
+ var _this12 = _possibleConstructorReturn(this, (Modal.__proto__ || Object.getPrototypeOf(Modal)).call(this, Modal, el, options));
2707
2854
 
2708
- _this11.el.M_Modal = _this11;
2855
+ _this12.el.M_Modal = _this12;
2709
2856
 
2710
2857
  /**
2711
2858
  * Options for the modal
@@ -2721,21 +2868,22 @@ $jscomp.polyfill = function (e, r, p, m) {
2721
2868
  * @prop {String} [startingTop='4%'] - startingTop
2722
2869
  * @prop {String} [endingTop='10%'] - endingTop
2723
2870
  */
2724
- _this11.options = $.extend({}, Modal.defaults, options);
2871
+ _this12.options = $.extend({}, Modal.defaults, options);
2725
2872
 
2726
2873
  /**
2727
2874
  * Describes open/close state of modal
2728
2875
  * @type {Boolean}
2729
2876
  */
2730
- _this11.isOpen = false;
2877
+ _this12.isOpen = false;
2731
2878
 
2732
- _this11.id = _this11.$el.attr('id');
2733
- _this11._openingTrigger = undefined;
2734
- _this11.$overlay = $('<div class="modal-overlay"></div>');
2879
+ _this12.id = _this12.$el.attr('id');
2880
+ _this12._openingTrigger = undefined;
2881
+ _this12.$overlay = $('<div class="modal-overlay"></div>');
2882
+ _this12.el.tabIndex = 0;
2735
2883
 
2736
2884
  Modal._count++;
2737
- _this11._setupEventHandlers();
2738
- return _this11;
2885
+ _this12._setupEventHandlers();
2886
+ return _this12;
2739
2887
  }
2740
2888
 
2741
2889
  _createClass(Modal, [{
@@ -2843,6 +2991,19 @@ $jscomp.polyfill = function (e, r, p, m) {
2843
2991
  }
2844
2992
  }
2845
2993
 
2994
+ /**
2995
+ * Handle Focus
2996
+ * @param {Event} e
2997
+ */
2998
+
2999
+ }, {
3000
+ key: "_handleFocus",
3001
+ value: function _handleFocus(e) {
3002
+ if (!this.el.contains(e.target)) {
3003
+ this.el.focus();
3004
+ }
3005
+ }
3006
+
2846
3007
  /**
2847
3008
  * Animate in modal
2848
3009
  */
@@ -2850,7 +3011,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2850
3011
  }, {
2851
3012
  key: "_animateIn",
2852
3013
  value: function _animateIn() {
2853
- var _this12 = this;
3014
+ var _this13 = this;
2854
3015
 
2855
3016
  // Set initial styles
2856
3017
  $.extend(this.el.style, {
@@ -2877,8 +3038,8 @@ $jscomp.polyfill = function (e, r, p, m) {
2877
3038
  easing: 'easeOutCubic',
2878
3039
  // Handle modal onOpenEnd callback
2879
3040
  complete: function () {
2880
- if (typeof _this12.options.onOpenEnd === 'function') {
2881
- _this12.options.onOpenEnd.call(_this12, _this12.el, _this12._openingTrigger);
3041
+ if (typeof _this13.options.onOpenEnd === 'function') {
3042
+ _this13.options.onOpenEnd.call(_this13, _this13.el, _this13._openingTrigger);
2882
3043
  }
2883
3044
  }
2884
3045
  };
@@ -2910,7 +3071,7 @@ $jscomp.polyfill = function (e, r, p, m) {
2910
3071
  }, {
2911
3072
  key: "_animateOut",
2912
3073
  value: function _animateOut() {
2913
- var _this13 = this;
3074
+ var _this14 = this;
2914
3075
 
2915
3076
  // Animate overlay
2916
3077
  anim({
@@ -2927,12 +3088,12 @@ $jscomp.polyfill = function (e, r, p, m) {
2927
3088
  easing: 'easeOutCubic',
2928
3089
  // Handle modal ready callback
2929
3090
  complete: function () {
2930
- _this13.el.style.display = 'none';
2931
- _this13.$overlay.remove();
3091
+ _this14.el.style.display = 'none';
3092
+ _this14.$overlay.remove();
2932
3093
 
2933
3094
  // Call onCloseEnd callback
2934
- if (typeof _this13.options.onCloseEnd === 'function') {
2935
- _this13.options.onCloseEnd.call(_this13, _this13.el);
3095
+ if (typeof _this14.options.onCloseEnd === 'function') {
3096
+ _this14.options.onCloseEnd.call(_this14, _this14.el);
2936
3097
  }
2937
3098
  }
2938
3099
  };
@@ -2984,18 +3145,27 @@ $jscomp.polyfill = function (e, r, p, m) {
2984
3145
  this.options.onOpenStart.call(this, this.el, this._openingTrigger);
2985
3146
  }
2986
3147
 
2987
- document.body.style.overflow = 'hidden';
3148
+ if (this.options.preventScrolling) {
3149
+ document.body.style.overflow = 'hidden';
3150
+ }
3151
+
2988
3152
  this.el.classList.add('open');
2989
3153
  this.el.insertAdjacentElement('afterend', this.$overlay[0]);
2990
3154
 
2991
3155
  if (this.options.dismissible) {
2992
3156
  this._handleKeydownBound = this._handleKeydown.bind(this);
3157
+ this._handleFocusBound = this._handleFocus.bind(this);
2993
3158
  document.addEventListener('keydown', this._handleKeydownBound);
3159
+ document.addEventListener('focus', this._handleFocusBound, true);
2994
3160
  }
2995
3161
 
2996
3162
  anim.remove(this.el);
2997
3163
  anim.remove(this.$overlay[0]);
2998
3164
  this._animateIn();
3165
+
3166
+ // Focus modal
3167
+ this.el.focus();
3168
+
2999
3169
  return this;
3000
3170
  }
3001
3171
 
@@ -3027,6 +3197,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3027
3197
 
3028
3198
  if (this.options.dismissible) {
3029
3199
  document.removeEventListener('keydown', this._handleKeydownBound);
3200
+ document.removeEventListener('focus', this._handleFocusBound);
3030
3201
  }
3031
3202
 
3032
3203
  anim.remove(this.el);
@@ -3109,9 +3280,9 @@ $jscomp.polyfill = function (e, r, p, m) {
3109
3280
  function Materialbox(el, options) {
3110
3281
  _classCallCheck(this, Materialbox);
3111
3282
 
3112
- var _this14 = _possibleConstructorReturn(this, (Materialbox.__proto__ || Object.getPrototypeOf(Materialbox)).call(this, Materialbox, el, options));
3283
+ var _this15 = _possibleConstructorReturn(this, (Materialbox.__proto__ || Object.getPrototypeOf(Materialbox)).call(this, Materialbox, el, options));
3113
3284
 
3114
- _this14.el.M_Materialbox = _this14;
3285
+ _this15.el.M_Materialbox = _this15;
3115
3286
 
3116
3287
  /**
3117
3288
  * Options for the modal
@@ -3123,22 +3294,22 @@ $jscomp.polyfill = function (e, r, p, m) {
3123
3294
  * @prop {Function} onCloseStart - Callback function called before materialbox is closed
3124
3295
  * @prop {Function} onCloseEnd - Callback function called after materialbox is closed
3125
3296
  */
3126
- _this14.options = $.extend({}, Materialbox.defaults, options);
3297
+ _this15.options = $.extend({}, Materialbox.defaults, options);
3127
3298
 
3128
- _this14.overlayActive = false;
3129
- _this14.doneAnimating = true;
3130
- _this14.placeholder = $('<div></div>').addClass('material-placeholder');
3131
- _this14.originalWidth = 0;
3132
- _this14.originalHeight = 0;
3133
- _this14.originInlineStyles = _this14.$el.attr('style');
3134
- _this14.caption = _this14.el.getAttribute('data-caption') || "";
3299
+ _this15.overlayActive = false;
3300
+ _this15.doneAnimating = true;
3301
+ _this15.placeholder = $('<div></div>').addClass('material-placeholder');
3302
+ _this15.originalWidth = 0;
3303
+ _this15.originalHeight = 0;
3304
+ _this15.originInlineStyles = _this15.$el.attr('style');
3305
+ _this15.caption = _this15.el.getAttribute('data-caption') || "";
3135
3306
 
3136
3307
  // Wrap
3137
- _this14.$el.before(_this14.placeholder);
3138
- _this14.placeholder.append(_this14.$el);
3308
+ _this15.$el.before(_this15.placeholder);
3309
+ _this15.placeholder.append(_this15.$el);
3139
3310
 
3140
- _this14._setupEventHandlers();
3141
- return _this14;
3311
+ _this15._setupEventHandlers();
3312
+ return _this15;
3142
3313
  }
3143
3314
 
3144
3315
  _createClass(Materialbox, [{
@@ -3258,7 +3429,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3258
3429
  }, {
3259
3430
  key: "_animateImageIn",
3260
3431
  value: function _animateImageIn() {
3261
- var _this15 = this;
3432
+ var _this16 = this;
3262
3433
 
3263
3434
  var animOptions = {
3264
3435
  targets: this.el,
@@ -3269,11 +3440,11 @@ $jscomp.polyfill = function (e, r, p, m) {
3269
3440
  duration: this.options.inDuration,
3270
3441
  easing: 'easeOutQuad',
3271
3442
  complete: function () {
3272
- _this15.doneAnimating = true;
3443
+ _this16.doneAnimating = true;
3273
3444
 
3274
3445
  // onOpenEnd callback
3275
- if (typeof _this15.options.onOpenEnd === 'function') {
3276
- _this15.options.onOpenEnd.call(_this15, _this15.el);
3446
+ if (typeof _this16.options.onOpenEnd === 'function') {
3447
+ _this16.options.onOpenEnd.call(_this16, _this16.el);
3277
3448
  }
3278
3449
  }
3279
3450
  };
@@ -3298,7 +3469,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3298
3469
  }, {
3299
3470
  key: "_animateImageOut",
3300
3471
  value: function _animateImageOut() {
3301
- var _this16 = this;
3472
+ var _this17 = this;
3302
3473
 
3303
3474
  var animOptions = {
3304
3475
  targets: this.el,
@@ -3309,7 +3480,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3309
3480
  duration: this.options.outDuration,
3310
3481
  easing: 'easeOutQuad',
3311
3482
  complete: function () {
3312
- _this16.placeholder.css({
3483
+ _this17.placeholder.css({
3313
3484
  height: '',
3314
3485
  width: '',
3315
3486
  position: '',
@@ -3318,28 +3489,28 @@ $jscomp.polyfill = function (e, r, p, m) {
3318
3489
  });
3319
3490
 
3320
3491
  // Revert to width or height attribute
3321
- if (_this16.attrWidth) {
3322
- _this16.$el.attr('width', _this16.attrWidth);
3492
+ if (_this17.attrWidth) {
3493
+ _this17.$el.attr('width', _this17.attrWidth);
3323
3494
  }
3324
- if (_this16.attrHeight) {
3325
- _this16.$el.attr('height', _this16.attrHeight);
3495
+ if (_this17.attrHeight) {
3496
+ _this17.$el.attr('height', _this17.attrHeight);
3326
3497
  }
3327
3498
 
3328
- _this16.$el.removeAttr('style');
3329
- _this16.$el.attr('style', _this16.originInlineStyles);
3499
+ _this17.$el.removeAttr('style');
3500
+ _this17.$el.attr('style', _this17.originInlineStyles);
3330
3501
 
3331
3502
  // Remove class
3332
- _this16.$el.removeClass('active');
3333
- _this16.doneAnimating = true;
3503
+ _this17.$el.removeClass('active');
3504
+ _this17.doneAnimating = true;
3334
3505
 
3335
3506
  // Remove overflow overrides on ancestors
3336
- if (_this16.ancestorsChanged.length) {
3337
- _this16.ancestorsChanged.css('overflow', '');
3507
+ if (_this17.ancestorsChanged.length) {
3508
+ _this17.ancestorsChanged.css('overflow', '');
3338
3509
  }
3339
3510
 
3340
3511
  // onCloseEnd callback
3341
- if (typeof _this16.options.onCloseEnd === 'function') {
3342
- _this16.options.onCloseEnd.call(_this16, _this16.el);
3512
+ if (typeof _this17.options.onCloseEnd === 'function') {
3513
+ _this17.options.onCloseEnd.call(_this17, _this17.el);
3343
3514
  }
3344
3515
  }
3345
3516
  };
@@ -3366,7 +3537,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3366
3537
  }, {
3367
3538
  key: "open",
3368
3539
  value: function open() {
3369
- var _this17 = this;
3540
+ var _this18 = this;
3370
3541
 
3371
3542
  this._updateVars();
3372
3543
  this.originalWidth = this.el.getBoundingClientRect().width;
@@ -3416,8 +3587,8 @@ $jscomp.polyfill = function (e, r, p, m) {
3416
3587
  this.$overlay = $('<div id="materialbox-overlay"></div>').css({
3417
3588
  opacity: 0
3418
3589
  }).one('click', function () {
3419
- if (_this17.doneAnimating) {
3420
- _this17.close();
3590
+ if (_this18.doneAnimating) {
3591
+ _this18.close();
3421
3592
  }
3422
3593
  });
3423
3594
 
@@ -3498,7 +3669,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3498
3669
  }, {
3499
3670
  key: "close",
3500
3671
  value: function close() {
3501
- var _this18 = this;
3672
+ var _this19 = this;
3502
3673
 
3503
3674
  this._updateVars();
3504
3675
  this.doneAnimating = false;
@@ -3526,8 +3697,8 @@ $jscomp.polyfill = function (e, r, p, m) {
3526
3697
  duration: this.options.outDuration,
3527
3698
  easing: 'easeOutQuad',
3528
3699
  complete: function () {
3529
- _this18.overlayActive = false;
3530
- _this18.$overlay.remove();
3700
+ _this19.overlayActive = false;
3701
+ _this19.$overlay.remove();
3531
3702
  }
3532
3703
  });
3533
3704
 
@@ -3541,7 +3712,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3541
3712
  duration: this.options.outDuration,
3542
3713
  easing: 'easeOutQuad',
3543
3714
  complete: function () {
3544
- _this18.$photoCaption.remove();
3715
+ _this19.$photoCaption.remove();
3545
3716
  }
3546
3717
  });
3547
3718
  }
@@ -3591,30 +3762,30 @@ $jscomp.polyfill = function (e, r, p, m) {
3591
3762
  function Parallax(el, options) {
3592
3763
  _classCallCheck(this, Parallax);
3593
3764
 
3594
- var _this19 = _possibleConstructorReturn(this, (Parallax.__proto__ || Object.getPrototypeOf(Parallax)).call(this, Parallax, el, options));
3765
+ var _this20 = _possibleConstructorReturn(this, (Parallax.__proto__ || Object.getPrototypeOf(Parallax)).call(this, Parallax, el, options));
3595
3766
 
3596
- _this19.el.M_Parallax = _this19;
3767
+ _this20.el.M_Parallax = _this20;
3597
3768
 
3598
3769
  /**
3599
3770
  * Options for the Parallax
3600
3771
  * @member Parallax#options
3601
3772
  * @prop {Number} responsiveThreshold
3602
3773
  */
3603
- _this19.options = $.extend({}, Parallax.defaults, options);
3604
- _this19._enabled = window.innerWidth > _this19.options.responsiveThreshold;
3774
+ _this20.options = $.extend({}, Parallax.defaults, options);
3775
+ _this20._enabled = window.innerWidth > _this20.options.responsiveThreshold;
3605
3776
 
3606
- _this19.$img = _this19.$el.find('img').first();
3607
- _this19.$img.each(function () {
3777
+ _this20.$img = _this20.$el.find('img').first();
3778
+ _this20.$img.each(function () {
3608
3779
  var el = this;
3609
3780
  if (el.complete) $(el).trigger("load");
3610
3781
  });
3611
3782
 
3612
- _this19._updateParallax();
3613
- _this19._setupEventHandlers();
3614
- _this19._setupStyles();
3783
+ _this20._updateParallax();
3784
+ _this20._setupEventHandlers();
3785
+ _this20._setupStyles();
3615
3786
 
3616
- Parallax._parallaxes.push(_this19);
3617
- return _this19;
3787
+ Parallax._parallaxes.push(_this20);
3788
+ return _this20;
3618
3789
  }
3619
3790
 
3620
3791
  _createClass(Parallax, [{
@@ -3768,9 +3939,9 @@ $jscomp.polyfill = function (e, r, p, m) {
3768
3939
  function Tabs(el, options) {
3769
3940
  _classCallCheck(this, Tabs);
3770
3941
 
3771
- var _this20 = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, Tabs, el, options));
3942
+ var _this21 = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, Tabs, el, options));
3772
3943
 
3773
- _this20.el.M_Tabs = _this20;
3944
+ _this21.el.M_Tabs = _this21;
3774
3945
 
3775
3946
  /**
3776
3947
  * Options for the Tabs
@@ -3780,23 +3951,23 @@ $jscomp.polyfill = function (e, r, p, m) {
3780
3951
  * @prop {Boolean} swipeable
3781
3952
  * @prop {Number} responsiveThreshold
3782
3953
  */
3783
- _this20.options = $.extend({}, Tabs.defaults, options);
3954
+ _this21.options = $.extend({}, Tabs.defaults, options);
3784
3955
 
3785
3956
  // Setup
3786
- _this20.$tabLinks = _this20.$el.children('li.tab').children('a');
3787
- _this20.index = 0;
3788
- _this20._setTabsAndTabWidth();
3789
- _this20._setupActiveTabLink();
3790
- _this20._createIndicator();
3791
-
3792
- if (_this20.options.swipeable) {
3793
- _this20._setupSwipeableTabs();
3957
+ _this21.$tabLinks = _this21.$el.children('li.tab').children('a');
3958
+ _this21.index = 0;
3959
+ _this21._setTabsAndTabWidth();
3960
+ _this21._setupActiveTabLink();
3961
+ _this21._createIndicator();
3962
+
3963
+ if (_this21.options.swipeable) {
3964
+ _this21._setupSwipeableTabs();
3794
3965
  } else {
3795
- _this20._setupNormalTabs();
3966
+ _this21._setupNormalTabs();
3796
3967
  }
3797
3968
 
3798
- _this20._setupEventHandlers();
3799
- return _this20;
3969
+ _this21._setupEventHandlers();
3970
+ return _this21;
3800
3971
  }
3801
3972
 
3802
3973
  _createClass(Tabs, [{
@@ -3867,7 +4038,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3867
4038
  }, {
3868
4039
  key: "_handleTabClick",
3869
4040
  value: function _handleTabClick(e) {
3870
- var _this21 = this;
4041
+ var _this22 = this;
3871
4042
 
3872
4043
  var tab = $(e.target).closest('li.tab');
3873
4044
  var tabLink = $(e.target).closest('a');
@@ -3907,8 +4078,8 @@ $jscomp.polyfill = function (e, r, p, m) {
3907
4078
  if (this.options.swipeable) {
3908
4079
  if (this._tabsCarousel) {
3909
4080
  this._tabsCarousel.set(this.index, function () {
3910
- if (typeof _this21.options.onShow === "function") {
3911
- _this21.options.onShow.call(_this21, _this21.$content[0]);
4081
+ if (typeof _this22.options.onShow === "function") {
4082
+ _this22.options.onShow.call(_this22, _this22.$content[0]);
3912
4083
  }
3913
4084
  });
3914
4085
  }
@@ -3941,7 +4112,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3941
4112
  }, {
3942
4113
  key: "_createIndicator",
3943
4114
  value: function _createIndicator() {
3944
- var _this22 = this;
4115
+ var _this23 = this;
3945
4116
 
3946
4117
  var indicator = document.createElement('li');
3947
4118
  indicator.classList.add('indicator');
@@ -3950,8 +4121,8 @@ $jscomp.polyfill = function (e, r, p, m) {
3950
4121
  this._indicator = indicator;
3951
4122
 
3952
4123
  setTimeout(function () {
3953
- _this22._indicator.style.left = _this22._calcLeftPos(_this22.$activeTabLink) + 'px';
3954
- _this22._indicator.style.right = _this22._calcRightPos(_this22.$activeTabLink) + 'px';
4124
+ _this23._indicator.style.left = _this23._calcLeftPos(_this23.$activeTabLink) + 'px';
4125
+ _this23._indicator.style.right = _this23._calcRightPos(_this23.$activeTabLink) + 'px';
3955
4126
  }, 0);
3956
4127
  }
3957
4128
 
@@ -3991,7 +4162,7 @@ $jscomp.polyfill = function (e, r, p, m) {
3991
4162
  }, {
3992
4163
  key: "_setupSwipeableTabs",
3993
4164
  value: function _setupSwipeableTabs() {
3994
- var _this23 = this;
4165
+ var _this24 = this;
3995
4166
 
3996
4167
  // Change swipeable according to responsive threshold
3997
4168
  if (window.innerWidth > this.options.responsiveThreshold) {
@@ -4010,21 +4181,27 @@ $jscomp.polyfill = function (e, r, p, m) {
4010
4181
  $tabsWrapper.append($tabsContent);
4011
4182
  $tabsContent[0].style.display = '';
4012
4183
 
4184
+ // Keep active tab index to set initial carousel slide
4185
+ var activeTabIndex = this.$activeTabLink.closest('.tab').index();
4186
+
4013
4187
  this._tabsCarousel = M.Carousel.init($tabsWrapper[0], {
4014
4188
  fullWidth: true,
4015
4189
  noWrap: true,
4016
4190
  onCycleTo: function (item) {
4017
- var prevIndex = _this23.index;
4018
- _this23.index = $(item).index();
4019
- _this23.$activeTabLink.removeClass('active');
4020
- _this23.$activeTabLink = _this23.$tabLinks.eq(_this23.index);
4021
- _this23.$activeTabLink.addClass('active');
4022
- _this23._animateIndicator(prevIndex);
4023
- if (typeof _this23.options.onShow === "function") {
4024
- _this23.options.onShow.call(_this23, _this23.$content[0]);
4191
+ var prevIndex = _this24.index;
4192
+ _this24.index = $(item).index();
4193
+ _this24.$activeTabLink.removeClass('active');
4194
+ _this24.$activeTabLink = _this24.$tabLinks.eq(_this24.index);
4195
+ _this24.$activeTabLink.addClass('active');
4196
+ _this24._animateIndicator(prevIndex);
4197
+ if (typeof _this24.options.onShow === "function") {
4198
+ _this24.options.onShow.call(_this24, _this24.$content[0]);
4025
4199
  }
4026
4200
  }
4027
4201
  });
4202
+
4203
+ // Set initial carousel slide to active tab
4204
+ this._tabsCarousel.set(activeTabIndex);
4028
4205
  }
4029
4206
 
4030
4207
  /**
@@ -4227,16 +4404,17 @@ $jscomp.polyfill = function (e, r, p, m) {
4227
4404
  function Tooltip(el, options) {
4228
4405
  _classCallCheck(this, Tooltip);
4229
4406
 
4230
- var _this24 = _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).call(this, Tooltip, el, options));
4407
+ var _this25 = _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).call(this, Tooltip, el, options));
4231
4408
 
4232
- _this24.el.M_Tooltip = _this24;
4233
- _this24.options = $.extend({}, Tooltip.defaults, options);
4409
+ _this25.el.M_Tooltip = _this25;
4410
+ _this25.options = $.extend({}, Tooltip.defaults, options);
4234
4411
 
4235
- _this24.isOpen = false;
4236
- _this24.isHovered = false;
4237
- _this24._appendTooltipEl();
4238
- _this24._setupEventHandlers();
4239
- return _this24;
4412
+ _this25.isOpen = false;
4413
+ _this25.isHovered = false;
4414
+ _this25.isFocused = false;
4415
+ _this25._appendTooltipEl();
4416
+ _this25._setupEventHandlers();
4417
+ return _this25;
4240
4418
  }
4241
4419
 
4242
4420
  _createClass(Tooltip, [{
@@ -4249,7 +4427,7 @@ $jscomp.polyfill = function (e, r, p, m) {
4249
4427
  value: function destroy() {
4250
4428
  $(this.tooltipEl).remove();
4251
4429
  this._removeEventHandlers();
4252
- this.$el[0].M_Tooltip = undefined;
4430
+ this.el.M_Tooltip = undefined;
4253
4431
  }
4254
4432
  }, {
4255
4433
  key: "_appendTooltipEl",
@@ -4272,16 +4450,22 @@ $jscomp.polyfill = function (e, r, p, m) {
4272
4450
  }, {
4273
4451
  key: "_setupEventHandlers",
4274
4452
  value: function _setupEventHandlers() {
4275
- this.handleMouseEnterBound = this._handleMouseEnter.bind(this);
4276
- this.handleMouseLeaveBound = this._handleMouseLeave.bind(this);
4277
- this.$el[0].addEventListener('mouseenter', this.handleMouseEnterBound);
4278
- this.$el[0].addEventListener('mouseleave', this.handleMouseLeaveBound);
4453
+ this._handleMouseEnterBound = this._handleMouseEnter.bind(this);
4454
+ this._handleMouseLeaveBound = this._handleMouseLeave.bind(this);
4455
+ this._handleFocusBound = this._handleFocus.bind(this);
4456
+ this._handleBlurBound = this._handleBlur.bind(this);
4457
+ this.el.addEventListener('mouseenter', this._handleMouseEnterBound);
4458
+ this.el.addEventListener('mouseleave', this._handleMouseLeaveBound);
4459
+ this.el.addEventListener('focus', this._handleFocusBound, true);
4460
+ this.el.addEventListener('blur', this._handleBlurBound, true);
4279
4461
  }
4280
4462
  }, {
4281
4463
  key: "_removeEventHandlers",
4282
4464
  value: function _removeEventHandlers() {
4283
- this.$el[0].removeEventListener('mouseenter', this.handleMouseEnterBound);
4284
- this.$el[0].removeEventListener('mouseleave', this.handleMouseLeaveBound);
4465
+ this.el.removeEventListener('mouseenter', this._handleMouseEnterBound);
4466
+ this.el.removeEventListener('mouseleave', this._handleMouseLeaveBound);
4467
+ this.el.removeEventListener('focus', this._handleFocusBound, true);
4468
+ this.el.removeEventListener('blur', this._handleBlurBound, true);
4285
4469
  }
4286
4470
  }, {
4287
4471
  key: "open",
@@ -4314,16 +4498,16 @@ $jscomp.polyfill = function (e, r, p, m) {
4314
4498
  }, {
4315
4499
  key: "_setExitDelayTimeout",
4316
4500
  value: function _setExitDelayTimeout() {
4317
- var _this25 = this;
4501
+ var _this26 = this;
4318
4502
 
4319
4503
  clearTimeout(this._exitDelayTimeout);
4320
4504
 
4321
4505
  this._exitDelayTimeout = setTimeout(function () {
4322
- if (_this25.isHovered) {
4506
+ if (_this26.isHovered || _this26.isFocused) {
4323
4507
  return;
4324
4508
  }
4325
4509
 
4326
- _this25._animateOut();
4510
+ _this26._animateOut();
4327
4511
  }, this.options.exitDelay);
4328
4512
  }
4329
4513
 
@@ -4334,22 +4518,22 @@ $jscomp.polyfill = function (e, r, p, m) {
4334
4518
  }, {
4335
4519
  key: "_setEnterDelayTimeout",
4336
4520
  value: function _setEnterDelayTimeout() {
4337
- var _this26 = this;
4521
+ var _this27 = this;
4338
4522
 
4339
4523
  clearTimeout(this._enterDelayTimeout);
4340
4524
 
4341
4525
  this._enterDelayTimeout = setTimeout(function () {
4342
- if (!_this26.isHovered) {
4526
+ if (!_this27.isHovered && !_this27.isFocused) {
4343
4527
  return;
4344
4528
  }
4345
4529
 
4346
- _this26._animateIn();
4530
+ _this27._animateIn();
4347
4531
  }, this.options.enterDelay);
4348
4532
  }
4349
4533
  }, {
4350
4534
  key: "_positionTooltip",
4351
4535
  value: function _positionTooltip() {
4352
- var origin = this.$el[0],
4536
+ var origin = this.el,
4353
4537
  tooltip = this.tooltipEl,
4354
4538
  originHeight = origin.offsetHeight,
4355
4539
  originWidth = origin.offsetWidth,
@@ -4464,12 +4648,24 @@ $jscomp.polyfill = function (e, r, p, m) {
4464
4648
  this.isHovered = false;
4465
4649
  this.close();
4466
4650
  }
4651
+ }, {
4652
+ key: "_handleFocus",
4653
+ value: function _handleFocus() {
4654
+ this.isFocused = true;
4655
+ this.open();
4656
+ }
4657
+ }, {
4658
+ key: "_handleBlur",
4659
+ value: function _handleBlur() {
4660
+ this.isFocused = false;
4661
+ this.close();
4662
+ }
4467
4663
  }, {
4468
4664
  key: "_getAttributeOptions",
4469
4665
  value: function _getAttributeOptions() {
4470
4666
  var attributeOptions = {};
4471
- var tooltipTextOption = this.$el[0].getAttribute('data-tooltip');
4472
- var positionOption = this.$el[0].getAttribute('data-position');
4667
+ var tooltipTextOption = this.el.getAttribute('data-tooltip');
4668
+ var positionOption = this.el.getAttribute('data-position');
4473
4669
 
4474
4670
  if (tooltipTextOption) {
4475
4671
  attributeOptions.html = tooltipTextOption;
@@ -4952,18 +5148,18 @@ $jscomp.polyfill = function (e, r, p, m) {
4952
5148
  }, {
4953
5149
  key: "_setTimer",
4954
5150
  value: function _setTimer() {
4955
- var _this27 = this;
5151
+ var _this28 = this;
4956
5152
 
4957
5153
  if (this.timeRemaining !== Infinity) {
4958
5154
  this.counterInterval = setInterval(function () {
4959
5155
  // If toast is not being dragged, decrease its time remaining
4960
- if (!_this27.panning) {
4961
- _this27.timeRemaining -= 20;
5156
+ if (!_this28.panning) {
5157
+ _this28.timeRemaining -= 20;
4962
5158
  }
4963
5159
 
4964
5160
  // Animate toast out
4965
- if (_this27.timeRemaining <= 0) {
4966
- _this27.dismiss();
5161
+ if (_this28.timeRemaining <= 0) {
5162
+ _this28.dismiss();
4967
5163
  }
4968
5164
  }, 20);
4969
5165
  }
@@ -4976,7 +5172,7 @@ $jscomp.polyfill = function (e, r, p, m) {
4976
5172
  }, {
4977
5173
  key: "dismiss",
4978
5174
  value: function dismiss() {
4979
- var _this28 = this;
5175
+ var _this29 = this;
4980
5176
 
4981
5177
  window.clearInterval(this.counterInterval);
4982
5178
  var activationDistance = this.el.offsetWidth * this.options.activationPercent;
@@ -4995,12 +5191,12 @@ $jscomp.polyfill = function (e, r, p, m) {
4995
5191
  easing: 'easeOutExpo',
4996
5192
  complete: function () {
4997
5193
  // Call the optional callback
4998
- if (typeof _this28.options.completeCallback === 'function') {
4999
- _this28.options.completeCallback();
5194
+ if (typeof _this29.options.completeCallback === 'function') {
5195
+ _this29.options.completeCallback();
5000
5196
  }
5001
5197
  // Remove toast from DOM
5002
- _this28.el.parentNode.removeChild(_this28.el);
5003
- Toast._toasts.splice(Toast._toasts.indexOf(_this28), 1);
5198
+ _this29.el.parentNode.removeChild(_this29.el);
5199
+ Toast._toasts.splice(Toast._toasts.indexOf(_this29), 1);
5004
5200
  if (Toast._toasts.length === 0) {
5005
5201
  Toast._removeContainer();
5006
5202
  }
@@ -5206,7 +5402,8 @@ $jscomp.polyfill = function (e, r, p, m) {
5206
5402
  onOpenStart: null,
5207
5403
  onOpenEnd: null,
5208
5404
  onCloseStart: null,
5209
- onCloseEnd: null
5405
+ onCloseEnd: null,
5406
+ preventScrolling: true
5210
5407
  };
5211
5408
 
5212
5409
  /**
@@ -5225,10 +5422,10 @@ $jscomp.polyfill = function (e, r, p, m) {
5225
5422
  function Sidenav(el, options) {
5226
5423
  _classCallCheck(this, Sidenav);
5227
5424
 
5228
- var _this29 = _possibleConstructorReturn(this, (Sidenav.__proto__ || Object.getPrototypeOf(Sidenav)).call(this, Sidenav, el, options));
5425
+ var _this30 = _possibleConstructorReturn(this, (Sidenav.__proto__ || Object.getPrototypeOf(Sidenav)).call(this, Sidenav, el, options));
5229
5426
 
5230
- _this29.el.M_Sidenav = _this29;
5231
- _this29.id = _this29.$el.attr('id');
5427
+ _this30.el.M_Sidenav = _this30;
5428
+ _this30.id = _this30.$el.attr('id');
5232
5429
 
5233
5430
  /**
5234
5431
  * Options for the Sidenav
@@ -5242,34 +5439,38 @@ $jscomp.polyfill = function (e, r, p, m) {
5242
5439
  * @prop {Function} onCloseStart - Function called when sidenav starts exiting
5243
5440
  * @prop {Function} onCloseEnd - Function called when sidenav finishes exiting
5244
5441
  */
5245
- _this29.options = $.extend({}, Sidenav.defaults, options);
5442
+ _this30.options = $.extend({}, Sidenav.defaults, options);
5246
5443
 
5247
5444
  /**
5248
5445
  * Describes open/close state of Sidenav
5249
5446
  * @type {Boolean}
5250
5447
  */
5251
- _this29.isOpen = false;
5448
+ _this30.isOpen = false;
5252
5449
 
5253
5450
  /**
5254
5451
  * Describes if Sidenav is fixed
5255
5452
  * @type {Boolean}
5256
5453
  */
5257
- _this29.isFixed = _this29.el.classList.contains('sidenav-fixed');
5454
+ _this30.isFixed = _this30.el.classList.contains('sidenav-fixed');
5258
5455
 
5259
5456
  /**
5260
5457
  * Describes if Sidenav is being draggeed
5261
5458
  * @type {Boolean}
5262
5459
  */
5263
- _this29.isDragged = false;
5460
+ _this30.isDragged = false;
5461
+
5462
+ // Window size variables for window resize checks
5463
+ _this30.lastWindowWidth = window.innerWidth;
5464
+ _this30.lastWindowHeight = window.innerHeight;
5264
5465
 
5265
- _this29._createOverlay();
5266
- _this29._createDragTarget();
5267
- _this29._setupEventHandlers();
5268
- _this29._setupClasses();
5269
- _this29._setupFixed();
5466
+ _this30._createOverlay();
5467
+ _this30._createDragTarget();
5468
+ _this30._setupEventHandlers();
5469
+ _this30._setupClasses();
5470
+ _this30._setupFixed();
5270
5471
 
5271
- Sidenav._sidenavs.push(_this29);
5272
- return _this29;
5472
+ Sidenav._sidenavs.push(_this30);
5473
+ return _this30;
5273
5474
  }
5274
5475
 
5275
5476
  _createClass(Sidenav, [{
@@ -5386,6 +5587,8 @@ $jscomp.polyfill = function (e, r, p, m) {
5386
5587
  this._time = Date.now();
5387
5588
  this._width = this.el.getBoundingClientRect().width;
5388
5589
  this._overlay.style.display = 'block';
5590
+ this._initialScrollTop = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop();
5591
+ this._verticallyScrolling = false;
5389
5592
  anim.remove(this.el);
5390
5593
  anim.remove(this._overlay);
5391
5594
  }
@@ -5399,10 +5602,14 @@ $jscomp.polyfill = function (e, r, p, m) {
5399
5602
  key: "_dragMoveUpdate",
5400
5603
  value: function _dragMoveUpdate(e) {
5401
5604
  var clientX = e.targetTouches[0].clientX;
5605
+ var currentScrollTop = this.isOpen ? this.el.scrollTop : M.getDocumentScrollTop();
5402
5606
  this.deltaX = Math.abs(this._xPos - clientX);
5403
5607
  this._xPos = clientX;
5404
5608
  this.velocityX = this.deltaX / (Date.now() - this._time);
5405
5609
  this._time = Date.now();
5610
+ if (this._initialScrollTop !== currentScrollTop) {
5611
+ this._verticallyScrolling = true;
5612
+ }
5406
5613
  }
5407
5614
 
5408
5615
  /**
@@ -5414,7 +5621,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5414
5621
  key: "_handleDragTargetDrag",
5415
5622
  value: function _handleDragTargetDrag(e) {
5416
5623
  // Check if draggable
5417
- if (!this.options.draggable || this._isCurrentlyFixed()) {
5624
+ if (!this.options.draggable || this._isCurrentlyFixed() || this._verticallyScrolling) {
5418
5625
  return;
5419
5626
  }
5420
5627
 
@@ -5473,6 +5680,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5473
5680
  }
5474
5681
 
5475
5682
  this.isDragged = false;
5683
+ this._verticallyScrolling = false;
5476
5684
  }
5477
5685
  }
5478
5686
 
@@ -5486,7 +5694,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5486
5694
  value: function _handleCloseDrag(e) {
5487
5695
  if (this.isOpen) {
5488
5696
  // Check if draggable
5489
- if (!this.options.draggable || this._isCurrentlyFixed()) {
5697
+ if (!this.options.draggable || this._isCurrentlyFixed() || this._verticallyScrolling) {
5490
5698
  return;
5491
5699
  }
5492
5700
 
@@ -5539,6 +5747,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5539
5747
  }
5540
5748
 
5541
5749
  this.isDragged = false;
5750
+ this._verticallyScrolling = false;
5542
5751
  }
5543
5752
  }
5544
5753
 
@@ -5550,7 +5759,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5550
5759
  key: "_handleCloseTriggerClick",
5551
5760
  value: function _handleCloseTriggerClick(e) {
5552
5761
  var $closeTrigger = $(e.target).closest('.sidenav-close');
5553
- if ($closeTrigger.length) {
5762
+ if ($closeTrigger.length && !this._isCurrentlyFixed()) {
5554
5763
  this.close();
5555
5764
  }
5556
5765
  }
@@ -5562,11 +5771,17 @@ $jscomp.polyfill = function (e, r, p, m) {
5562
5771
  }, {
5563
5772
  key: "_handleWindowResize",
5564
5773
  value: function _handleWindowResize() {
5565
- if (window.innerWidth > 992) {
5566
- this.open();
5567
- } else {
5568
- this.close();
5774
+ // Only handle horizontal resizes
5775
+ if (this.lastWindowWidth !== window.innerWidth) {
5776
+ if (window.innerWidth > 992) {
5777
+ this.open();
5778
+ } else {
5779
+ this.close();
5780
+ }
5569
5781
  }
5782
+
5783
+ this.lastWindowWidth = window.innerWidth;
5784
+ this.lastWindowHeight = window.innerHeight;
5570
5785
  }
5571
5786
  }, {
5572
5787
  key: "_setupClasses",
@@ -5642,7 +5857,9 @@ $jscomp.polyfill = function (e, r, p, m) {
5642
5857
 
5643
5858
  // Handle non-fixed Sidenav
5644
5859
  } else {
5645
- this._preventBodyScrolling();
5860
+ if (this.options.preventScrolling) {
5861
+ this._preventBodyScrolling();
5862
+ }
5646
5863
 
5647
5864
  if (!this.isDragged || this.percentOpen != 1) {
5648
5865
  this._animateIn();
@@ -5688,7 +5905,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5688
5905
  }, {
5689
5906
  key: "_animateSidenavIn",
5690
5907
  value: function _animateSidenavIn() {
5691
- var _this30 = this;
5908
+ var _this31 = this;
5692
5909
 
5693
5910
  var slideOutPercent = this.options.edge === 'left' ? -1 : 1;
5694
5911
  if (this.isDragged) {
@@ -5703,8 +5920,8 @@ $jscomp.polyfill = function (e, r, p, m) {
5703
5920
  easing: 'easeOutQuad',
5704
5921
  complete: function () {
5705
5922
  // Run onOpenEnd callback
5706
- if (typeof _this30.options.onOpenEnd === 'function') {
5707
- _this30.options.onOpenEnd.call(_this30, _this30.el);
5923
+ if (typeof _this31.options.onOpenEnd === 'function') {
5924
+ _this31.options.onOpenEnd.call(_this31, _this31.el);
5708
5925
  }
5709
5926
  }
5710
5927
  });
@@ -5738,7 +5955,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5738
5955
  }, {
5739
5956
  key: "_animateSidenavOut",
5740
5957
  value: function _animateSidenavOut() {
5741
- var _this31 = this;
5958
+ var _this32 = this;
5742
5959
 
5743
5960
  var endPercent = this.options.edge === 'left' ? -1 : 1;
5744
5961
  var slideOutPercent = 0;
@@ -5754,8 +5971,8 @@ $jscomp.polyfill = function (e, r, p, m) {
5754
5971
  easing: 'easeOutQuad',
5755
5972
  complete: function () {
5756
5973
  // Run onOpenEnd callback
5757
- if (typeof _this31.options.onCloseEnd === 'function') {
5758
- _this31.options.onCloseEnd.call(_this31, _this31.el);
5974
+ if (typeof _this32.options.onCloseEnd === 'function') {
5975
+ _this32.options.onCloseEnd.call(_this32, _this32.el);
5759
5976
  }
5760
5977
  }
5761
5978
  });
@@ -5763,7 +5980,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5763
5980
  }, {
5764
5981
  key: "_animateOverlayOut",
5765
5982
  value: function _animateOverlayOut() {
5766
- var _this32 = this;
5983
+ var _this33 = this;
5767
5984
 
5768
5985
  anim.remove(this._overlay);
5769
5986
  anim({
@@ -5772,7 +5989,7 @@ $jscomp.polyfill = function (e, r, p, m) {
5772
5989
  duration: this.options.outDuration,
5773
5990
  easing: 'easeOutQuad',
5774
5991
  complete: function () {
5775
- $(_this32._overlay).css('display', 'none');
5992
+ $(_this33._overlay).css('display', 'none');
5776
5993
  }
5777
5994
  });
5778
5995
  }
@@ -5846,9 +6063,9 @@ $jscomp.polyfill = function (e, r, p, m) {
5846
6063
  function ScrollSpy(el, options) {
5847
6064
  _classCallCheck(this, ScrollSpy);
5848
6065
 
5849
- var _this33 = _possibleConstructorReturn(this, (ScrollSpy.__proto__ || Object.getPrototypeOf(ScrollSpy)).call(this, ScrollSpy, el, options));
6066
+ var _this34 = _possibleConstructorReturn(this, (ScrollSpy.__proto__ || Object.getPrototypeOf(ScrollSpy)).call(this, ScrollSpy, el, options));
5850
6067
 
5851
- _this33.el.M_ScrollSpy = _this33;
6068
+ _this34.el.M_ScrollSpy = _this34;
5852
6069
 
5853
6070
  /**
5854
6071
  * Options for the modal
@@ -5858,17 +6075,17 @@ $jscomp.polyfill = function (e, r, p, m) {
5858
6075
  * @prop {String} [activeClass='active'] - Class applied to active elements
5859
6076
  * @prop {Function} [getActiveElement] - Used to find active element
5860
6077
  */
5861
- _this33.options = $.extend({}, ScrollSpy.defaults, options);
6078
+ _this34.options = $.extend({}, ScrollSpy.defaults, options);
5862
6079
 
5863
6080
  // setup
5864
- ScrollSpy._elements.push(_this33);
6081
+ ScrollSpy._elements.push(_this34);
5865
6082
  ScrollSpy._count++;
5866
6083
  ScrollSpy._increment++;
5867
- _this33.tickId = -1;
5868
- _this33.id = ScrollSpy._increment;
5869
- _this33._setupEventHandlers();
5870
- _this33._handleWindowScroll();
5871
- return _this33;
6084
+ _this34.tickId = -1;
6085
+ _this34.id = ScrollSpy._increment;
6086
+ _this34._setupEventHandlers();
6087
+ _this34._handleWindowScroll();
6088
+ return _this34;
5872
6089
  }
5873
6090
 
5874
6091
  _createClass(ScrollSpy, [{
@@ -6021,7 +6238,7 @@ $jscomp.polyfill = function (e, r, p, m) {
6021
6238
  }, {
6022
6239
  key: "_exit",
6023
6240
  value: function _exit() {
6024
- var _this34 = this;
6241
+ var _this35 = this;
6025
6242
 
6026
6243
  ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (value) {
6027
6244
  return value.height() != 0;
@@ -6031,7 +6248,7 @@ $jscomp.polyfill = function (e, r, p, m) {
6031
6248
  $(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).removeClass(this.options.activeClass);
6032
6249
 
6033
6250
  ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (el) {
6034
- return el.attr('id') != _this34.$el.attr('id');
6251
+ return el.attr('id') != _this35.$el.attr('id');
6035
6252
  });
6036
6253
  if (ScrollSpy._visibleElements[0]) {
6037
6254
  // Check if empty
@@ -6166,9 +6383,9 @@ $jscomp.polyfill = function (e, r, p, m) {
6166
6383
  function Autocomplete(el, options) {
6167
6384
  _classCallCheck(this, Autocomplete);
6168
6385
 
6169
- var _this35 = _possibleConstructorReturn(this, (Autocomplete.__proto__ || Object.getPrototypeOf(Autocomplete)).call(this, Autocomplete, el, options));
6386
+ var _this36 = _possibleConstructorReturn(this, (Autocomplete.__proto__ || Object.getPrototypeOf(Autocomplete)).call(this, Autocomplete, el, options));
6170
6387
 
6171
- _this35.el.M_Autocomplete = _this35;
6388
+ _this36.el.M_Autocomplete = _this36;
6172
6389
 
6173
6390
  /**
6174
6391
  * Options for the autocomplete
@@ -6182,19 +6399,19 @@ $jscomp.polyfill = function (e, r, p, m) {
6182
6399
  * @prop {Boolean} noWrap
6183
6400
  * @prop {Function} onCycleTo
6184
6401
  */
6185
- _this35.options = $.extend({}, Autocomplete.defaults, options);
6402
+ _this36.options = $.extend({}, Autocomplete.defaults, options);
6186
6403
 
6187
6404
  // Setup
6188
- _this35.isOpen = false;
6189
- _this35.count = 0;
6190
- _this35.activeIndex = -1;
6191
- _this35.oldVal;
6192
- _this35.$inputField = _this35.$el.closest('.input-field');
6193
- _this35.$active = $();
6194
- _this35._setupDropdown();
6195
-
6196
- _this35._setupEventHandlers();
6197
- return _this35;
6405
+ _this36.isOpen = false;
6406
+ _this36.count = 0;
6407
+ _this36.activeIndex = -1;
6408
+ _this36.oldVal;
6409
+ _this36.$inputField = _this36.$el.closest('.input-field');
6410
+ _this36.$active = $();
6411
+ _this36._setupDropdown();
6412
+
6413
+ _this36._setupEventHandlers();
6414
+ return _this36;
6198
6415
  }
6199
6416
 
6200
6417
  _createClass(Autocomplete, [{
@@ -6259,8 +6476,19 @@ $jscomp.polyfill = function (e, r, p, m) {
6259
6476
  key: "_setupDropdown",
6260
6477
  value: function _setupDropdown() {
6261
6478
  this.container = document.createElement('ul');
6479
+ this.container.id = "autocomplete-options-" + M.guid();
6262
6480
  $(this.container).addClass('autocomplete-content dropdown-content');
6263
6481
  this.$inputField.append(this.container);
6482
+ this.el.setAttribute('data-target', this.container.id);
6483
+
6484
+ this.dropdown = M.Dropdown.init(this.el, {
6485
+ autoFocus: false,
6486
+ closeOnClick: false,
6487
+ coverTrigger: false
6488
+ });
6489
+
6490
+ // Sketchy removal of dropdown click handler
6491
+ this.el.removeEventListener('click', this.dropdown._handleClickBound);
6264
6492
  }
6265
6493
 
6266
6494
  /**
@@ -6280,7 +6508,8 @@ $jscomp.polyfill = function (e, r, p, m) {
6280
6508
  }, {
6281
6509
  key: "_handleInputBlur",
6282
6510
  value: function _handleInputBlur() {
6283
- this._removeAutocomplete();
6511
+ this.dropdown.close();
6512
+ this._resetAutocomplete();
6284
6513
  }
6285
6514
 
6286
6515
  /**
@@ -6291,6 +6520,8 @@ $jscomp.polyfill = function (e, r, p, m) {
6291
6520
  }, {
6292
6521
  key: "_handleInputKeyupAndFocus",
6293
6522
  value: function _handleInputKeyupAndFocus(e) {
6523
+ var _this37 = this;
6524
+
6294
6525
  if (e.type === 'keyup') {
6295
6526
  Autocomplete._keydown = false;
6296
6527
  }
@@ -6305,12 +6536,24 @@ $jscomp.polyfill = function (e, r, p, m) {
6305
6536
 
6306
6537
  // Check if the input isn't empty
6307
6538
  if (this.oldVal !== val) {
6308
- this._removeAutocomplete();
6539
+ this._resetAutocomplete();
6309
6540
 
6310
6541
  if (val.length >= this.options.minLength) {
6311
6542
  this.isOpen = true;
6312
6543
  this._renderDropdown(this.options.data, val);
6313
6544
  }
6545
+
6546
+ // Open dropdown
6547
+ if (!this.dropdown.isOpen) {
6548
+ // Timeout to prevent dropdown temp doc click handler from firing
6549
+ setTimeout(function () {
6550
+ _this37.dropdown.open();
6551
+ }, 100);
6552
+
6553
+ // Recalculate dropdown when its already open
6554
+ } else {
6555
+ this.dropdown.recalculateDimensions();
6556
+ }
6314
6557
  }
6315
6558
 
6316
6559
  // Update oldVal
@@ -6405,18 +6648,15 @@ $jscomp.polyfill = function (e, r, p, m) {
6405
6648
  }
6406
6649
 
6407
6650
  /**
6408
- * Remove autocomplete elements
6651
+ * Reset autocomplete elements
6409
6652
  */
6410
6653
 
6411
6654
  }, {
6412
- key: "_removeAutocomplete",
6413
- value: function _removeAutocomplete() {
6655
+ key: "_resetAutocomplete",
6656
+ value: function _resetAutocomplete() {
6414
6657
  $(this.container).empty();
6415
6658
  this._resetCurrentElement();
6416
6659
  this.oldVal = null;
6417
- $(this.container).css({
6418
- display: ''
6419
- });
6420
6660
  this.isOpen = false;
6421
6661
  }
6422
6662
 
@@ -6431,7 +6671,8 @@ $jscomp.polyfill = function (e, r, p, m) {
6431
6671
  var text = el.text().trim();
6432
6672
  this.el.value = text;
6433
6673
  this.$el.trigger('change');
6434
- this._removeAutocomplete();
6674
+ this._resetAutocomplete();
6675
+ this.dropdown.close();
6435
6676
 
6436
6677
  // Handle onAutocomplete callback.
6437
6678
  if (typeof this.options.onAutocomplete === 'function') {
@@ -6448,9 +6689,9 @@ $jscomp.polyfill = function (e, r, p, m) {
6448
6689
  }, {
6449
6690
  key: "_renderDropdown",
6450
6691
  value: function _renderDropdown(data, val) {
6451
- var _this36 = this;
6692
+ var _this38 = this;
6452
6693
 
6453
- this._removeAutocomplete();
6694
+ this._resetAutocomplete();
6454
6695
 
6455
6696
  var matchingData = [];
6456
6697
 
@@ -6474,14 +6715,10 @@ $jscomp.polyfill = function (e, r, p, m) {
6474
6715
 
6475
6716
  // Sort
6476
6717
  var sortFunctionBound = function (a, b) {
6477
- return _this36.options.sortFunction(a.key.toLowerCase(), b.key.toLowerCase(), val.toLowerCase());
6718
+ return _this38.options.sortFunction(a.key.toLowerCase(), b.key.toLowerCase(), val.toLowerCase());
6478
6719
  };
6479
6720
  matchingData.sort(sortFunctionBound);
6480
6721
 
6481
- $(this.container).css({
6482
- display: 'block'
6483
- });
6484
-
6485
6722
  // Render
6486
6723
  for (var i = 0; i < matchingData.length; i++) {
6487
6724
  var _entry = matchingData[i];
@@ -6555,7 +6792,7 @@ $jscomp.polyfill = function (e, r, p, m) {
6555
6792
  ;(function ($) {
6556
6793
  // Function to update labels of text fields
6557
6794
  M.updateTextFields = function () {
6558
- var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], textarea';
6795
+ var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
6559
6796
  $(input_selector).each(function (element, index) {
6560
6797
  var $this = $(this);
6561
6798
  if (element.value.length > 0 || $(element).is(':focus') || element.autofocus || $this.attr('placeholder') !== null) {
@@ -6684,7 +6921,7 @@ $jscomp.polyfill = function (e, r, p, m) {
6684
6921
 
6685
6922
  $(document).ready(function () {
6686
6923
  // Text based inputs
6687
- var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], textarea';
6924
+ var input_selector = 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
6688
6925
 
6689
6926
  // Add active if form auto complete
6690
6927
  $(document).on('change', input_selector, function () {
@@ -6824,9 +7061,9 @@ $jscomp.polyfill = function (e, r, p, m) {
6824
7061
  function Slider(el, options) {
6825
7062
  _classCallCheck(this, Slider);
6826
7063
 
6827
- var _this37 = _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).call(this, Slider, el, options));
7064
+ var _this39 = _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).call(this, Slider, el, options));
6828
7065
 
6829
- _this37.el.M_Slider = _this37;
7066
+ _this39.el.M_Slider = _this39;
6830
7067
 
6831
7068
  /**
6832
7069
  * Options for the modal
@@ -6836,25 +7073,27 @@ $jscomp.polyfill = function (e, r, p, m) {
6836
7073
  * @prop {Number} [duration=500] - Length in ms of slide transition
6837
7074
  * @prop {Number} [interval=6000] - Length in ms of slide interval
6838
7075
  */
6839
- _this37.options = $.extend({}, Slider.defaults, options);
7076
+ _this39.options = $.extend({}, Slider.defaults, options);
6840
7077
 
6841
7078
  // setup
6842
- _this37.$slider = _this37.$el.find('.slides');
6843
- _this37.$slides = _this37.$slider.children('li');
6844
- _this37.activeIndex = _this37.$slider.find('.active').index();
6845
- if (_this37.activeIndex != -1) {
6846
- _this37.$active = _this37.$slides.eq(_this37.activeIndex);
7079
+ _this39.$slider = _this39.$el.find('.slides');
7080
+ _this39.$slides = _this39.$slider.children('li');
7081
+ _this39.activeIndex = _this39.$slides.filter(function (item) {
7082
+ return $(item).hasClass('active');
7083
+ }).first().index();
7084
+ if (_this39.activeIndex != -1) {
7085
+ _this39.$active = _this39.$slides.eq(_this39.activeIndex);
6847
7086
  }
6848
7087
 
6849
- _this37._setSliderHeight();
7088
+ _this39._setSliderHeight();
6850
7089
 
6851
7090
  // Set initial positions of captions
6852
- _this37.$slides.find('.caption').each(function (el) {
6853
- _this37._animateCaptionIn(el, 0);
7091
+ _this39.$slides.find('.caption').each(function (el) {
7092
+ _this39._animateCaptionIn(el, 0);
6854
7093
  });
6855
7094
 
6856
7095
  // Move img src into background-image
6857
- _this37.$slides.find('img').each(function (el) {
7096
+ _this39.$slides.find('img').each(function (el) {
6858
7097
  var placeholderBase64 = '';
6859
7098
  if ($(el).attr('src') !== placeholderBase64) {
6860
7099
  $(el).css('background-image', 'url("' + $(el).attr('src') + '")');
@@ -6862,46 +7101,46 @@ $jscomp.polyfill = function (e, r, p, m) {
6862
7101
  }
6863
7102
  });
6864
7103
 
6865
- _this37._setupIndicators();
7104
+ _this39._setupIndicators();
6866
7105
 
6867
7106
  // Show active slide
6868
- if (_this37.$active) {
6869
- _this37.$active.css('display', 'block');
7107
+ if (_this39.$active) {
7108
+ _this39.$active.css('display', 'block');
6870
7109
  } else {
6871
- _this37.$slides.first().addClass('active');
7110
+ _this39.$slides.first().addClass('active');
6872
7111
  anim({
6873
- targets: _this37.$slides.first()[0],
7112
+ targets: _this39.$slides.first()[0],
6874
7113
  opacity: 1,
6875
- duration: _this37.options.duration,
7114
+ duration: _this39.options.duration,
6876
7115
  easing: 'easeOutQuad'
6877
7116
  });
6878
7117
 
6879
- _this37.activeIndex = 0;
6880
- _this37.$active = _this37.$slides.eq(_this37.activeIndex);
7118
+ _this39.activeIndex = 0;
7119
+ _this39.$active = _this39.$slides.eq(_this39.activeIndex);
6881
7120
 
6882
7121
  // Update indicators
6883
- if (_this37.options.indicators) {
6884
- _this37.$indicators.eq(_this37.activeIndex).addClass('active');
7122
+ if (_this39.options.indicators) {
7123
+ _this39.$indicators.eq(_this39.activeIndex).addClass('active');
6885
7124
  }
6886
7125
  }
6887
7126
 
6888
7127
  // Adjust height to current slide
6889
- _this37.$active.find('img').each(function (el) {
7128
+ _this39.$active.find('img').each(function (el) {
6890
7129
  anim({
6891
- targets: _this37.$active.find('.caption')[0],
7130
+ targets: _this39.$active.find('.caption')[0],
6892
7131
  opacity: 1,
6893
7132
  translateX: 0,
6894
7133
  translateY: 0,
6895
- duration: _this37.options.duration,
7134
+ duration: _this39.options.duration,
6896
7135
  easing: 'easeOutQuad'
6897
7136
  });
6898
7137
  });
6899
7138
 
6900
- _this37._setupEventHandlers();
7139
+ _this39._setupEventHandlers();
6901
7140
 
6902
7141
  // auto scroll
6903
- _this37.start();
6904
- return _this37;
7142
+ _this39.start();
7143
+ return _this39;
6905
7144
  }
6906
7145
 
6907
7146
  _createClass(Slider, [{
@@ -6925,14 +7164,14 @@ $jscomp.polyfill = function (e, r, p, m) {
6925
7164
  }, {
6926
7165
  key: "_setupEventHandlers",
6927
7166
  value: function _setupEventHandlers() {
6928
- var _this38 = this;
7167
+ var _this40 = this;
6929
7168
 
6930
7169
  this._handleIntervalBound = this._handleInterval.bind(this);
6931
7170
  this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
6932
7171
 
6933
7172
  if (this.options.indicators) {
6934
7173
  this.$indicators.each(function (el) {
6935
- el.addEventListener('click', _this38._handleIndicatorClickBound);
7174
+ el.addEventListener('click', _this40._handleIndicatorClickBound);
6936
7175
  });
6937
7176
  }
6938
7177
  }
@@ -6944,11 +7183,11 @@ $jscomp.polyfill = function (e, r, p, m) {
6944
7183
  }, {
6945
7184
  key: "_removeEventHandlers",
6946
7185
  value: function _removeEventHandlers() {
6947
- var _this39 = this;
7186
+ var _this41 = this;
6948
7187
 
6949
7188
  if (this.options.indicators) {
6950
7189
  this.$indicators.each(function (el) {
6951
- el.removeEventListener('click', _this39._handleIndicatorClickBound);
7190
+ el.removeEventListener('click', _this41._handleIndicatorClickBound);
6952
7191
  });
6953
7192
  }
6954
7193
  }
@@ -7032,13 +7271,13 @@ $jscomp.polyfill = function (e, r, p, m) {
7032
7271
  }, {
7033
7272
  key: "_setupIndicators",
7034
7273
  value: function _setupIndicators() {
7035
- var _this40 = this;
7274
+ var _this42 = this;
7036
7275
 
7037
7276
  if (this.options.indicators) {
7038
7277
  this.$indicators = $('<ul class="indicators"></ul>');
7039
7278
  this.$slides.each(function (el, index) {
7040
7279
  var $indicator = $('<li class="indicator-item"></li>');
7041
- _this40.$indicators.append($indicator[0]);
7280
+ _this42.$indicators.append($indicator[0]);
7042
7281
  });
7043
7282
  this.$el.append(this.$indicators[0]);
7044
7283
  this.$indicators = this.$indicators.children('li.indicator-item');
@@ -7063,7 +7302,7 @@ $jscomp.polyfill = function (e, r, p, m) {
7063
7302
  }, {
7064
7303
  key: "set",
7065
7304
  value: function set(index) {
7066
- var _this41 = this;
7305
+ var _this43 = this;
7067
7306
 
7068
7307
  // Wrap around indices.
7069
7308
  if (index >= this.$slides.length) index = 0;else if (index < 0) index = this.$slides.length - 1;
@@ -7080,7 +7319,7 @@ $jscomp.polyfill = function (e, r, p, m) {
7080
7319
  duration: this.options.duration,
7081
7320
  easing: 'easeOutQuad',
7082
7321
  complete: function () {
7083
- _this41.$slides.not('.active').each(function (el) {
7322
+ _this43.$slides.not('.active').each(function (el) {
7084
7323
  anim({
7085
7324
  targets: el,
7086
7325
  opacity: 0,
@@ -7279,9 +7518,9 @@ $jscomp.polyfill = function (e, r, p, m) {
7279
7518
  function Chips(el, options) {
7280
7519
  _classCallCheck(this, Chips);
7281
7520
 
7282
- var _this42 = _possibleConstructorReturn(this, (Chips.__proto__ || Object.getPrototypeOf(Chips)).call(this, Chips, el, options));
7521
+ var _this44 = _possibleConstructorReturn(this, (Chips.__proto__ || Object.getPrototypeOf(Chips)).call(this, Chips, el, options));
7283
7522
 
7284
- _this42.el.M_Chips = _this42;
7523
+ _this44.el.M_Chips = _this44;
7285
7524
 
7286
7525
  /**
7287
7526
  * Options for the modal
@@ -7291,34 +7530,34 @@ $jscomp.polyfill = function (e, r, p, m) {
7291
7530
  * @prop {String} secondaryPlaceholder
7292
7531
  * @prop {Object} autocompleteOptions
7293
7532
  */
7294
- _this42.options = $.extend({}, Chips.defaults, options);
7533
+ _this44.options = $.extend({}, Chips.defaults, options);
7295
7534
 
7296
- _this42.$el.addClass('chips input-field');
7297
- _this42.chipsData = [];
7298
- _this42.$chips = $();
7299
- _this42._setupInput();
7300
- _this42.hasAutocomplete = Object.keys(_this42.options.autocompleteOptions).length > 0;
7535
+ _this44.$el.addClass('chips input-field');
7536
+ _this44.chipsData = [];
7537
+ _this44.$chips = $();
7538
+ _this44._setupInput();
7539
+ _this44.hasAutocomplete = Object.keys(_this44.options.autocompleteOptions).length > 0;
7301
7540
 
7302
7541
  // Set input id
7303
- if (!_this42.$input.attr('id')) {
7304
- _this42.$input.attr('id', M.guid());
7542
+ if (!_this44.$input.attr('id')) {
7543
+ _this44.$input.attr('id', M.guid());
7305
7544
  }
7306
7545
 
7307
7546
  // Render initial chips
7308
- if (_this42.options.data.length) {
7309
- _this42.chipsData = _this42.options.data;
7310
- _this42._renderChips(_this42.chipsData);
7547
+ if (_this44.options.data.length) {
7548
+ _this44.chipsData = _this44.options.data;
7549
+ _this44._renderChips(_this44.chipsData);
7311
7550
  }
7312
7551
 
7313
7552
  // Setup autocomplete if needed
7314
- if (_this42.hasAutocomplete) {
7315
- _this42._setupAutocomplete();
7553
+ if (_this44.hasAutocomplete) {
7554
+ _this44._setupAutocomplete();
7316
7555
  }
7317
7556
 
7318
- _this42._setPlaceholder();
7319
- _this42._setupLabel();
7320
- _this42._setupEventHandlers();
7321
- return _this42;
7557
+ _this44._setPlaceholder();
7558
+ _this44._setupLabel();
7559
+ _this44._setupEventHandlers();
7560
+ return _this44;
7322
7561
  }
7323
7562
 
7324
7563
  _createClass(Chips, [{
@@ -7521,14 +7760,14 @@ $jscomp.polyfill = function (e, r, p, m) {
7521
7760
  }, {
7522
7761
  key: "_setupAutocomplete",
7523
7762
  value: function _setupAutocomplete() {
7524
- var _this43 = this;
7763
+ var _this45 = this;
7525
7764
 
7526
7765
  this.options.autocompleteOptions.onAutocomplete = function (val) {
7527
- _this43.addChip({
7766
+ _this45.addChip({
7528
7767
  tag: val
7529
7768
  });
7530
- _this43.$input[0].value = '';
7531
- _this43.$input[0].focus();
7769
+ _this45.$input[0].value = '';
7770
+ _this45.$input[0].focus();
7532
7771
  };
7533
7772
 
7534
7773
  this.autocomplete = M.Autocomplete.init(this.$input[0], this.options.autocompleteOptions);
@@ -7702,7 +7941,9 @@ $jscomp.polyfill = function (e, r, p, m) {
7702
7941
  var index = currChips._selectedChip.index();
7703
7942
  currChips.deleteChip(index);
7704
7943
  currChips._selectedChip = null;
7705
- selectIndex = index - 1;
7944
+
7945
+ // Make sure selectIndex doesn't go negative
7946
+ selectIndex = Math.max(index - 1, 0);
7706
7947
  }
7707
7948
 
7708
7949
  if (currChips.chipsData.length) {
@@ -7821,21 +8062,21 @@ $jscomp.polyfill = function (e, r, p, m) {
7821
8062
  function Pushpin(el, options) {
7822
8063
  _classCallCheck(this, Pushpin);
7823
8064
 
7824
- var _this44 = _possibleConstructorReturn(this, (Pushpin.__proto__ || Object.getPrototypeOf(Pushpin)).call(this, Pushpin, el, options));
8065
+ var _this46 = _possibleConstructorReturn(this, (Pushpin.__proto__ || Object.getPrototypeOf(Pushpin)).call(this, Pushpin, el, options));
7825
8066
 
7826
- _this44.el.M_Pushpin = _this44;
8067
+ _this46.el.M_Pushpin = _this46;
7827
8068
 
7828
8069
  /**
7829
8070
  * Options for the modal
7830
8071
  * @member Pushpin#options
7831
8072
  */
7832
- _this44.options = $.extend({}, Pushpin.defaults, options);
8073
+ _this46.options = $.extend({}, Pushpin.defaults, options);
7833
8074
 
7834
- _this44.originalOffset = _this44.el.offsetTop;
7835
- Pushpin._pushpins.push(_this44);
7836
- _this44._setupEventHandlers();
7837
- _this44._updatePosition();
7838
- return _this44;
8075
+ _this46.originalOffset = _this46.el.offsetTop;
8076
+ Pushpin._pushpins.push(_this46);
8077
+ _this46._setupEventHandlers();
8078
+ _this46._updatePosition();
8079
+ return _this46;
7839
8080
  }
7840
8081
 
7841
8082
  _createClass(Pushpin, [{
@@ -7986,9 +8227,9 @@ $jscomp.polyfill = function (e, r, p, m) {
7986
8227
  function FloatingActionButton(el, options) {
7987
8228
  _classCallCheck(this, FloatingActionButton);
7988
8229
 
7989
- var _this45 = _possibleConstructorReturn(this, (FloatingActionButton.__proto__ || Object.getPrototypeOf(FloatingActionButton)).call(this, FloatingActionButton, el, options));
8230
+ var _this47 = _possibleConstructorReturn(this, (FloatingActionButton.__proto__ || Object.getPrototypeOf(FloatingActionButton)).call(this, FloatingActionButton, el, options));
7990
8231
 
7991
- _this45.el.M_FloatingActionButton = _this45;
8232
+ _this47.el.M_FloatingActionButton = _this47;
7992
8233
 
7993
8234
  /**
7994
8235
  * Options for the fab
@@ -7997,30 +8238,30 @@ $jscomp.polyfill = function (e, r, p, m) {
7997
8238
  * @prop {Boolean} [hoverEnabled=true] - Enable hover vs click
7998
8239
  * @prop {Boolean} [toolbarEnabled=false] - Enable toolbar transition
7999
8240
  */
8000
- _this45.options = $.extend({}, FloatingActionButton.defaults, options);
8001
-
8002
- _this45.isOpen = false;
8003
- _this45.$anchor = _this45.$el.children('a').first();
8004
- _this45.$menu = _this45.$el.children('ul').first();
8005
- _this45.$floatingBtns = _this45.$el.find('ul .btn-floating');
8006
- _this45.$floatingBtnsReverse = _this45.$el.find('ul .btn-floating').reverse();
8007
- _this45.offsetY = 0;
8008
- _this45.offsetX = 0;
8009
- if (_this45.options.direction === 'top') {
8010
- _this45.$el.addClass('direction-top');
8011
- _this45.offsetY = 40;
8012
- } else if (_this45.options.direction === 'right') {
8013
- _this45.$el.addClass('direction-right');
8014
- _this45.offsetX = -40;
8015
- } else if (_this45.options.direction === 'bottom') {
8016
- _this45.$el.addClass('direction-bottom');
8017
- _this45.offsetY = -40;
8241
+ _this47.options = $.extend({}, FloatingActionButton.defaults, options);
8242
+
8243
+ _this47.isOpen = false;
8244
+ _this47.$anchor = _this47.$el.children('a').first();
8245
+ _this47.$menu = _this47.$el.children('ul').first();
8246
+ _this47.$floatingBtns = _this47.$el.find('ul .btn-floating');
8247
+ _this47.$floatingBtnsReverse = _this47.$el.find('ul .btn-floating').reverse();
8248
+ _this47.offsetY = 0;
8249
+ _this47.offsetX = 0;
8250
+ if (_this47.options.direction === 'top') {
8251
+ _this47.$el.addClass('direction-top');
8252
+ _this47.offsetY = 40;
8253
+ } else if (_this47.options.direction === 'right') {
8254
+ _this47.$el.addClass('direction-right');
8255
+ _this47.offsetX = -40;
8256
+ } else if (_this47.options.direction === 'bottom') {
8257
+ _this47.$el.addClass('direction-bottom');
8258
+ _this47.offsetY = -40;
8018
8259
  } else {
8019
- _this45.$el.addClass('direction-left');
8020
- _this45.offsetX = 40;
8260
+ _this47.$el.addClass('direction-left');
8261
+ _this47.offsetX = 40;
8021
8262
  }
8022
- _this45._setupEventHandlers();
8023
- return _this45;
8263
+ _this47._setupEventHandlers();
8264
+ return _this47;
8024
8265
  }
8025
8266
 
8026
8267
  _createClass(FloatingActionButton, [{
@@ -8143,7 +8384,7 @@ $jscomp.polyfill = function (e, r, p, m) {
8143
8384
  }, {
8144
8385
  key: "_animateInFAB",
8145
8386
  value: function _animateInFAB() {
8146
- var _this46 = this;
8387
+ var _this48 = this;
8147
8388
 
8148
8389
  this.$el.addClass('active');
8149
8390
 
@@ -8153,8 +8394,8 @@ $jscomp.polyfill = function (e, r, p, m) {
8153
8394
  targets: el,
8154
8395
  opacity: 1,
8155
8396
  scale: [.4, 1],
8156
- translateY: [_this46.offsetY, 0],
8157
- translateX: [_this46.offsetX, 0],
8397
+ translateY: [_this48.offsetY, 0],
8398
+ translateX: [_this48.offsetX, 0],
8158
8399
  duration: 275,
8159
8400
  delay: time,
8160
8401
  easing: 'easeInOutQuad'
@@ -8170,7 +8411,7 @@ $jscomp.polyfill = function (e, r, p, m) {
8170
8411
  }, {
8171
8412
  key: "_animateOutFAB",
8172
8413
  value: function _animateOutFAB() {
8173
- var _this47 = this;
8414
+ var _this49 = this;
8174
8415
 
8175
8416
  this.$floatingBtnsReverse.each(function (el) {
8176
8417
  anim.remove(el);
@@ -8178,12 +8419,12 @@ $jscomp.polyfill = function (e, r, p, m) {
8178
8419
  targets: el,
8179
8420
  opacity: 0,
8180
8421
  scale: .4,
8181
- translateY: _this47.offsetY,
8182
- translateX: _this47.offsetX,
8422
+ translateY: _this49.offsetY,
8423
+ translateX: _this49.offsetX,
8183
8424
  duration: 175,
8184
8425
  easing: 'easeOutQuad',
8185
8426
  complete: function () {
8186
- _this47.$el.removeClass('active');
8427
+ _this49.$el.removeClass('active');
8187
8428
  }
8188
8429
  });
8189
8430
  });
@@ -8196,7 +8437,7 @@ $jscomp.polyfill = function (e, r, p, m) {
8196
8437
  }, {
8197
8438
  key: "_animateInToolbar",
8198
8439
  value: function _animateInToolbar() {
8199
- var _this48 = this;
8440
+ var _this50 = this;
8200
8441
 
8201
8442
  var scaleFactor = void 0;
8202
8443
  var windowWidth = window.innerWidth;
@@ -8232,18 +8473,18 @@ $jscomp.polyfill = function (e, r, p, m) {
8232
8473
  });
8233
8474
 
8234
8475
  setTimeout(function () {
8235
- _this48.$el.css({
8476
+ _this50.$el.css({
8236
8477
  transform: '',
8237
8478
  transition: 'transform .2s cubic-bezier(0.550, 0.085, 0.680, 0.530), background-color 0s linear .2s'
8238
8479
  });
8239
- _this48.$anchor.css({
8480
+ _this50.$anchor.css({
8240
8481
  overflow: 'visible',
8241
8482
  transform: '',
8242
8483
  transition: 'transform .2s'
8243
8484
  });
8244
8485
 
8245
8486
  setTimeout(function () {
8246
- _this48.$el.css({
8487
+ _this50.$el.css({
8247
8488
  overflow: 'hidden',
8248
8489
  'background-color': fabColor
8249
8490
  });
@@ -8251,14 +8492,14 @@ $jscomp.polyfill = function (e, r, p, m) {
8251
8492
  transform: 'scale(' + scaleFactor + ')',
8252
8493
  transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
8253
8494
  });
8254
- _this48.$menu.children('li').children('a').css({
8495
+ _this50.$menu.children('li').children('a').css({
8255
8496
  opacity: 1
8256
8497
  });
8257
8498
 
8258
8499
  // Scroll to close.
8259
- _this48._handleDocumentClickBound = _this48._handleDocumentClick.bind(_this48);
8260
- window.addEventListener('scroll', _this48._handleCloseBound, true);
8261
- document.body.addEventListener('click', _this48._handleDocumentClickBound, true);
8500
+ _this50._handleDocumentClickBound = _this50._handleDocumentClick.bind(_this50);
8501
+ window.addEventListener('scroll', _this50._handleCloseBound, true);
8502
+ document.body.addEventListener('click', _this50._handleDocumentClickBound, true);
8262
8503
  }, 100);
8263
8504
  }, 0);
8264
8505
  }
@@ -8270,7 +8511,7 @@ $jscomp.polyfill = function (e, r, p, m) {
8270
8511
  }, {
8271
8512
  key: "_animateOutToolbar",
8272
8513
  value: function _animateOutToolbar() {
8273
- var _this49 = this;
8514
+ var _this51 = this;
8274
8515
 
8275
8516
  var windowWidth = window.innerWidth;
8276
8517
  var windowHeight = window.innerHeight;
@@ -8301,26 +8542,26 @@ $jscomp.polyfill = function (e, r, p, m) {
8301
8542
  backdrop.remove();
8302
8543
 
8303
8544
  // Set initial state.
8304
- _this49.$el.css({
8545
+ _this51.$el.css({
8305
8546
  'text-align': '',
8306
8547
  width: '',
8307
8548
  bottom: '',
8308
8549
  left: '',
8309
8550
  overflow: '',
8310
8551
  'background-color': '',
8311
- transform: 'translate3d(' + -_this49.offsetX + 'px,0,0)'
8552
+ transform: 'translate3d(' + -_this51.offsetX + 'px,0,0)'
8312
8553
  });
8313
- _this49.$anchor.css({
8554
+ _this51.$anchor.css({
8314
8555
  overflow: '',
8315
- transform: 'translate3d(0,' + _this49.offsetY + 'px,0)'
8556
+ transform: 'translate3d(0,' + _this51.offsetY + 'px,0)'
8316
8557
  });
8317
8558
 
8318
8559
  setTimeout(function () {
8319
- _this49.$el.css({
8560
+ _this51.$el.css({
8320
8561
  transform: 'translate3d(0,0,0)',
8321
8562
  transition: 'transform .2s'
8322
8563
  });
8323
- _this49.$anchor.css({
8564
+ _this51.$anchor.css({
8324
8565
  transform: 'translate3d(0,0,0)',
8325
8566
  transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
8326
8567
  });
@@ -8411,10 +8652,13 @@ $jscomp.polyfill = function (e, r, p, m) {
8411
8652
  // Specify a DOM element to render the calendar in
8412
8653
  container: null,
8413
8654
 
8655
+ // Show clear button
8656
+ showClearBtn: false,
8657
+
8414
8658
  // internationalization
8415
8659
  i18n: {
8660
+ cancel: 'Cancel',
8416
8661
  clear: 'Clear',
8417
- today: 'Today',
8418
8662
  done: 'Ok',
8419
8663
  previousMonth: '‹',
8420
8664
  nextMonth: '›',
@@ -8452,53 +8696,53 @@ $jscomp.polyfill = function (e, r, p, m) {
8452
8696
  function Datepicker(el, options) {
8453
8697
  _classCallCheck(this, Datepicker);
8454
8698
 
8455
- var _this50 = _possibleConstructorReturn(this, (Datepicker.__proto__ || Object.getPrototypeOf(Datepicker)).call(this, Datepicker, el, options));
8699
+ var _this52 = _possibleConstructorReturn(this, (Datepicker.__proto__ || Object.getPrototypeOf(Datepicker)).call(this, Datepicker, el, options));
8456
8700
 
8457
- _this50.el.M_Datepicker = _this50;
8701
+ _this52.el.M_Datepicker = _this52;
8458
8702
 
8459
- _this50.options = $.extend({}, Datepicker.defaults, options);
8703
+ _this52.options = $.extend({}, Datepicker.defaults, options);
8460
8704
 
8461
8705
  // make sure i18n defaults are not lost when only few i18n option properties are passed
8462
8706
  if (!!options && options.hasOwnProperty('i18n') && typeof options.i18n === 'object') {
8463
- _this50.options.i18n = $.extend({}, Datepicker.defaults.i18n, options.i18n);
8707
+ _this52.options.i18n = $.extend({}, Datepicker.defaults.i18n, options.i18n);
8464
8708
  }
8465
8709
 
8466
8710
  // Remove time component from minDate and maxDate options
8467
- if (_this50.options.minDate) _this50.options.minDate.setHours(0, 0, 0, 0);
8468
- if (_this50.options.maxDate) _this50.options.maxDate.setHours(0, 0, 0, 0);
8711
+ if (_this52.options.minDate) _this52.options.minDate.setHours(0, 0, 0, 0);
8712
+ if (_this52.options.maxDate) _this52.options.maxDate.setHours(0, 0, 0, 0);
8469
8713
 
8470
- _this50.id = M.guid();
8714
+ _this52.id = M.guid();
8471
8715
 
8472
- _this50._setupVariables();
8473
- _this50._insertHTMLIntoDOM();
8474
- _this50._setupModal();
8716
+ _this52._setupVariables();
8717
+ _this52._insertHTMLIntoDOM();
8718
+ _this52._setupModal();
8475
8719
 
8476
- _this50._setupEventHandlers();
8720
+ _this52._setupEventHandlers();
8477
8721
 
8478
- if (!_this50.options.defaultDate) {
8479
- _this50.options.defaultDate = new Date(Date.parse(_this50.el.value));
8480
- _this50.options.setDefaultDate = true;
8722
+ if (!_this52.options.defaultDate) {
8723
+ _this52.options.defaultDate = new Date(Date.parse(_this52.el.value));
8724
+ _this52.options.setDefaultDate = true;
8481
8725
  }
8482
8726
 
8483
- var defDate = _this50.options.defaultDate;
8727
+ var defDate = _this52.options.defaultDate;
8484
8728
 
8485
8729
  if (Datepicker._isDate(defDate)) {
8486
- if (_this50.options.setDefaultDate) {
8487
- _this50.setDate(defDate, true);
8730
+ if (_this52.options.setDefaultDate) {
8731
+ _this52.setDate(defDate, true);
8488
8732
  } else {
8489
- _this50.gotoDate(defDate);
8733
+ _this52.gotoDate(defDate);
8490
8734
  }
8491
8735
  } else {
8492
- _this50.gotoDate(new Date());
8736
+ _this52.gotoDate(new Date());
8493
8737
  }
8494
8738
 
8495
8739
  /**
8496
8740
  * Describes open/close state of datepicker
8497
8741
  * @type {Boolean}
8498
8742
  */
8499
- _this50.isOpen = false;
8743
+ _this52.isOpen = false;
8500
8744
 
8501
- return _this50;
8745
+ return _this52;
8502
8746
  }
8503
8747
 
8504
8748
  _createClass(Datepicker, [{
@@ -8512,18 +8756,34 @@ $jscomp.polyfill = function (e, r, p, m) {
8512
8756
  this._removeEventHandlers();
8513
8757
  this.modal.destroy();
8514
8758
  $(this.modalEl).remove();
8759
+ this.destroySelects();
8515
8760
  this.el.M_Datepicker = undefined;
8516
8761
  }
8762
+ }, {
8763
+ key: "destroySelects",
8764
+ value: function destroySelects() {
8765
+ var oldYearSelect = this.calendarEl.querySelector('.pika-select-year');
8766
+ if (oldYearSelect) {
8767
+ M.FormSelect.getInstance(oldYearSelect).destroy();
8768
+ }
8769
+ var oldMonthSelect = this.calendarEl.querySelector('.pika-select-month');
8770
+ if (oldMonthSelect) {
8771
+ M.FormSelect.getInstance(oldMonthSelect).destroy();
8772
+ }
8773
+ }
8517
8774
  }, {
8518
8775
  key: "_insertHTMLIntoDOM",
8519
8776
  value: function _insertHTMLIntoDOM() {
8520
- this.clearBtn.innerHTML = this.options.i18n.clear;
8521
- this.todayBtn.innerHTML = this.options.i18n.today;
8777
+ if (this.options.showClearBtn) {
8778
+ $(this.clearBtn).css({ visibility: '' });
8779
+ this.clearBtn.innerHTML = this.options.i18n.clear;
8780
+ }
8781
+
8522
8782
  this.doneBtn.innerHTML = this.options.i18n.done;
8783
+ this.cancelBtn.innerHTML = this.options.i18n.cancel;
8523
8784
 
8524
- var containerEl = document.querySelector(this.options.container);
8525
- if (this.options.container && !!containerEl) {
8526
- this.$modalEl.appendTo(containerEl);
8785
+ if (this.options.container) {
8786
+ this.$modalEl.appendTo(this.options.container);
8527
8787
  } else {
8528
8788
  this.$modalEl.insertBefore(this.el);
8529
8789
  }
@@ -8531,19 +8791,19 @@ $jscomp.polyfill = function (e, r, p, m) {
8531
8791
  }, {
8532
8792
  key: "_setupModal",
8533
8793
  value: function _setupModal() {
8534
- var _this51 = this;
8794
+ var _this53 = this;
8535
8795
 
8536
8796
  this.modalEl.id = 'modal-' + this.id;
8537
8797
  this.modal = M.Modal.init(this.modalEl, {
8538
8798
  onCloseEnd: function () {
8539
- _this51.isOpen = false;
8799
+ _this53.isOpen = false;
8540
8800
  }
8541
8801
  });
8542
8802
  }
8543
8803
  }, {
8544
8804
  key: "toString",
8545
8805
  value: function toString(format) {
8546
- var _this52 = this;
8806
+ var _this54 = this;
8547
8807
 
8548
8808
  format = format || this.options.format;
8549
8809
  if (!Datepicker._isDate(this.date)) {
@@ -8552,8 +8812,8 @@ $jscomp.polyfill = function (e, r, p, m) {
8552
8812
 
8553
8813
  var formatArray = format.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g);
8554
8814
  var formattedDate = formatArray.map(function (label) {
8555
- if (_this52.formats[label]) {
8556
- return _this52.formats[label]();
8815
+ if (_this54.formats[label]) {
8816
+ return _this54.formats[label]();
8557
8817
  }
8558
8818
 
8559
8819
  return label;
@@ -8930,15 +9190,7 @@ $jscomp.polyfill = function (e, r, p, m) {
8930
9190
  html += this.renderTitle(this, c, this.calendars[c].year, this.calendars[c].month, this.calendars[0].year, randId) + this.render(this.calendars[c].year, this.calendars[c].month, randId);
8931
9191
  }
8932
9192
 
8933
- // Destroy Materialize Select
8934
- var oldYearSelect = this.calendarEl.querySelector('.pika-select-year');
8935
- if (oldYearSelect) {
8936
- M.FormSelect.getInstance(oldYearSelect).destroy();
8937
- }
8938
- var oldMonthSelect = this.calendarEl.querySelector('.pika-select-month');
8939
- if (oldMonthSelect) {
8940
- M.FormSelect.getInstance(oldMonthSelect).destroy();
8941
- }
9193
+ this.destroySelects();
8942
9194
 
8943
9195
  this.calendarEl.innerHTML = html;
8944
9196
 
@@ -8969,22 +9221,25 @@ $jscomp.polyfill = function (e, r, p, m) {
8969
9221
  this._handleInputChangeBound = this._handleInputChange.bind(this);
8970
9222
  this._handleCalendarClickBound = this._handleCalendarClick.bind(this);
8971
9223
  this._finishSelectionBound = this._finishSelection.bind(this);
8972
- this._handleTodayClickBound = this._handleTodayClick.bind(this);
8973
- this._handleClearClickBound = this._handleClearClick.bind(this);
8974
9224
  this._handleMonthChange = this._handleMonthChange.bind(this);
9225
+ this._closeBound = this.close.bind(this);
8975
9226
 
8976
9227
  this.el.addEventListener('click', this._handleInputClickBound);
8977
9228
  this.el.addEventListener('keydown', this._handleInputKeydownBound);
8978
9229
  this.el.addEventListener('change', this._handleInputChangeBound);
8979
9230
  this.calendarEl.addEventListener('click', this._handleCalendarClickBound);
8980
9231
  this.doneBtn.addEventListener('click', this._finishSelectionBound);
8981
- this.todayBtn.addEventListener('click', this._handleTodayClickBound);
8982
- this.clearBtn.addEventListener('click', this._handleClearClickBound);
9232
+ this.cancelBtn.addEventListener('click', this._closeBound);
9233
+
9234
+ if (this.options.showClearBtn) {
9235
+ this._handleClearClickBound = this._handleClearClick.bind(this);
9236
+ this.clearBtn.addEventListener('click', this._handleClearClickBound);
9237
+ }
8983
9238
  }
8984
9239
  }, {
8985
9240
  key: "_setupVariables",
8986
9241
  value: function _setupVariables() {
8987
- var _this53 = this;
9242
+ var _this55 = this;
8988
9243
 
8989
9244
  this.$modalEl = $(Datepicker._template);
8990
9245
  this.modalEl = this.$modalEl[0];
@@ -8993,43 +9248,45 @@ $jscomp.polyfill = function (e, r, p, m) {
8993
9248
 
8994
9249
  this.yearTextEl = this.modalEl.querySelector('.year-text');
8995
9250
  this.dateTextEl = this.modalEl.querySelector('.date-text');
8996
- this.clearBtn = this.modalEl.querySelector('.datepicker-clear');
8997
- this.todayBtn = this.modalEl.querySelector('.datepicker-today');
9251
+ if (this.options.showClearBtn) {
9252
+ this.clearBtn = this.modalEl.querySelector('.datepicker-clear');
9253
+ }
8998
9254
  this.doneBtn = this.modalEl.querySelector('.datepicker-done');
9255
+ this.cancelBtn = this.modalEl.querySelector('.datepicker-cancel');
8999
9256
 
9000
9257
  this.formats = {
9001
9258
 
9002
9259
  d: function () {
9003
- return _this53.date.getDate();
9260
+ return _this55.date.getDate();
9004
9261
  },
9005
9262
  dd: function () {
9006
- var d = _this53.date.getDate();
9263
+ var d = _this55.date.getDate();
9007
9264
  return (d < 10 ? '0' : '') + d;
9008
9265
  },
9009
9266
  ddd: function () {
9010
- return _this53.options.i18n.weekdaysShort[_this53.date.getDay()];
9267
+ return _this55.options.i18n.weekdaysShort[_this55.date.getDay()];
9011
9268
  },
9012
9269
  dddd: function () {
9013
- return _this53.options.i18n.weekdays[_this53.date.getDay()];
9270
+ return _this55.options.i18n.weekdays[_this55.date.getDay()];
9014
9271
  },
9015
9272
  m: function () {
9016
- return _this53.date.getMonth() + 1;
9273
+ return _this55.date.getMonth() + 1;
9017
9274
  },
9018
9275
  mm: function () {
9019
- var m = _this53.date.getMonth() + 1;
9276
+ var m = _this55.date.getMonth() + 1;
9020
9277
  return (m < 10 ? '0' : '') + m;
9021
9278
  },
9022
9279
  mmm: function () {
9023
- return _this53.options.i18n.monthsShort[_this53.date.getMonth()];
9280
+ return _this55.options.i18n.monthsShort[_this55.date.getMonth()];
9024
9281
  },
9025
9282
  mmmm: function () {
9026
- return _this53.options.i18n.months[_this53.date.getMonth()];
9283
+ return _this55.options.i18n.months[_this55.date.getMonth()];
9027
9284
  },
9028
9285
  yy: function () {
9029
- return ('' + _this53.date.getFullYear()).slice(2);
9286
+ return ('' + _this55.date.getFullYear()).slice(2);
9030
9287
  },
9031
9288
  yyyy: function () {
9032
- return _this53.date.getFullYear();
9289
+ return _this55.date.getFullYear();
9033
9290
  }
9034
9291
  };
9035
9292
  }
@@ -9088,13 +9345,6 @@ $jscomp.polyfill = function (e, r, p, m) {
9088
9345
  // this._c = true;
9089
9346
  // }
9090
9347
  }
9091
- }, {
9092
- key: "_handleTodayClick",
9093
- value: function _handleTodayClick() {
9094
- this.date = new Date();
9095
- this.setInputValue();
9096
- this.close();
9097
- }
9098
9348
  }, {
9099
9349
  key: "_handleClearClick",
9100
9350
  value: function _handleClearClick() {
@@ -9284,7 +9534,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9284
9534
  return Datepicker;
9285
9535
  }(Component);
9286
9536
 
9287
- Datepicker._template = ['<div class= "modal datepicker-modal">', '<div class="modal-content datepicker-container">', '<div class="datepicker-date-display">', '<span class="year-text"></span>', '<span class="date-text"></span>', '</div>', '<div class="datepicker-calendar-container">', '<div class="pika-single"></div>', '<div class="datepicker-footer">', '<button class="btn-flat datepicker-clear waves-effect" type="button"></button>', '<div class="confirmation-btns">', '<button class="btn-flat datepicker-today waves-effect" type="button"></button>', '<button class="btn-flat datepicker-done waves-effect" type="button"></button>', '</div>', '</div>', '</div>', '</div>', '</div>'].join('');
9537
+ Datepicker._template = ['<div class= "modal datepicker-modal">', '<div class="modal-content datepicker-container">', '<div class="datepicker-date-display">', '<span class="year-text"></span>', '<span class="date-text"></span>', '</div>', '<div class="datepicker-calendar-container">', '<div class="pika-single"></div>', '<div class="datepicker-footer">', '<button class="btn-flat datepicker-clear waves-effect" style="visibility: hidden;" type="button"></button>', '<div class="confirmation-btns">', '<button class="btn-flat datepicker-cancel waves-effect" type="button"></button>', '<button class="btn-flat datepicker-done waves-effect" type="button"></button>', '</div>', '</div>', '</div>', '</div>', '</div>'].join('');
9288
9538
 
9289
9539
  M.Datepicker = Datepicker;
9290
9540
 
@@ -9303,13 +9553,14 @@ $jscomp.polyfill = function (e, r, p, m) {
9303
9553
  duration: 350,
9304
9554
  container: null,
9305
9555
  defaultTime: 'now', // default time, 'now' or '13:14' e.g.
9306
- fromnow: 0, // Millisecond offset from the defaultTime
9556
+ fromNow: 0, // Millisecond offset from the defaultTime
9557
+ showClearBtn: false,
9307
9558
 
9308
9559
  // internationalization
9309
9560
  i18n: {
9310
- done: 'Ok',
9561
+ cancel: 'Cancel',
9311
9562
  clear: 'Clear',
9312
- cancel: 'Cancel'
9563
+ done: 'Ok'
9313
9564
  },
9314
9565
 
9315
9566
  autoClose: false, // auto close when minute is selected
@@ -9328,21 +9579,21 @@ $jscomp.polyfill = function (e, r, p, m) {
9328
9579
  function Timepicker(el, options) {
9329
9580
  _classCallCheck(this, Timepicker);
9330
9581
 
9331
- var _this54 = _possibleConstructorReturn(this, (Timepicker.__proto__ || Object.getPrototypeOf(Timepicker)).call(this, Timepicker, el, options));
9582
+ var _this56 = _possibleConstructorReturn(this, (Timepicker.__proto__ || Object.getPrototypeOf(Timepicker)).call(this, Timepicker, el, options));
9332
9583
 
9333
- _this54.el.M_Timepicker = _this54;
9584
+ _this56.el.M_Timepicker = _this56;
9334
9585
 
9335
- _this54.options = $.extend({}, Timepicker.defaults, options);
9586
+ _this56.options = $.extend({}, Timepicker.defaults, options);
9336
9587
 
9337
- _this54.id = M.guid();
9338
- _this54._insertHTMLIntoDOM();
9339
- _this54._setupModal();
9340
- _this54._setupVariables();
9341
- _this54._setupEventHandlers();
9588
+ _this56.id = M.guid();
9589
+ _this56._insertHTMLIntoDOM();
9590
+ _this56._setupModal();
9591
+ _this56._setupVariables();
9592
+ _this56._setupEventHandlers();
9342
9593
 
9343
- _this54._clockSetup();
9344
- _this54._pickerSetup();
9345
- return _this54;
9594
+ _this56._clockSetup();
9595
+ _this56._pickerSetup();
9596
+ return _this56;
9346
9597
  }
9347
9598
 
9348
9599
  _createClass(Timepicker, [{
@@ -9437,7 +9688,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9437
9688
  }, {
9438
9689
  key: "_handleDocumentClickEnd",
9439
9690
  value: function _handleDocumentClickEnd(e) {
9440
- var _this55 = this;
9691
+ var _this57 = this;
9441
9692
 
9442
9693
  e.preventDefault();
9443
9694
  document.removeEventListener('mouseup', this._handleDocumentClickEndBound);
@@ -9454,7 +9705,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9454
9705
  } else if (this.options.autoClose) {
9455
9706
  $(this.minutesView).addClass('timepicker-dial-out');
9456
9707
  setTimeout(function () {
9457
- _this55.done();
9708
+ _this57.done();
9458
9709
  }, this.options.duration / 2);
9459
9710
  }
9460
9711
 
@@ -9480,11 +9731,11 @@ $jscomp.polyfill = function (e, r, p, m) {
9480
9731
  }, {
9481
9732
  key: "_setupModal",
9482
9733
  value: function _setupModal() {
9483
- var _this56 = this;
9734
+ var _this58 = this;
9484
9735
 
9485
9736
  this.modal = M.Modal.init(this.modalEl, {
9486
9737
  onCloseEnd: function () {
9487
- _this56.isOpen = false;
9738
+ _this58.isOpen = false;
9488
9739
  }
9489
9740
  });
9490
9741
  }
@@ -9508,7 +9759,11 @@ $jscomp.polyfill = function (e, r, p, m) {
9508
9759
  }, {
9509
9760
  key: "_pickerSetup",
9510
9761
  value: function _pickerSetup() {
9511
- $('<button class="btn-flat timepicker-clear waves-effect" type="button" tabindex="' + (this.options.twelveHour ? '3' : '1') + '">' + this.options.i18n.clear + '</button>').appendTo(this.footer).on('click', this.clear.bind(this));
9762
+
9763
+ var $clearBtn = $('<button class="btn-flat timepicker-clear waves-effect" style="visibility: hidden;" type="button" tabindex="' + (this.options.twelveHour ? '3' : '1') + '">' + this.options.i18n.clear + '</button>').appendTo(this.footer).on('click', this.clear.bind(this));
9764
+ if (this.options.showClearBtn) {
9765
+ $clearBtn.css({ visibility: '' });
9766
+ }
9512
9767
 
9513
9768
  var confirmationBtnsContainer = $('<div class="confirmation-btns"></div>');
9514
9769
  $('<button class="btn-flat timepicker-close waves-effect" type="button" tabindex="' + (this.options.twelveHour ? '3' : '1') + '">' + this.options.i18n.cancel + '</button>').appendTo(confirmationBtnsContainer).on('click', this.close.bind(this));
@@ -9644,7 +9899,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9644
9899
  value[1] = value[1].replace("AM", "").replace("PM", "");
9645
9900
  }
9646
9901
  if (value[0] === 'now') {
9647
- var now = new Date(+new Date() + this.options.fromnow);
9902
+ var now = new Date(+new Date() + this.options.fromNow);
9648
9903
  value = [now.getHours(), now.getMinutes()];
9649
9904
  if (this.options.twelveHour) {
9650
9905
  this.amOrPm = value[0] >= 12 && value[0] < 24 ? 'PM' : 'AM';
@@ -9710,7 +9965,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9710
9965
  }, {
9711
9966
  key: "setHand",
9712
9967
  value: function setHand(x, y, roundBy5) {
9713
- var _this57 = this;
9968
+ var _this59 = this;
9714
9969
 
9715
9970
  var radian = Math.atan2(x, -y),
9716
9971
  isHours = this.currentView === 'hours',
@@ -9765,7 +10020,7 @@ $jscomp.polyfill = function (e, r, p, m) {
9765
10020
  if (!this.vibrateTimer) {
9766
10021
  navigator[this.vibrate](10);
9767
10022
  this.vibrateTimer = setTimeout(function () {
9768
- _this57.vibrateTimer = null;
10023
+ _this59.vibrateTimer = null;
9769
10024
  }, 100);
9770
10025
  }
9771
10026
  }
@@ -9929,20 +10184,20 @@ $jscomp.polyfill = function (e, r, p, m) {
9929
10184
  function CharacterCounter(el, options) {
9930
10185
  _classCallCheck(this, CharacterCounter);
9931
10186
 
9932
- var _this58 = _possibleConstructorReturn(this, (CharacterCounter.__proto__ || Object.getPrototypeOf(CharacterCounter)).call(this, CharacterCounter, el, options));
10187
+ var _this60 = _possibleConstructorReturn(this, (CharacterCounter.__proto__ || Object.getPrototypeOf(CharacterCounter)).call(this, CharacterCounter, el, options));
9933
10188
 
9934
- _this58.el.M_CharacterCounter = _this58;
10189
+ _this60.el.M_CharacterCounter = _this60;
9935
10190
 
9936
10191
  /**
9937
10192
  * Options for the character counter
9938
10193
  */
9939
- _this58.options = $.extend({}, CharacterCounter.defaults, options);
10194
+ _this60.options = $.extend({}, CharacterCounter.defaults, options);
9940
10195
 
9941
- _this58.isInvalid = false;
9942
- _this58.isValidLength = false;
9943
- _this58._setupCounter();
9944
- _this58._setupEventHandlers();
9945
- return _this58;
10196
+ _this60.isInvalid = false;
10197
+ _this60.isValidLength = false;
10198
+ _this60._setupCounter();
10199
+ _this60._setupEventHandlers();
10200
+ return _this60;
9946
10201
  }
9947
10202
 
9948
10203
  _createClass(CharacterCounter, [{
@@ -10085,6 +10340,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10085
10340
  dist: -100, // zoom scale TODO: make this more intuitive as an option
10086
10341
  shift: 0, // spacing for center image
10087
10342
  padding: 0, // Padding between non center items
10343
+ numVisible: 5, // Number of visible items in carousel
10088
10344
  fullWidth: false, // Change to full width styles
10089
10345
  indicators: false, // Toggle indicators
10090
10346
  noWrap: false, // Don't wrap around and cycle through items.
@@ -10108,54 +10364,55 @@ $jscomp.polyfill = function (e, r, p, m) {
10108
10364
  function Carousel(el, options) {
10109
10365
  _classCallCheck(this, Carousel);
10110
10366
 
10111
- var _this59 = _possibleConstructorReturn(this, (Carousel.__proto__ || Object.getPrototypeOf(Carousel)).call(this, Carousel, el, options));
10367
+ var _this61 = _possibleConstructorReturn(this, (Carousel.__proto__ || Object.getPrototypeOf(Carousel)).call(this, Carousel, el, options));
10112
10368
 
10113
- _this59.el.M_Carousel = _this59;
10369
+ _this61.el.M_Carousel = _this61;
10114
10370
 
10115
10371
  /**
10116
10372
  * Options for the carousel
10117
10373
  * @member Carousel#options
10118
10374
  * @prop {Number} duration
10119
10375
  * @prop {Number} dist
10120
- * @prop {number} shift
10121
- * @prop {number} padding
10376
+ * @prop {Number} shift
10377
+ * @prop {Number} padding
10378
+ * @prop {Number} numVisible
10122
10379
  * @prop {Boolean} fullWidth
10123
10380
  * @prop {Boolean} indicators
10124
10381
  * @prop {Boolean} noWrap
10125
10382
  * @prop {Function} onCycleTo
10126
10383
  */
10127
- _this59.options = $.extend({}, Carousel.defaults, options);
10384
+ _this61.options = $.extend({}, Carousel.defaults, options);
10128
10385
 
10129
10386
  // Setup
10130
- _this59.hasMultipleSlides = _this59.$el.find('.carousel-item').length > 1;
10131
- _this59.showIndicators = _this59.options.indicators && _this59.hasMultipleSlides;
10132
- _this59.noWrap = _this59.options.noWrap || !_this59.hasMultipleSlides;
10133
- _this59.pressed = false;
10134
- _this59.dragged = false;
10135
- _this59.offset = _this59.target = 0;
10136
- _this59.images = [];
10137
- _this59.itemWidth = _this59.$el.find('.carousel-item').first().innerWidth();
10138
- _this59.itemHeight = _this59.$el.find('.carousel-item').first().innerHeight();
10139
- _this59.dim = _this59.itemWidth * 2 + _this59.options.padding || 1; // Make sure dim is non zero for divisions.
10140
- _this59._autoScrollBound = _this59._autoScroll.bind(_this59);
10141
- _this59._trackBound = _this59._track.bind(_this59);
10387
+ _this61.hasMultipleSlides = _this61.$el.find('.carousel-item').length > 1;
10388
+ _this61.showIndicators = _this61.options.indicators && _this61.hasMultipleSlides;
10389
+ _this61.noWrap = _this61.options.noWrap || !_this61.hasMultipleSlides;
10390
+ _this61.pressed = false;
10391
+ _this61.dragged = false;
10392
+ _this61.offset = _this61.target = 0;
10393
+ _this61.images = [];
10394
+ _this61.itemWidth = _this61.$el.find('.carousel-item').first().innerWidth();
10395
+ _this61.itemHeight = _this61.$el.find('.carousel-item').first().innerHeight();
10396
+ _this61.dim = _this61.itemWidth * 2 + _this61.options.padding || 1; // Make sure dim is non zero for divisions.
10397
+ _this61._autoScrollBound = _this61._autoScroll.bind(_this61);
10398
+ _this61._trackBound = _this61._track.bind(_this61);
10142
10399
 
10143
10400
  // Full Width carousel setup
10144
- if (_this59.options.fullWidth) {
10145
- _this59.options.dist = 0;
10146
- _this59._setCarouselHeight();
10401
+ if (_this61.options.fullWidth) {
10402
+ _this61.options.dist = 0;
10403
+ _this61._setCarouselHeight();
10147
10404
 
10148
10405
  // Offset fixed items when indicators.
10149
- if (_this59.showIndicators) {
10150
- _this59.$el.find('.carousel-fixed-item').addClass('with-indicators');
10406
+ if (_this61.showIndicators) {
10407
+ _this61.$el.find('.carousel-fixed-item').addClass('with-indicators');
10151
10408
  }
10152
10409
  }
10153
10410
 
10154
10411
  // Iterate through slides
10155
- _this59.$indicators = $('<ul class="indicators"></ul>');
10156
- _this59.$el.find('.carousel-item').each(function (el, i) {
10157
- _this59.images.push(el);
10158
- if (_this59.showIndicators) {
10412
+ _this61.$indicators = $('<ul class="indicators"></ul>');
10413
+ _this61.$el.find('.carousel-item').each(function (el, i) {
10414
+ _this61.images.push(el);
10415
+ if (_this61.showIndicators) {
10159
10416
  var $indicator = $('<li class="indicator-item"></li>');
10160
10417
 
10161
10418
  // Add active to first by default.
@@ -10163,28 +10420,31 @@ $jscomp.polyfill = function (e, r, p, m) {
10163
10420
  $indicator[0].classList.add('active');
10164
10421
  }
10165
10422
 
10166
- _this59.$indicators.append($indicator);
10423
+ _this61.$indicators.append($indicator);
10167
10424
  }
10168
10425
  });
10169
- if (_this59.showIndicators) {
10170
- _this59.$el.append(_this59.$indicators);
10426
+ if (_this61.showIndicators) {
10427
+ _this61.$el.append(_this61.$indicators);
10171
10428
  }
10172
- _this59.count = _this59.images.length;
10429
+ _this61.count = _this61.images.length;
10430
+
10431
+ // Cap numVisible at count
10432
+ _this61.options.numVisible = Math.min(_this61.count, _this61.options.numVisible);
10173
10433
 
10174
10434
  // Setup cross browser string
10175
- _this59.xform = 'transform';
10435
+ _this61.xform = 'transform';
10176
10436
  ['webkit', 'Moz', 'O', 'ms'].every(function (prefix) {
10177
10437
  var e = prefix + 'Transform';
10178
10438
  if (typeof document.body.style[e] !== 'undefined') {
10179
- _this59.xform = e;
10439
+ _this61.xform = e;
10180
10440
  return false;
10181
10441
  }
10182
10442
  return true;
10183
10443
  });
10184
10444
 
10185
- _this59._setupEventHandlers();
10186
- _this59._scroll(_this59.offset);
10187
- return _this59;
10445
+ _this61._setupEventHandlers();
10446
+ _this61._scroll(_this61.offset);
10447
+ return _this61;
10188
10448
  }
10189
10449
 
10190
10450
  _createClass(Carousel, [{
@@ -10206,7 +10466,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10206
10466
  }, {
10207
10467
  key: "_setupEventHandlers",
10208
10468
  value: function _setupEventHandlers() {
10209
- var _this60 = this;
10469
+ var _this62 = this;
10210
10470
 
10211
10471
  this._handleCarouselTapBound = this._handleCarouselTap.bind(this);
10212
10472
  this._handleCarouselDragBound = this._handleCarouselDrag.bind(this);
@@ -10228,7 +10488,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10228
10488
  if (this.showIndicators && this.$indicators) {
10229
10489
  this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
10230
10490
  this.$indicators.find('.indicator-item').each(function (el, i) {
10231
- el.addEventListener('click', _this60._handleIndicatorClickBound);
10491
+ el.addEventListener('click', _this62._handleIndicatorClickBound);
10232
10492
  });
10233
10493
  }
10234
10494
 
@@ -10246,7 +10506,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10246
10506
  }, {
10247
10507
  key: "_removeEventHandlers",
10248
10508
  value: function _removeEventHandlers() {
10249
- var _this61 = this;
10509
+ var _this63 = this;
10250
10510
 
10251
10511
  if (typeof window.ontouchstart !== 'undefined') {
10252
10512
  this.el.removeEventListener('touchstart', this._handleCarouselTapBound);
@@ -10261,7 +10521,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10261
10521
 
10262
10522
  if (this.showIndicators && this.$indicators) {
10263
10523
  this.$indicators.find('.indicator-item').each(function (el, i) {
10264
- el.removeEventListener('click', _this61._handleIndicatorClickBound);
10524
+ el.removeEventListener('click', _this63._handleIndicatorClickBound);
10265
10525
  });
10266
10526
  }
10267
10527
 
@@ -10447,7 +10707,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10447
10707
  }, {
10448
10708
  key: "_setCarouselHeight",
10449
10709
  value: function _setCarouselHeight(imageOnly) {
10450
- var _this62 = this;
10710
+ var _this64 = this;
10451
10711
 
10452
10712
  var firstSlide = this.$el.find('.carousel-item.active').length ? this.$el.find('.carousel-item.active').first() : this.$el.find('.carousel-item').first();
10453
10713
  var firstImage = firstSlide.find('img').first();
@@ -10467,7 +10727,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10467
10727
  } else {
10468
10728
  // Get height when image is loaded normally
10469
10729
  firstImage.one('load', function (el, i) {
10470
- _this62.$el.css('height', el.offsetHeight + 'px');
10730
+ _this64.$el.css('height', el.offsetHeight + 'px');
10471
10731
  });
10472
10732
  }
10473
10733
  } else if (!imageOnly) {
@@ -10573,7 +10833,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10573
10833
  }, {
10574
10834
  key: "_scroll",
10575
10835
  value: function _scroll(x) {
10576
- var _this63 = this;
10836
+ var _this65 = this;
10577
10837
 
10578
10838
  // Track scrolling state
10579
10839
  if (!this.$el.hasClass('scrolling')) {
@@ -10583,7 +10843,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10583
10843
  window.clearTimeout(this.scrollingTimeout);
10584
10844
  }
10585
10845
  this.scrollingTimeout = window.setTimeout(function () {
10586
- _this63.$el.removeClass('scrolling');
10846
+ _this65.$el.removeClass('scrolling');
10587
10847
  }, this.options.duration);
10588
10848
 
10589
10849
  // Start actual scroll
@@ -10595,8 +10855,10 @@ $jscomp.polyfill = function (e, r, p, m) {
10595
10855
  el = void 0,
10596
10856
  alignment = void 0,
10597
10857
  zTranslation = void 0,
10598
- tweenedOpacity = void 0;
10858
+ tweenedOpacity = void 0,
10859
+ centerTweenedOpacity = void 0;
10599
10860
  var lastCenter = this.center;
10861
+ var numVisibleOffset = 1 / this.options.numVisible;
10600
10862
 
10601
10863
  this.offset = typeof x === 'number' ? x : this.offset;
10602
10864
  this.center = Math.floor((this.offset + this.dim / 2) / this.dim);
@@ -10605,11 +10867,13 @@ $jscomp.polyfill = function (e, r, p, m) {
10605
10867
  tween = -dir * delta * 2 / this.dim;
10606
10868
  half = this.count >> 1;
10607
10869
 
10608
- if (!this.options.fullWidth) {
10870
+ if (this.options.fullWidth) {
10871
+ alignment = 'translateX(0)';
10872
+ centerTweenedOpacity = 1;
10873
+ } else {
10609
10874
  alignment = 'translateX(' + (this.el.clientWidth - this.itemWidth) / 2 + 'px) ';
10610
10875
  alignment += 'translateY(' + (this.el.clientHeight - this.itemHeight) / 2 + 'px)';
10611
- } else {
10612
- alignment = 'translateX(0)';
10876
+ centerTweenedOpacity = 1 - numVisibleOffset * tween;
10613
10877
  }
10614
10878
 
10615
10879
  // Set indicator active
@@ -10632,15 +10896,8 @@ $jscomp.polyfill = function (e, r, p, m) {
10632
10896
  this.$el.find('.carousel-item').removeClass('active');
10633
10897
  el.classList.add('active');
10634
10898
  }
10635
- el.style[this.xform] = alignment + ' translateX(' + -delta / 2 + 'px)' + ' translateX(' + dir * this.options.shift * tween * i + 'px)' + ' translateZ(' + this.options.dist * tween + 'px)';
10636
- el.style.zIndex = 0;
10637
- if (this.options.fullWidth) {
10638
- tweenedOpacity = 1;
10639
- } else {
10640
- tweenedOpacity = 1 - 0.2 * tween;
10641
- }
10642
- el.style.opacity = tweenedOpacity;
10643
- el.style.visibility = 'visible';
10899
+ var transformString = alignment + ' translateX(' + -delta / 2 + 'px)' + ' translateX(' + dir * this.options.shift * tween * i + 'px)' + ' translateZ(' + this.options.dist * tween + 'px)';
10900
+ this._updateItemStyle(el, centerTweenedOpacity, 0, transformString);
10644
10901
  }
10645
10902
 
10646
10903
  for (i = 1; i <= half; ++i) {
@@ -10650,15 +10907,13 @@ $jscomp.polyfill = function (e, r, p, m) {
10650
10907
  tweenedOpacity = i === half && delta < 0 ? 1 - tween : 1;
10651
10908
  } else {
10652
10909
  zTranslation = this.options.dist * (i * 2 + tween * dir);
10653
- tweenedOpacity = 1 - 0.2 * (i * 2 + tween * dir);
10910
+ tweenedOpacity = 1 - numVisibleOffset * (i * 2 + tween * dir);
10654
10911
  }
10655
10912
  // Don't show wrapped items.
10656
10913
  if (!this.noWrap || this.center + i < this.count) {
10657
10914
  el = this.images[this._wrap(this.center + i)];
10658
- el.style[this.xform] = alignment + ' translateX(' + (this.options.shift + (this.dim * i - delta) / 2) + 'px)' + ' translateZ(' + zTranslation + 'px)';
10659
- el.style.zIndex = -i;
10660
- el.style.opacity = tweenedOpacity;
10661
- el.style.visibility = 'visible';
10915
+ var _transformString = alignment + ' translateX(' + (this.options.shift + (this.dim * i - delta) / 2) + 'px)' + ' translateZ(' + zTranslation + 'px)';
10916
+ this._updateItemStyle(el, tweenedOpacity, -i, _transformString);
10662
10917
  }
10663
10918
 
10664
10919
  // left side
@@ -10667,15 +10922,13 @@ $jscomp.polyfill = function (e, r, p, m) {
10667
10922
  tweenedOpacity = i === half && delta > 0 ? 1 - tween : 1;
10668
10923
  } else {
10669
10924
  zTranslation = this.options.dist * (i * 2 - tween * dir);
10670
- tweenedOpacity = 1 - 0.2 * (i * 2 - tween * dir);
10925
+ tweenedOpacity = 1 - numVisibleOffset * (i * 2 - tween * dir);
10671
10926
  }
10672
10927
  // Don't show wrapped items.
10673
10928
  if (!this.noWrap || this.center - i >= 0) {
10674
10929
  el = this.images[this._wrap(this.center - i)];
10675
- el.style[this.xform] = alignment + ' translateX(' + (-this.options.shift + (-this.dim * i - delta) / 2) + 'px)' + ' translateZ(' + zTranslation + 'px)';
10676
- el.style.zIndex = -i;
10677
- el.style.opacity = tweenedOpacity;
10678
- el.style.visibility = 'visible';
10930
+ var _transformString2 = alignment + ' translateX(' + (-this.options.shift + (-this.dim * i - delta) / 2) + 'px)' + ' translateZ(' + zTranslation + 'px)';
10931
+ this._updateItemStyle(el, tweenedOpacity, -i, _transformString2);
10679
10932
  }
10680
10933
  }
10681
10934
 
@@ -10683,15 +10936,8 @@ $jscomp.polyfill = function (e, r, p, m) {
10683
10936
  // Don't show wrapped items.
10684
10937
  if (!this.noWrap || this.center >= 0 && this.center < this.count) {
10685
10938
  el = this.images[this._wrap(this.center)];
10686
- el.style[this.xform] = alignment + ' translateX(' + -delta / 2 + 'px)' + ' translateX(' + dir * this.options.shift * tween + 'px)' + ' translateZ(' + this.options.dist * tween + 'px)';
10687
- el.style.zIndex = 0;
10688
- if (this.options.fullWidth) {
10689
- tweenedOpacity = 1;
10690
- } else {
10691
- tweenedOpacity = 1 - 0.2 * tween;
10692
- }
10693
- el.style.opacity = tweenedOpacity;
10694
- el.style.visibility = 'visible';
10939
+ var _transformString3 = alignment + ' translateX(' + -delta / 2 + 'px)' + ' translateX(' + dir * this.options.shift * tween + 'px)' + ' translateZ(' + this.options.dist * tween + 'px)';
10940
+ this._updateItemStyle(el, centerTweenedOpacity, 0, _transformString3);
10695
10941
  }
10696
10942
 
10697
10943
  // onCycleTo callback
@@ -10707,6 +10953,23 @@ $jscomp.polyfill = function (e, r, p, m) {
10707
10953
  }
10708
10954
  }
10709
10955
 
10956
+ /**
10957
+ * Cycle to target
10958
+ * @param {Element} el
10959
+ * @param {Number} opacity
10960
+ * @param {Number} zIndex
10961
+ * @param {String} transform
10962
+ */
10963
+
10964
+ }, {
10965
+ key: "_updateItemStyle",
10966
+ value: function _updateItemStyle(el, opacity, zIndex, transform) {
10967
+ el.style[this.xform] = transform;
10968
+ el.style.zIndex = zIndex;
10969
+ el.style.opacity = opacity;
10970
+ el.style.visibility = 'visible';
10971
+ }
10972
+
10710
10973
  /**
10711
10974
  * Cycle to target
10712
10975
  * @param {Number} n
@@ -10869,42 +11132,42 @@ $jscomp.polyfill = function (e, r, p, m) {
10869
11132
  *
10870
11133
  */
10871
11134
 
10872
- var FeatureDiscovery = function (_Component19) {
10873
- _inherits(FeatureDiscovery, _Component19);
11135
+ var TapTarget = function (_Component19) {
11136
+ _inherits(TapTarget, _Component19);
10874
11137
 
10875
11138
  /**
10876
- * Construct FeatureDiscovery instance
11139
+ * Construct TapTarget instance
10877
11140
  * @constructor
10878
11141
  * @param {Element} el
10879
11142
  * @param {Object} options
10880
11143
  */
10881
- function FeatureDiscovery(el, options) {
10882
- _classCallCheck(this, FeatureDiscovery);
11144
+ function TapTarget(el, options) {
11145
+ _classCallCheck(this, TapTarget);
10883
11146
 
10884
- var _this64 = _possibleConstructorReturn(this, (FeatureDiscovery.__proto__ || Object.getPrototypeOf(FeatureDiscovery)).call(this, FeatureDiscovery, el, options));
11147
+ var _this66 = _possibleConstructorReturn(this, (TapTarget.__proto__ || Object.getPrototypeOf(TapTarget)).call(this, TapTarget, el, options));
10885
11148
 
10886
- _this64.el.M_FeatureDiscovery = _this64;
11149
+ _this66.el.M_TapTarget = _this66;
10887
11150
 
10888
11151
  /**
10889
11152
  * Options for the select
10890
- * @member FeatureDiscovery#options
11153
+ * @member TapTarget#options
10891
11154
  * @prop {Function} onOpen - Callback function called when feature discovery is opened
10892
11155
  * @prop {Function} onClose - Callback function called when feature discovery is closed
10893
11156
  */
10894
- _this64.options = $.extend({}, FeatureDiscovery.defaults, options);
11157
+ _this66.options = $.extend({}, TapTarget.defaults, options);
10895
11158
 
10896
- _this64.isOpen = false;
11159
+ _this66.isOpen = false;
10897
11160
 
10898
11161
  // setup
10899
- _this64.$origin = $('#' + _this64.$el.attr('data-target'));
10900
- _this64._setup();
11162
+ _this66.$origin = $('#' + _this66.$el.attr('data-target'));
11163
+ _this66._setup();
10901
11164
 
10902
- _this64._calculatePositioning();
10903
- _this64._setupEventHandlers();
10904
- return _this64;
11165
+ _this66._calculatePositioning();
11166
+ _this66._setupEventHandlers();
11167
+ return _this66;
10905
11168
  }
10906
11169
 
10907
- _createClass(FeatureDiscovery, [{
11170
+ _createClass(TapTarget, [{
10908
11171
  key: "destroy",
10909
11172
 
10910
11173
 
@@ -10913,7 +11176,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10913
11176
  */
10914
11177
  value: function destroy() {
10915
11178
  this._removeEventHandlers();
10916
- this.el.FeatureDiscovery = undefined;
11179
+ this.el.TapTarget = undefined;
10917
11180
  }
10918
11181
 
10919
11182
  /**
@@ -10998,7 +11261,7 @@ $jscomp.polyfill = function (e, r, p, m) {
10998
11261
  }
10999
11262
 
11000
11263
  /**
11001
- * Setup feature discovery
11264
+ * Setup Tap Target
11002
11265
  */
11003
11266
 
11004
11267
  }, {
@@ -11134,7 +11397,7 @@ $jscomp.polyfill = function (e, r, p, m) {
11134
11397
  }
11135
11398
 
11136
11399
  /**
11137
- * Open Feature Discovery
11400
+ * Open TapTarget
11138
11401
  */
11139
11402
 
11140
11403
  }, {
@@ -11157,7 +11420,7 @@ $jscomp.polyfill = function (e, r, p, m) {
11157
11420
  }
11158
11421
 
11159
11422
  /**
11160
- * Close Feature Discovery
11423
+ * Close Tap Target
11161
11424
  */
11162
11425
 
11163
11426
  }, {
@@ -11181,7 +11444,7 @@ $jscomp.polyfill = function (e, r, p, m) {
11181
11444
  }], [{
11182
11445
  key: "init",
11183
11446
  value: function init(els, options) {
11184
- return _get(FeatureDiscovery.__proto__ || Object.getPrototypeOf(FeatureDiscovery), "init", this).call(this, this, els, options);
11447
+ return _get(TapTarget.__proto__ || Object.getPrototypeOf(TapTarget), "init", this).call(this, this, els, options);
11185
11448
  }
11186
11449
 
11187
11450
  /**
@@ -11192,7 +11455,7 @@ $jscomp.polyfill = function (e, r, p, m) {
11192
11455
  key: "getInstance",
11193
11456
  value: function getInstance(el) {
11194
11457
  var domElem = !!el.jquery ? el[0] : el;
11195
- return domElem.M_FeatureDiscovery;
11458
+ return domElem.M_TapTarget;
11196
11459
  }
11197
11460
  }, {
11198
11461
  key: "defaults",
@@ -11201,13 +11464,13 @@ $jscomp.polyfill = function (e, r, p, m) {
11201
11464
  }
11202
11465
  }]);
11203
11466
 
11204
- return FeatureDiscovery;
11467
+ return TapTarget;
11205
11468
  }(Component);
11206
11469
 
11207
- M.FeatureDiscovery = FeatureDiscovery;
11470
+ M.TapTarget = TapTarget;
11208
11471
 
11209
11472
  if (M.jQueryLoaded) {
11210
- M.initializeJqueryWrapper(FeatureDiscovery, 'featureDiscovery', 'M_FeatureDiscovery');
11473
+ M.initializeJqueryWrapper(TapTarget, 'tapTarget', 'M_TapTarget');
11211
11474
  }
11212
11475
  })(cash);
11213
11476
  ;(function ($) {
@@ -11236,30 +11499,30 @@ $jscomp.polyfill = function (e, r, p, m) {
11236
11499
  _classCallCheck(this, FormSelect);
11237
11500
 
11238
11501
  // Don't init if browser default version
11239
- var _this65 = _possibleConstructorReturn(this, (FormSelect.__proto__ || Object.getPrototypeOf(FormSelect)).call(this, FormSelect, el, options));
11502
+ var _this67 = _possibleConstructorReturn(this, (FormSelect.__proto__ || Object.getPrototypeOf(FormSelect)).call(this, FormSelect, el, options));
11240
11503
 
11241
- if (_this65.$el.hasClass('browser-default')) {
11242
- return _possibleConstructorReturn(_this65);
11504
+ if (_this67.$el.hasClass('browser-default')) {
11505
+ return _possibleConstructorReturn(_this67);
11243
11506
  }
11244
11507
 
11245
- _this65.el.M_FormSelect = _this65;
11508
+ _this67.el.M_FormSelect = _this67;
11246
11509
 
11247
11510
  /**
11248
11511
  * Options for the select
11249
11512
  * @member FormSelect#options
11250
11513
  */
11251
- _this65.options = $.extend({}, FormSelect.defaults, options);
11514
+ _this67.options = $.extend({}, FormSelect.defaults, options);
11252
11515
 
11253
- _this65.isMultiple = _this65.$el.prop('multiple');
11516
+ _this67.isMultiple = _this67.$el.prop('multiple');
11254
11517
 
11255
11518
  // Setup
11256
- _this65.el.tabIndex = -1;
11257
- _this65._keysSelected = {};
11258
- _this65._valueDict = {}; // Maps key to original and generated option element.
11259
- _this65._setupDropdown();
11519
+ _this67.el.tabIndex = -1;
11520
+ _this67._keysSelected = {};
11521
+ _this67._valueDict = {}; // Maps key to original and generated option element.
11522
+ _this67._setupDropdown();
11260
11523
 
11261
- _this65._setupEventHandlers();
11262
- return _this65;
11524
+ _this67._setupEventHandlers();
11525
+ return _this67;
11263
11526
  }
11264
11527
 
11265
11528
  _createClass(FormSelect, [{
@@ -11282,14 +11545,14 @@ $jscomp.polyfill = function (e, r, p, m) {
11282
11545
  }, {
11283
11546
  key: "_setupEventHandlers",
11284
11547
  value: function _setupEventHandlers() {
11285
- var _this66 = this;
11548
+ var _this68 = this;
11286
11549
 
11287
11550
  this._handleSelectChangeBound = this._handleSelectChange.bind(this);
11288
11551
  this._handleOptionClickBound = this._handleOptionClick.bind(this);
11289
11552
  this._handleInputClickBound = this._handleInputClick.bind(this);
11290
11553
 
11291
11554
  $(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
11292
- el.addEventListener('click', _this66._handleOptionClickBound);
11555
+ el.addEventListener('click', _this68._handleOptionClickBound);
11293
11556
  });
11294
11557
  this.el.addEventListener('change', this._handleSelectChangeBound);
11295
11558
  this.input.addEventListener('click', this._handleInputClickBound);
@@ -11302,10 +11565,10 @@ $jscomp.polyfill = function (e, r, p, m) {
11302
11565
  }, {
11303
11566
  key: "_removeEventHandlers",
11304
11567
  value: function _removeEventHandlers() {
11305
- var _this67 = this;
11568
+ var _this69 = this;
11306
11569
 
11307
11570
  $(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
11308
- el.removeEventListener('click', _this67._handleOptionClickBound);
11571
+ el.removeEventListener('click', _this69._handleOptionClickBound);
11309
11572
  });
11310
11573
  this.el.removeEventListener('change', this._handleSelectChangeBound);
11311
11574
  this.input.removeEventListener('click', this._handleInputClickBound);
@@ -11382,7 +11645,7 @@ $jscomp.polyfill = function (e, r, p, m) {
11382
11645
  }, {
11383
11646
  key: "_setupDropdown",
11384
11647
  value: function _setupDropdown() {
11385
- var _this68 = this;
11648
+ var _this70 = this;
11386
11649
 
11387
11650
  this.wrapper = document.createElement('div');
11388
11651
  $(this.wrapper).addClass('select-wrapper' + ' ' + this.options.classes);
@@ -11405,21 +11668,21 @@ $jscomp.polyfill = function (e, r, p, m) {
11405
11668
  if ($(el).is('option')) {
11406
11669
  // Direct descendant option.
11407
11670
  var optionEl = void 0;
11408
- if (_this68.isMultiple) {
11409
- optionEl = _this68._appendOptionWithIcon(_this68.$el, el, 'multiple');
11671
+ if (_this70.isMultiple) {
11672
+ optionEl = _this70._appendOptionWithIcon(_this70.$el, el, 'multiple');
11410
11673
  } else {
11411
- optionEl = _this68._appendOptionWithIcon(_this68.$el, el);
11674
+ optionEl = _this70._appendOptionWithIcon(_this70.$el, el);
11412
11675
  }
11413
11676
 
11414
- _this68._addOptionToValueDict(el, optionEl);
11677
+ _this70._addOptionToValueDict(el, optionEl);
11415
11678
  } else if ($(el).is('optgroup')) {
11416
11679
  // Optgroup.
11417
11680
  var selectOptions = $(el).children('option');
11418
- $(_this68.dropdownOptions).append($('<li class="optgroup"><span>' + el.getAttribute('label') + '</span></li>')[0]);
11681
+ $(_this70.dropdownOptions).append($('<li class="optgroup"><span>' + el.getAttribute('label') + '</span></li>')[0]);
11419
11682
 
11420
11683
  selectOptions.each(function (el) {
11421
- var optionEl = _this68._appendOptionWithIcon(_this68.$el, el, 'optgroup-option');
11422
- _this68._addOptionToValueDict(el, optionEl);
11684
+ var optionEl = _this70._appendOptionWithIcon(_this70.$el, el, 'optgroup-option');
11685
+ _this70._addOptionToValueDict(el, optionEl);
11423
11686
  });
11424
11687
  }
11425
11688
  });
@@ -11448,6 +11711,16 @@ $jscomp.polyfill = function (e, r, p, m) {
11448
11711
  if (!this.el.disabled) {
11449
11712
  var dropdownOptions = $.extend({}, this.options.dropdownOptions);
11450
11713
 
11714
+ // Add callback for centering selected option when dropdown content is scrollable
11715
+ dropdownOptions.onOpenEnd = function (el) {
11716
+ var selectedOption = $(_this70.dropdownOptions).find('.selected').first();
11717
+ if (_this70.dropdown.isScrollable && selectedOption.length) {
11718
+ var scrollOffset = selectedOption[0].getBoundingClientRect().top - _this70.dropdownOptions.getBoundingClientRect().top; // scroll to selected option
11719
+ scrollOffset -= _this70.dropdownOptions.clientHeight / 2; // center in dropdown
11720
+ _this70.dropdownOptions.scrollTop = scrollOffset;
11721
+ }
11722
+ };
11723
+
11451
11724
  if (this.isMultiple) {
11452
11725
  dropdownOptions.closeOnClick = false;
11453
11726
  }
@@ -11685,23 +11958,23 @@ $jscomp.polyfill = function (e, r, p, m) {
11685
11958
  function Range(el, options) {
11686
11959
  _classCallCheck(this, Range);
11687
11960
 
11688
- var _this69 = _possibleConstructorReturn(this, (Range.__proto__ || Object.getPrototypeOf(Range)).call(this, Range, el, options));
11961
+ var _this71 = _possibleConstructorReturn(this, (Range.__proto__ || Object.getPrototypeOf(Range)).call(this, Range, el, options));
11689
11962
 
11690
- _this69.el.M_Range = _this69;
11963
+ _this71.el.M_Range = _this71;
11691
11964
 
11692
11965
  /**
11693
11966
  * Options for the range
11694
11967
  * @member Range#options
11695
11968
  */
11696
- _this69.options = $.extend({}, Range.defaults, options);
11969
+ _this71.options = $.extend({}, Range.defaults, options);
11697
11970
 
11698
- _this69._mousedown = false;
11971
+ _this71._mousedown = false;
11699
11972
 
11700
11973
  // Setup
11701
- _this69._setupThumb();
11974
+ _this71._setupThumb();
11702
11975
 
11703
- _this69._setupEventHandlers();
11704
- return _this69;
11976
+ _this71._setupEventHandlers();
11977
+ return _this71;
11705
11978
  }
11706
11979
 
11707
11980
  _createClass(Range, [{