materialize-sass 1.0.0.beta → 1.0.0.1
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 +4 -4
- data/.gitattributes +1 -0
- data/README.md +2 -2
- data/Rakefile +1 -1
- data/assets/javascripts/materialize/autocomplete.js +94 -37
- data/assets/javascripts/materialize/buttons.js +4 -6
- data/assets/javascripts/materialize/carousel.js +9 -9
- data/assets/javascripts/materialize/chips.js +2 -2
- data/assets/javascripts/materialize/collapsible.js +13 -10
- data/assets/javascripts/materialize/datepicker.js +27 -44
- data/assets/javascripts/materialize/dropdown.js +38 -15
- data/assets/javascripts/materialize/extras/nouislider.js +1 -1
- data/assets/javascripts/materialize/extras/nouislider.min.js +1 -1
- data/assets/javascripts/materialize/forms.js +7 -8
- data/assets/javascripts/materialize/global.js +28 -11
- data/assets/javascripts/materialize/materialbox.js +12 -7
- data/assets/javascripts/materialize/modal.js +8 -4
- data/assets/javascripts/materialize/parallax.js +1 -1
- data/assets/javascripts/materialize/pushpin.js +8 -3
- data/assets/javascripts/materialize/range.js +2 -19
- data/assets/javascripts/materialize/select.js +57 -33
- data/assets/javascripts/materialize/sidenav.js +5 -3
- data/assets/javascripts/materialize/slider.js +2 -1
- data/assets/javascripts/materialize/tabs.js +13 -8
- data/assets/javascripts/materialize/timepicker.js +22 -5
- data/assets/javascripts/materialize/toasts.js +4 -3
- data/assets/javascripts/materialize/tooltip.js +14 -8
- data/assets/javascripts/materialize.js +804 -685
- data/assets/stylesheets/materialize/components/_buttons.scss +2 -1
- data/assets/stylesheets/materialize/components/_collapsible.scss +8 -1
- data/assets/stylesheets/materialize/components/_datepicker.scss +5 -1
- data/assets/stylesheets/materialize/components/_dropdown.scss +10 -1
- data/assets/stylesheets/materialize/components/_global.scss +2 -0
- data/assets/stylesheets/materialize/components/_modal.scss +4 -0
- data/assets/stylesheets/materialize/components/_sidenav.scss +9 -17
- data/assets/stylesheets/materialize/components/_toast.scss +0 -1
- data/assets/stylesheets/materialize/components/_variables.scss +1 -0
- data/assets/stylesheets/materialize/components/forms/_input-fields.scss +2 -0
- data/assets/stylesheets/materialize/components/forms/_range.scss +3 -3
- data/assets/stylesheets/materialize/components/forms/_select.scss +19 -7
- data/assets/stylesheets/materialize/extras/nouislider.css +1 -1
- data/lib/materialize-sass/engine.rb +4 -1
- data/lib/materialize-sass/version.rb +1 -1
- data/lib/materialize-sass.rb +3 -8
- data/materialize-sass.gemspec +4 -5
- metadata +18 -32
@@ -186,7 +186,8 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
186
186
|
key: '_handleInterval',
|
187
187
|
value: function _handleInterval() {
|
188
188
|
var newActiveIndex = this.$slider.find('.active').index();
|
189
|
-
if (this.$slides.length === newActiveIndex + 1) newActiveIndex = 0;
|
189
|
+
if (this.$slides.length === newActiveIndex + 1) newActiveIndex = 0;
|
190
|
+
// loop to start
|
190
191
|
else newActiveIndex += 1;
|
191
192
|
|
192
193
|
this.set(newActiveIndex);
|
@@ -52,16 +52,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
52
52
|
// Setup
|
53
53
|
_this.$tabLinks = _this.$el.children('li.tab').children('a');
|
54
54
|
_this.index = 0;
|
55
|
-
_this._setTabsAndTabWidth();
|
56
55
|
_this._setupActiveTabLink();
|
57
|
-
_this._createIndicator();
|
58
56
|
|
57
|
+
// Setup tabs content
|
59
58
|
if (_this.options.swipeable) {
|
60
59
|
_this._setupSwipeableTabs();
|
61
60
|
} else {
|
62
61
|
_this._setupNormalTabs();
|
63
62
|
}
|
64
63
|
|
64
|
+
// Setup tabs indicator after content to ensure accurate widths
|
65
|
+
_this._setTabsAndTabWidth();
|
66
|
+
_this._createIndicator();
|
67
|
+
|
65
68
|
_this._setupEventHandlers();
|
66
69
|
return _this;
|
67
70
|
}
|
@@ -150,12 +153,10 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
150
153
|
}
|
151
154
|
|
152
155
|
// Act as regular link if target attribute is specified.
|
153
|
-
if (!!tabLink.attr(
|
156
|
+
if (!!tabLink.attr('target')) {
|
154
157
|
return;
|
155
158
|
}
|
156
159
|
|
157
|
-
this._setTabsAndTabWidth();
|
158
|
-
|
159
160
|
// Make the old tab inactive.
|
160
161
|
this.$activeTabLink.removeClass('active');
|
161
162
|
var $oldContent = this.$content;
|
@@ -174,7 +175,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
174
175
|
if (this.options.swipeable) {
|
175
176
|
if (this._tabsCarousel) {
|
176
177
|
this._tabsCarousel.set(this.index, function () {
|
177
|
-
if (typeof _this2.options.onShow ===
|
178
|
+
if (typeof _this2.options.onShow === 'function') {
|
178
179
|
_this2.options.onShow.call(_this2, _this2.$content[0]);
|
179
180
|
}
|
180
181
|
});
|
@@ -194,6 +195,9 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
194
195
|
}
|
195
196
|
}
|
196
197
|
|
198
|
+
// Update widths after content is swapped (scrollbar bugfix)
|
199
|
+
this._setTabsAndTabWidth();
|
200
|
+
|
197
201
|
// Update indicator
|
198
202
|
this._animateIndicator(prevIndex);
|
199
203
|
|
@@ -290,7 +294,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
290
294
|
_this4.$activeTabLink = _this4.$tabLinks.eq(_this4.index);
|
291
295
|
_this4.$activeTabLink.addClass('active');
|
292
296
|
_this4._animateIndicator(prevIndex);
|
293
|
-
if (typeof _this4.options.onShow ===
|
297
|
+
if (typeof _this4.options.onShow === 'function') {
|
294
298
|
_this4.options.onShow.call(_this4, _this4.$content[0]);
|
295
299
|
}
|
296
300
|
}
|
@@ -386,6 +390,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
386
390
|
}, {
|
387
391
|
key: 'updateTabIndicator',
|
388
392
|
value: function updateTabIndicator() {
|
393
|
+
this._setTabsAndTabWidth();
|
389
394
|
this._animateIndicator(this.index);
|
390
395
|
}
|
391
396
|
|
@@ -463,7 +468,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
463
468
|
return Tabs;
|
464
469
|
}(Component);
|
465
470
|
|
466
|
-
|
471
|
+
M.Tabs = Tabs;
|
467
472
|
|
468
473
|
if (M.jQueryLoaded) {
|
469
474
|
M.initializeJqueryWrapper(Tabs, 'tabs', 'M_Tabs');
|
@@ -31,7 +31,14 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
31
31
|
|
32
32
|
autoClose: false, // auto close when minute is selected
|
33
33
|
twelveHour: true, // change to 12 hour AM/PM clock from 24 hour
|
34
|
-
vibrate: true // vibrate the device when dragging clock hand
|
34
|
+
vibrate: true, // vibrate the device when dragging clock hand
|
35
|
+
|
36
|
+
// Callbacks
|
37
|
+
onOpenStart: null,
|
38
|
+
onOpenEnd: null,
|
39
|
+
onCloseStart: null,
|
40
|
+
onCloseEnd: null,
|
41
|
+
onSelect: null
|
35
42
|
};
|
36
43
|
|
37
44
|
/**
|
@@ -175,6 +182,10 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
175
182
|
}, this.options.duration / 2);
|
176
183
|
}
|
177
184
|
|
185
|
+
if (typeof this.options.onSelect === 'function') {
|
186
|
+
this.options.onSelect.call(this, this.hours, this.minutes);
|
187
|
+
}
|
188
|
+
|
178
189
|
// Unbind mousemove event
|
179
190
|
document.removeEventListener('mousemove', this._handleDocumentClickMoveBound);
|
180
191
|
document.removeEventListener('touchmove', this._handleDocumentClickMoveBound);
|
@@ -200,7 +211,13 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
200
211
|
var _this3 = this;
|
201
212
|
|
202
213
|
this.modal = M.Modal.init(this.modalEl, {
|
214
|
+
onOpenStart: this.options.onOpenStart,
|
215
|
+
onOpenEnd: this.options.onOpenEnd,
|
216
|
+
onCloseStart: this.options.onCloseStart,
|
203
217
|
onCloseEnd: function () {
|
218
|
+
if (typeof _this3.options.onCloseEnd === 'function') {
|
219
|
+
_this3.options.onCloseEnd.call(_this3);
|
220
|
+
}
|
204
221
|
_this3.isOpen = false;
|
205
222
|
}
|
206
223
|
});
|
@@ -225,7 +242,6 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
225
242
|
}, {
|
226
243
|
key: '_pickerSetup',
|
227
244
|
value: function _pickerSetup() {
|
228
|
-
|
229
245
|
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));
|
230
246
|
if (this.options.showClearBtn) {
|
231
247
|
$clearBtn.css({ visibility: '' });
|
@@ -357,12 +373,12 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
357
373
|
// Get the time
|
358
374
|
var value = ((this.el.value || this.options.defaultTime || '') + '').split(':');
|
359
375
|
if (this.options.twelveHour && !(typeof value[1] === 'undefined')) {
|
360
|
-
if (value[1].toUpperCase().indexOf(
|
376
|
+
if (value[1].toUpperCase().indexOf('AM') > 0) {
|
361
377
|
this.amOrPm = 'AM';
|
362
378
|
} else {
|
363
379
|
this.amOrPm = 'PM';
|
364
380
|
}
|
365
|
-
value[1] = value[1].replace(
|
381
|
+
value[1] = value[1].replace('AM', '').replace('PM', '');
|
366
382
|
}
|
367
383
|
if (value[0] === 'now') {
|
368
384
|
var now = new Date(+new Date() + this.options.fromNow);
|
@@ -381,7 +397,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
381
397
|
}, {
|
382
398
|
key: 'showView',
|
383
399
|
value: function showView(view, delay) {
|
384
|
-
if (view === 'minutes' && $(this.hoursView).css(
|
400
|
+
if (view === 'minutes' && $(this.hoursView).css('visibility') === 'visible') {
|
385
401
|
// raiseCallback(this.options.beforeHourSelect);
|
386
402
|
}
|
387
403
|
var isHours = view === 'hours',
|
@@ -519,6 +535,7 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
519
535
|
this.isOpen = true;
|
520
536
|
this._updateTimeFromInput();
|
521
537
|
this.showView('hours');
|
538
|
+
|
522
539
|
this.modal.open();
|
523
540
|
}
|
524
541
|
}, {
|
@@ -46,6 +46,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
|
|
46
46
|
var toastElement = this._createToast();
|
47
47
|
toastElement.M_Toast = this;
|
48
48
|
this.el = toastElement;
|
49
|
+
this.$el = $(toastElement);
|
49
50
|
this._animateIn();
|
50
51
|
this._setTimer();
|
51
52
|
}
|
@@ -96,7 +97,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
|
|
96
97
|
targets: this.el,
|
97
98
|
top: 0,
|
98
99
|
opacity: 1,
|
99
|
-
duration:
|
100
|
+
duration: this.options.inDuration,
|
100
101
|
easing: 'easeOutCubic'
|
101
102
|
});
|
102
103
|
}
|
@@ -156,7 +157,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
|
|
156
157
|
_this2.options.completeCallback();
|
157
158
|
}
|
158
159
|
// Remove toast from DOM
|
159
|
-
_this2
|
160
|
+
_this2.$el.remove();
|
160
161
|
Toast._toasts.splice(Toast._toasts.indexOf(_this2), 1);
|
161
162
|
if (Toast._toasts.length === 0) {
|
162
163
|
Toast._removeContainer();
|
@@ -210,7 +211,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
|
|
210
211
|
document.removeEventListener('mousemove', Toast._onDragMove);
|
211
212
|
document.removeEventListener('mouseup', Toast._onDragEnd);
|
212
213
|
|
213
|
-
Toast._container.
|
214
|
+
$(Toast._container).remove();
|
214
215
|
Toast._container = null;
|
215
216
|
}
|
216
217
|
|
@@ -104,16 +104,16 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
104
104
|
}
|
105
105
|
}, {
|
106
106
|
key: 'open',
|
107
|
-
value: function open() {
|
107
|
+
value: function open(isManual) {
|
108
108
|
if (this.isOpen) {
|
109
109
|
return;
|
110
110
|
}
|
111
|
-
|
111
|
+
isManual = isManual === undefined ? true : undefined; // Default value true
|
112
112
|
this.isOpen = true;
|
113
113
|
// Update tooltip content with HTML attribute options
|
114
114
|
this.options = $.extend({}, this.options, this._getAttributeOptions());
|
115
115
|
this._updateTooltipContent();
|
116
|
-
this._setEnterDelayTimeout();
|
116
|
+
this._setEnterDelayTimeout(isManual);
|
117
117
|
}
|
118
118
|
}, {
|
119
119
|
key: 'close',
|
@@ -122,6 +122,8 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
122
122
|
return;
|
123
123
|
}
|
124
124
|
|
125
|
+
this.isHovered = false;
|
126
|
+
this.isFocused = false;
|
125
127
|
this.isOpen = false;
|
126
128
|
this._setExitDelayTimeout();
|
127
129
|
}
|
@@ -152,13 +154,13 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
152
154
|
|
153
155
|
}, {
|
154
156
|
key: '_setEnterDelayTimeout',
|
155
|
-
value: function _setEnterDelayTimeout() {
|
157
|
+
value: function _setEnterDelayTimeout(isManual) {
|
156
158
|
var _this3 = this;
|
157
159
|
|
158
160
|
clearTimeout(this._enterDelayTimeout);
|
159
161
|
|
160
162
|
this._enterDelayTimeout = setTimeout(function () {
|
161
|
-
if (!_this3.isHovered && !_this3.isFocused) {
|
163
|
+
if (!_this3.isHovered && !_this3.isFocused && !isManual) {
|
162
164
|
return;
|
163
165
|
}
|
164
166
|
|
@@ -275,19 +277,23 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
|
275
277
|
key: '_handleMouseEnter',
|
276
278
|
value: function _handleMouseEnter() {
|
277
279
|
this.isHovered = true;
|
278
|
-
this.
|
280
|
+
this.isFocused = false; // Allows close of tooltip when opened by focus.
|
281
|
+
this.open(false);
|
279
282
|
}
|
280
283
|
}, {
|
281
284
|
key: '_handleMouseLeave',
|
282
285
|
value: function _handleMouseLeave() {
|
283
286
|
this.isHovered = false;
|
287
|
+
this.isFocused = false; // Allows close of tooltip when opened by focus.
|
284
288
|
this.close();
|
285
289
|
}
|
286
290
|
}, {
|
287
291
|
key: '_handleFocus',
|
288
292
|
value: function _handleFocus() {
|
289
|
-
|
290
|
-
|
293
|
+
if (M.tabPressed) {
|
294
|
+
this.isFocused = true;
|
295
|
+
this.open(false);
|
296
|
+
}
|
291
297
|
}
|
292
298
|
}, {
|
293
299
|
key: '_handleBlur',
|
@@ -1,5 +1,5 @@
|
|
1
1
|
/*!
|
2
|
-
* Materialize v1.0.0
|
2
|
+
* Materialize v1.0.0 (http://materializecss.com)
|
3
3
|
* Copyright 2014-2017 Materialize
|
4
4
|
* MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE)
|
5
5
|
*/
|
@@ -1071,8 +1071,8 @@ var Component = function () {
|
|
1071
1071
|
})(window);
|
1072
1072
|
|
1073
1073
|
// AMD
|
1074
|
-
if (typeof define ===
|
1075
|
-
define(
|
1074
|
+
if (typeof define === 'function' && define.amd) {
|
1075
|
+
define('M', [], function () {
|
1076
1076
|
return M;
|
1077
1077
|
});
|
1078
1078
|
|
@@ -1084,6 +1084,8 @@ if (typeof define === "function" && define.amd) {
|
|
1084
1084
|
exports.default = M;
|
1085
1085
|
}
|
1086
1086
|
|
1087
|
+
M.version = '1.0.0';
|
1088
|
+
|
1087
1089
|
M.keys = {
|
1088
1090
|
TAB: 9,
|
1089
1091
|
ENTER: 13,
|
@@ -1096,18 +1098,31 @@ M.keys = {
|
|
1096
1098
|
* TabPress Keydown handler
|
1097
1099
|
*/
|
1098
1100
|
M.tabPressed = false;
|
1101
|
+
M.keyDown = false;
|
1099
1102
|
var docHandleKeydown = function (e) {
|
1100
|
-
|
1103
|
+
M.keyDown = true;
|
1104
|
+
if (e.which === M.keys.TAB || e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) {
|
1101
1105
|
M.tabPressed = true;
|
1102
1106
|
}
|
1103
1107
|
};
|
1104
1108
|
var docHandleKeyup = function (e) {
|
1105
|
-
|
1109
|
+
M.keyDown = false;
|
1110
|
+
if (e.which === M.keys.TAB || e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) {
|
1106
1111
|
M.tabPressed = false;
|
1107
1112
|
}
|
1108
1113
|
};
|
1109
|
-
|
1110
|
-
|
1114
|
+
var docHandleFocus = function (e) {
|
1115
|
+
if (M.keyDown) {
|
1116
|
+
document.body.classList.add('keyboard-focused');
|
1117
|
+
}
|
1118
|
+
};
|
1119
|
+
var docHandleBlur = function (e) {
|
1120
|
+
document.body.classList.remove('keyboard-focused');
|
1121
|
+
};
|
1122
|
+
document.addEventListener('keydown', docHandleKeydown, true);
|
1123
|
+
document.addEventListener('keyup', docHandleKeyup, true);
|
1124
|
+
document.addEventListener('focus', docHandleFocus, true);
|
1125
|
+
document.addEventListener('blur', docHandleBlur, true);
|
1111
1126
|
|
1112
1127
|
/**
|
1113
1128
|
* Initialize jQuery wrapper for plugin
|
@@ -1207,7 +1222,7 @@ M.guid = function () {
|
|
1207
1222
|
* @returns {string}
|
1208
1223
|
*/
|
1209
1224
|
M.escapeHash = function (hash) {
|
1210
|
-
return hash.replace(/(:|\.|\[|\]|,|=|\/)/g,
|
1225
|
+
return hash.replace(/(:|\.|\[|\]|,|=|\/)/g, '\\$1');
|
1211
1226
|
};
|
1212
1227
|
|
1213
1228
|
M.elementOrParentIsFixed = function (element) {
|
@@ -1215,7 +1230,7 @@ M.elementOrParentIsFixed = function (element) {
|
|
1215
1230
|
var $checkElements = $element.add($element.parents());
|
1216
1231
|
var isFixed = false;
|
1217
1232
|
$checkElements.each(function () {
|
1218
|
-
if ($(this).css(
|
1233
|
+
if ($(this).css('position') === 'fixed') {
|
1219
1234
|
isFixed = true;
|
1220
1235
|
return false;
|
1221
1236
|
}
|
@@ -1255,6 +1270,8 @@ M.checkWithinContainer = function (container, bounding, offset) {
|
|
1255
1270
|
};
|
1256
1271
|
|
1257
1272
|
var containerRect = container.getBoundingClientRect();
|
1273
|
+
// If body element is smaller than viewport, use viewport height instead.
|
1274
|
+
var containerBottom = container === document.body ? Math.max(containerRect.bottom, window.innerHeight) : containerRect.bottom;
|
1258
1275
|
|
1259
1276
|
var scrollLeft = container.scrollLeft;
|
1260
1277
|
var scrollTop = container.scrollTop;
|
@@ -1275,7 +1292,7 @@ M.checkWithinContainer = function (container, bounding, offset) {
|
|
1275
1292
|
edges.top = true;
|
1276
1293
|
}
|
1277
1294
|
|
1278
|
-
if (scrolledY + bounding.height >
|
1295
|
+
if (scrolledY + bounding.height > containerBottom - offset || scrolledY + bounding.height > window.innerHeight - offset) {
|
1279
1296
|
edges.bottom = true;
|
1280
1297
|
}
|
1281
1298
|
|
@@ -1358,7 +1375,7 @@ M.getIdFromTrigger = function (trigger) {
|
|
1358
1375
|
if (id) {
|
1359
1376
|
id = id.slice(1);
|
1360
1377
|
} else {
|
1361
|
-
id =
|
1378
|
+
id = '';
|
1362
1379
|
}
|
1363
1380
|
}
|
1364
1381
|
return id;
|
@@ -1967,7 +1984,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
1967
1984
|
}, {
|
1968
1985
|
key: "_removeEventHandlers",
|
1969
1986
|
value: function _removeEventHandlers() {
|
1987
|
+
var _this5 = this;
|
1988
|
+
|
1970
1989
|
this.el.removeEventListener('click', this._handleCollapsibleClickBound);
|
1990
|
+
this.$headers.each(function (header) {
|
1991
|
+
header.removeEventListener('keydown', _this5._handleCollapsibleKeydownBound);
|
1992
|
+
});
|
1971
1993
|
}
|
1972
1994
|
|
1973
1995
|
/**
|
@@ -2017,7 +2039,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2017
2039
|
}, {
|
2018
2040
|
key: "_animateIn",
|
2019
2041
|
value: function _animateIn(index) {
|
2020
|
-
var
|
2042
|
+
var _this6 = this;
|
2021
2043
|
|
2022
2044
|
var $collapsibleLi = this.$el.children('li').eq(index);
|
2023
2045
|
if ($collapsibleLi.length) {
|
@@ -2056,8 +2078,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2056
2078
|
});
|
2057
2079
|
|
2058
2080
|
// onOpenEnd callback
|
2059
|
-
if (typeof
|
2060
|
-
|
2081
|
+
if (typeof _this6.options.onOpenEnd === 'function') {
|
2082
|
+
_this6.options.onOpenEnd.call(_this6, $collapsibleLi[0]);
|
2061
2083
|
}
|
2062
2084
|
}
|
2063
2085
|
});
|
@@ -2072,7 +2094,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2072
2094
|
}, {
|
2073
2095
|
key: "_animateOut",
|
2074
2096
|
value: function _animateOut(index) {
|
2075
|
-
var
|
2097
|
+
var _this7 = this;
|
2076
2098
|
|
2077
2099
|
var $collapsibleLi = this.$el.children('li').eq(index);
|
2078
2100
|
if ($collapsibleLi.length) {
|
@@ -2095,8 +2117,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2095
2117
|
});
|
2096
2118
|
|
2097
2119
|
// onCloseEnd callback
|
2098
|
-
if (typeof
|
2099
|
-
|
2120
|
+
if (typeof _this7.options.onCloseEnd === 'function') {
|
2121
|
+
_this7.options.onCloseEnd.call(_this7, $collapsibleLi[0]);
|
2100
2122
|
}
|
2101
2123
|
}
|
2102
2124
|
});
|
@@ -2111,11 +2133,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2111
2133
|
}, {
|
2112
2134
|
key: "open",
|
2113
2135
|
value: function open(index) {
|
2114
|
-
var
|
2136
|
+
var _this8 = this;
|
2115
2137
|
|
2116
2138
|
var $collapsibleLi = this.$el.children('li').eq(index);
|
2117
2139
|
if ($collapsibleLi.length && !$collapsibleLi[0].classList.contains('active')) {
|
2118
|
-
|
2119
2140
|
// onOpenStart callback
|
2120
2141
|
if (typeof this.options.onOpenStart === 'function') {
|
2121
2142
|
this.options.onOpenStart.call(this, $collapsibleLi[0]);
|
@@ -2127,7 +2148,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2127
2148
|
var $activeLis = this.$el.children('li.active');
|
2128
2149
|
$activeLis.each(function (el) {
|
2129
2150
|
var index = $collapsibleLis.index($(el));
|
2130
|
-
|
2151
|
+
_this8.close(index);
|
2131
2152
|
});
|
2132
2153
|
}
|
2133
2154
|
|
@@ -2147,7 +2168,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2147
2168
|
value: function close(index) {
|
2148
2169
|
var $collapsibleLi = this.$el.children('li').eq(index);
|
2149
2170
|
if ($collapsibleLi.length && $collapsibleLi[0].classList.contains('active')) {
|
2150
|
-
|
2151
2171
|
// onCloseStart callback
|
2152
2172
|
if (typeof this.options.onCloseStart === 'function') {
|
2153
2173
|
this.options.onCloseStart.call(this, $collapsibleLi[0]);
|
@@ -2206,7 +2226,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2206
2226
|
onOpenStart: null,
|
2207
2227
|
onOpenEnd: null,
|
2208
2228
|
onCloseStart: null,
|
2209
|
-
onCloseEnd: null
|
2229
|
+
onCloseEnd: null,
|
2230
|
+
onItemClick: null
|
2210
2231
|
};
|
2211
2232
|
|
2212
2233
|
/**
|
@@ -2219,14 +2240,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2219
2240
|
function Dropdown(el, options) {
|
2220
2241
|
_classCallCheck(this, Dropdown);
|
2221
2242
|
|
2222
|
-
var
|
2243
|
+
var _this9 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options));
|
2223
2244
|
|
2224
|
-
|
2225
|
-
Dropdown._dropdowns.push(
|
2245
|
+
_this9.el.M_Dropdown = _this9;
|
2246
|
+
Dropdown._dropdowns.push(_this9);
|
2226
2247
|
|
2227
|
-
|
2228
|
-
|
2229
|
-
|
2248
|
+
_this9.id = M.getIdFromTrigger(el);
|
2249
|
+
_this9.dropdownEl = document.getElementById(_this9.id);
|
2250
|
+
_this9.$dropdownEl = $(_this9.dropdownEl);
|
2230
2251
|
|
2231
2252
|
/**
|
2232
2253
|
* Options for the dropdown
|
@@ -2245,44 +2266,45 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2245
2266
|
* @prop {Function} onCloseStart - Function called when dropdown starts closing
|
2246
2267
|
* @prop {Function} onCloseEnd - Function called when dropdown finishes closing
|
2247
2268
|
*/
|
2248
|
-
|
2269
|
+
_this9.options = $.extend({}, Dropdown.defaults, options);
|
2249
2270
|
|
2250
2271
|
/**
|
2251
2272
|
* Describes open/close state of dropdown
|
2252
2273
|
* @type {Boolean}
|
2253
2274
|
*/
|
2254
|
-
|
2275
|
+
_this9.isOpen = false;
|
2255
2276
|
|
2256
2277
|
/**
|
2257
2278
|
* Describes if dropdown content is scrollable
|
2258
2279
|
* @type {Boolean}
|
2259
2280
|
*/
|
2260
|
-
|
2281
|
+
_this9.isScrollable = false;
|
2261
2282
|
|
2262
2283
|
/**
|
2263
2284
|
* Describes if touch moving on dropdown content
|
2264
2285
|
* @type {Boolean}
|
2265
2286
|
*/
|
2266
|
-
|
2287
|
+
_this9.isTouchMoving = false;
|
2267
2288
|
|
2268
|
-
|
2269
|
-
|
2289
|
+
_this9.focusedIndex = -1;
|
2290
|
+
_this9.filterQuery = [];
|
2270
2291
|
|
2271
2292
|
// Move dropdown-content after dropdown-trigger
|
2272
|
-
if (!!
|
2273
|
-
$(
|
2293
|
+
if (!!_this9.options.container) {
|
2294
|
+
$(_this9.options.container).append(_this9.dropdownEl);
|
2274
2295
|
} else {
|
2275
|
-
|
2276
|
-
}
|
2277
|
-
|
2278
|
-
|
2279
|
-
|
2280
|
-
|
2281
|
-
|
2282
|
-
|
2283
|
-
|
2284
|
-
|
2285
|
-
|
2296
|
+
_this9.$el.after(_this9.dropdownEl);
|
2297
|
+
}
|
2298
|
+
|
2299
|
+
_this9._makeDropdownFocusable();
|
2300
|
+
_this9._resetFilterQueryBound = _this9._resetFilterQuery.bind(_this9);
|
2301
|
+
_this9._handleDocumentClickBound = _this9._handleDocumentClick.bind(_this9);
|
2302
|
+
_this9._handleDocumentTouchmoveBound = _this9._handleDocumentTouchmove.bind(_this9);
|
2303
|
+
_this9._handleDropdownClickBound = _this9._handleDropdownClick.bind(_this9);
|
2304
|
+
_this9._handleDropdownKeydownBound = _this9._handleDropdownKeydown.bind(_this9);
|
2305
|
+
_this9._handleTriggerKeydownBound = _this9._handleTriggerKeydown.bind(_this9);
|
2306
|
+
_this9._setupEventHandlers();
|
2307
|
+
return _this9;
|
2286
2308
|
}
|
2287
2309
|
|
2288
2310
|
_createClass(Dropdown, [{
|
@@ -2309,6 +2331,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2309
2331
|
// Trigger keydown handler
|
2310
2332
|
this.el.addEventListener('keydown', this._handleTriggerKeydownBound);
|
2311
2333
|
|
2334
|
+
// Item click handler
|
2335
|
+
this.dropdownEl.addEventListener('click', this._handleDropdownClickBound);
|
2336
|
+
|
2312
2337
|
// Hover event handlers
|
2313
2338
|
if (this.options.hover) {
|
2314
2339
|
this._handleMouseEnterBound = this._handleMouseEnter.bind(this);
|
@@ -2331,13 +2356,13 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2331
2356
|
}, {
|
2332
2357
|
key: "_removeEventHandlers",
|
2333
2358
|
value: function _removeEventHandlers() {
|
2334
|
-
// Trigger keydown handler
|
2335
2359
|
this.el.removeEventListener('keydown', this._handleTriggerKeydownBound);
|
2360
|
+
this.dropdownEl.removeEventListener('click', this._handleDropdownClickBound);
|
2336
2361
|
|
2337
2362
|
if (this.options.hover) {
|
2338
|
-
this.el.
|
2339
|
-
this.el.
|
2340
|
-
this.dropdownEl.
|
2363
|
+
this.el.removeEventListener('mouseenter', this._handleMouseEnterBound);
|
2364
|
+
this.el.removeEventListener('mouseleave', this._handleMouseLeaveBound);
|
2365
|
+
this.dropdownEl.removeEventListener('mouseleave', this._handleMouseLeaveBound);
|
2341
2366
|
} else {
|
2342
2367
|
this.el.removeEventListener('click', this._handleClickBound);
|
2343
2368
|
}
|
@@ -2391,17 +2416,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2391
2416
|
}, {
|
2392
2417
|
key: "_handleDocumentClick",
|
2393
2418
|
value: function _handleDocumentClick(e) {
|
2394
|
-
var
|
2419
|
+
var _this10 = this;
|
2395
2420
|
|
2396
2421
|
var $target = $(e.target);
|
2397
2422
|
if (this.options.closeOnClick && $target.closest('.dropdown-content').length && !this.isTouchMoving) {
|
2398
2423
|
// isTouchMoving to check if scrolling on mobile.
|
2399
2424
|
setTimeout(function () {
|
2400
|
-
|
2425
|
+
_this10.close();
|
2401
2426
|
}, 0);
|
2402
2427
|
} else if ($target.closest('.dropdown-trigger').length || !$target.closest('.dropdown-content').length) {
|
2403
2428
|
setTimeout(function () {
|
2404
|
-
|
2429
|
+
_this10.close();
|
2405
2430
|
}, 0);
|
2406
2431
|
}
|
2407
2432
|
this.isTouchMoving = false;
|
@@ -2430,6 +2455,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2430
2455
|
}
|
2431
2456
|
}
|
2432
2457
|
|
2458
|
+
/**
|
2459
|
+
* Handle Dropdown Click
|
2460
|
+
* @param {Event} e
|
2461
|
+
*/
|
2462
|
+
|
2463
|
+
}, {
|
2464
|
+
key: "_handleDropdownClick",
|
2465
|
+
value: function _handleDropdownClick(e) {
|
2466
|
+
// onItemClick callback
|
2467
|
+
if (typeof this.options.onItemClick === 'function') {
|
2468
|
+
var itemEl = $(e.target).closest('li')[0];
|
2469
|
+
this.options.onItemClick.call(this, itemEl);
|
2470
|
+
}
|
2471
|
+
}
|
2472
|
+
|
2433
2473
|
/**
|
2434
2474
|
* Handle Dropdown Keydown
|
2435
2475
|
* @param {Event} e
|
@@ -2469,7 +2509,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2469
2509
|
var $activatableElement = $(focusedElement).find('a, button').first();
|
2470
2510
|
|
2471
2511
|
// Click a or button tag if exists, otherwise click li tag
|
2472
|
-
!!$activatableElement.length
|
2512
|
+
if (!!$activatableElement.length) {
|
2513
|
+
$activatableElement[0].click();
|
2514
|
+
} else if (!!focusedElement) {
|
2515
|
+
focusedElement.click();
|
2516
|
+
}
|
2473
2517
|
|
2474
2518
|
// Close dropdown on ESC
|
2475
2519
|
} else if (e.which === M.keys.ESC && this.isOpen) {
|
@@ -2560,7 +2604,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2560
2604
|
};
|
2561
2605
|
|
2562
2606
|
// Countainer here will be closest ancestor with overflow: hidden
|
2563
|
-
var closestOverflowParent = this.dropdownEl.offsetParent;
|
2607
|
+
var closestOverflowParent = !!this.dropdownEl.offsetParent ? this.dropdownEl.offsetParent : this.dropdownEl.parentNode;
|
2608
|
+
|
2564
2609
|
var alignments = M.checkPossibleAlignments(this.el, closestOverflowParent, dropdownBounds, this.options.coverTrigger ? 0 : triggerBRect.height);
|
2565
2610
|
|
2566
2611
|
var verticalAlignment = 'top';
|
@@ -2628,7 +2673,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2628
2673
|
}, {
|
2629
2674
|
key: "_animateIn",
|
2630
2675
|
value: function _animateIn() {
|
2631
|
-
var
|
2676
|
+
var _this11 = this;
|
2632
2677
|
|
2633
2678
|
anim.remove(this.dropdownEl);
|
2634
2679
|
anim({
|
@@ -2637,19 +2682,18 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2637
2682
|
value: [0, 1],
|
2638
2683
|
easing: 'easeOutQuad'
|
2639
2684
|
},
|
2640
|
-
scaleX: [.3, 1],
|
2641
|
-
scaleY: [.3, 1],
|
2685
|
+
scaleX: [0.3, 1],
|
2686
|
+
scaleY: [0.3, 1],
|
2642
2687
|
duration: this.options.inDuration,
|
2643
2688
|
easing: 'easeOutQuint',
|
2644
2689
|
complete: function (anim) {
|
2645
|
-
if (
|
2646
|
-
|
2690
|
+
if (_this11.options.autoFocus) {
|
2691
|
+
_this11.dropdownEl.focus();
|
2647
2692
|
}
|
2648
2693
|
|
2649
2694
|
// onOpenEnd callback
|
2650
|
-
if (typeof
|
2651
|
-
|
2652
|
-
_this10.options.onOpenEnd.call(elem, _this10.el);
|
2695
|
+
if (typeof _this11.options.onOpenEnd === 'function') {
|
2696
|
+
_this11.options.onOpenEnd.call(_this11, _this11.el);
|
2653
2697
|
}
|
2654
2698
|
}
|
2655
2699
|
});
|
@@ -2662,7 +2706,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2662
2706
|
}, {
|
2663
2707
|
key: "_animateOut",
|
2664
2708
|
value: function _animateOut() {
|
2665
|
-
var
|
2709
|
+
var _this12 = this;
|
2666
2710
|
|
2667
2711
|
anim.remove(this.dropdownEl);
|
2668
2712
|
anim({
|
@@ -2671,17 +2715,16 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2671
2715
|
value: 0,
|
2672
2716
|
easing: 'easeOutQuint'
|
2673
2717
|
},
|
2674
|
-
scaleX: .3,
|
2675
|
-
scaleY: .3,
|
2718
|
+
scaleX: 0.3,
|
2719
|
+
scaleY: 0.3,
|
2676
2720
|
duration: this.options.outDuration,
|
2677
2721
|
easing: 'easeOutQuint',
|
2678
2722
|
complete: function (anim) {
|
2679
|
-
|
2723
|
+
_this12._resetDropdownStyles();
|
2680
2724
|
|
2681
2725
|
// onCloseEnd callback
|
2682
|
-
if (typeof
|
2683
|
-
|
2684
|
-
_this11.options.onCloseEnd.call(_this11, _this11.el);
|
2726
|
+
if (typeof _this12.options.onCloseEnd === 'function') {
|
2727
|
+
_this12.options.onCloseEnd.call(_this12, _this12.el);
|
2685
2728
|
}
|
2686
2729
|
}
|
2687
2730
|
});
|
@@ -2810,7 +2853,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2810
2853
|
|
2811
2854
|
Dropdown._dropdowns = [];
|
2812
2855
|
|
2813
|
-
|
2856
|
+
M.Dropdown = Dropdown;
|
2814
2857
|
|
2815
2858
|
if (M.jQueryLoaded) {
|
2816
2859
|
M.initializeJqueryWrapper(Dropdown, 'dropdown', 'M_Dropdown');
|
@@ -2850,9 +2893,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2850
2893
|
function Modal(el, options) {
|
2851
2894
|
_classCallCheck(this, Modal);
|
2852
2895
|
|
2853
|
-
var
|
2896
|
+
var _this13 = _possibleConstructorReturn(this, (Modal.__proto__ || Object.getPrototypeOf(Modal)).call(this, Modal, el, options));
|
2854
2897
|
|
2855
|
-
|
2898
|
+
_this13.el.M_Modal = _this13;
|
2856
2899
|
|
2857
2900
|
/**
|
2858
2901
|
* Options for the modal
|
@@ -2868,22 +2911,23 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2868
2911
|
* @prop {String} [startingTop='4%'] - startingTop
|
2869
2912
|
* @prop {String} [endingTop='10%'] - endingTop
|
2870
2913
|
*/
|
2871
|
-
|
2914
|
+
_this13.options = $.extend({}, Modal.defaults, options);
|
2872
2915
|
|
2873
2916
|
/**
|
2874
2917
|
* Describes open/close state of modal
|
2875
2918
|
* @type {Boolean}
|
2876
2919
|
*/
|
2877
|
-
|
2920
|
+
_this13.isOpen = false;
|
2878
2921
|
|
2879
|
-
|
2880
|
-
|
2881
|
-
|
2882
|
-
|
2922
|
+
_this13.id = _this13.$el.attr('id');
|
2923
|
+
_this13._openingTrigger = undefined;
|
2924
|
+
_this13.$overlay = $('<div class="modal-overlay"></div>');
|
2925
|
+
_this13.el.tabIndex = 0;
|
2926
|
+
_this13._nthModalOpened = 0;
|
2883
2927
|
|
2884
2928
|
Modal._count++;
|
2885
|
-
|
2886
|
-
return
|
2929
|
+
_this13._setupEventHandlers();
|
2930
|
+
return _this13;
|
2887
2931
|
}
|
2888
2932
|
|
2889
2933
|
_createClass(Modal, [{
|
@@ -2999,7 +3043,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
2999
3043
|
}, {
|
3000
3044
|
key: "_handleFocus",
|
3001
3045
|
value: function _handleFocus(e) {
|
3002
|
-
if
|
3046
|
+
// Only trap focus if this modal is the last model opened (prevents loops in nested modals).
|
3047
|
+
if (!this.el.contains(e.target) && this._nthModalOpened === Modal._modalsOpen) {
|
3003
3048
|
this.el.focus();
|
3004
3049
|
}
|
3005
3050
|
}
|
@@ -3011,7 +3056,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3011
3056
|
}, {
|
3012
3057
|
key: "_animateIn",
|
3013
3058
|
value: function _animateIn() {
|
3014
|
-
var
|
3059
|
+
var _this14 = this;
|
3015
3060
|
|
3016
3061
|
// Set initial styles
|
3017
3062
|
$.extend(this.el.style, {
|
@@ -3038,8 +3083,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3038
3083
|
easing: 'easeOutCubic',
|
3039
3084
|
// Handle modal onOpenEnd callback
|
3040
3085
|
complete: function () {
|
3041
|
-
if (typeof
|
3042
|
-
|
3086
|
+
if (typeof _this14.options.onOpenEnd === 'function') {
|
3087
|
+
_this14.options.onOpenEnd.call(_this14, _this14.el, _this14._openingTrigger);
|
3043
3088
|
}
|
3044
3089
|
}
|
3045
3090
|
};
|
@@ -3057,8 +3102,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3057
3102
|
$.extend(enterAnimOptions, {
|
3058
3103
|
top: [this.options.startingTop, this.options.endingTop],
|
3059
3104
|
opacity: 1,
|
3060
|
-
scaleX: [.8, 1],
|
3061
|
-
scaleY: [.8, 1]
|
3105
|
+
scaleX: [0.8, 1],
|
3106
|
+
scaleY: [0.8, 1]
|
3062
3107
|
});
|
3063
3108
|
anim(enterAnimOptions);
|
3064
3109
|
}
|
@@ -3071,7 +3116,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3071
3116
|
}, {
|
3072
3117
|
key: "_animateOut",
|
3073
3118
|
value: function _animateOut() {
|
3074
|
-
var
|
3119
|
+
var _this15 = this;
|
3075
3120
|
|
3076
3121
|
// Animate overlay
|
3077
3122
|
anim({
|
@@ -3088,12 +3133,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3088
3133
|
easing: 'easeOutCubic',
|
3089
3134
|
// Handle modal ready callback
|
3090
3135
|
complete: function () {
|
3091
|
-
|
3092
|
-
|
3136
|
+
_this15.el.style.display = 'none';
|
3137
|
+
_this15.$overlay.remove();
|
3093
3138
|
|
3094
3139
|
// Call onCloseEnd callback
|
3095
|
-
if (typeof
|
3096
|
-
|
3140
|
+
if (typeof _this15.options.onCloseEnd === 'function') {
|
3141
|
+
_this15.options.onCloseEnd.call(_this15, _this15.el);
|
3097
3142
|
}
|
3098
3143
|
}
|
3099
3144
|
};
|
@@ -3132,6 +3177,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3132
3177
|
|
3133
3178
|
this.isOpen = true;
|
3134
3179
|
Modal._modalsOpen++;
|
3180
|
+
this._nthModalOpened = Modal._modalsOpen;
|
3135
3181
|
|
3136
3182
|
// Set Z-Index based on number of currently open modals
|
3137
3183
|
this.$overlay[0].style.zIndex = 1000 + Modal._modalsOpen * 2;
|
@@ -3182,6 +3228,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3182
3228
|
|
3183
3229
|
this.isOpen = false;
|
3184
3230
|
Modal._modalsOpen--;
|
3231
|
+
this._nthModalOpened = 0;
|
3185
3232
|
|
3186
3233
|
// Call onCloseStart callback
|
3187
3234
|
if (typeof this.options.onCloseStart === 'function') {
|
@@ -3197,7 +3244,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3197
3244
|
|
3198
3245
|
if (this.options.dismissible) {
|
3199
3246
|
document.removeEventListener('keydown', this._handleKeydownBound);
|
3200
|
-
document.removeEventListener('focus', this._handleFocusBound);
|
3247
|
+
document.removeEventListener('focus', this._handleFocusBound, true);
|
3201
3248
|
}
|
3202
3249
|
|
3203
3250
|
anim.remove(this.el);
|
@@ -3280,9 +3327,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3280
3327
|
function Materialbox(el, options) {
|
3281
3328
|
_classCallCheck(this, Materialbox);
|
3282
3329
|
|
3283
|
-
var
|
3330
|
+
var _this16 = _possibleConstructorReturn(this, (Materialbox.__proto__ || Object.getPrototypeOf(Materialbox)).call(this, Materialbox, el, options));
|
3284
3331
|
|
3285
|
-
|
3332
|
+
_this16.el.M_Materialbox = _this16;
|
3286
3333
|
|
3287
3334
|
/**
|
3288
3335
|
* Options for the modal
|
@@ -3294,22 +3341,22 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3294
3341
|
* @prop {Function} onCloseStart - Callback function called before materialbox is closed
|
3295
3342
|
* @prop {Function} onCloseEnd - Callback function called after materialbox is closed
|
3296
3343
|
*/
|
3297
|
-
|
3344
|
+
_this16.options = $.extend({}, Materialbox.defaults, options);
|
3298
3345
|
|
3299
|
-
|
3300
|
-
|
3301
|
-
|
3302
|
-
|
3303
|
-
|
3304
|
-
|
3305
|
-
|
3346
|
+
_this16.overlayActive = false;
|
3347
|
+
_this16.doneAnimating = true;
|
3348
|
+
_this16.placeholder = $('<div></div>').addClass('material-placeholder');
|
3349
|
+
_this16.originalWidth = 0;
|
3350
|
+
_this16.originalHeight = 0;
|
3351
|
+
_this16.originInlineStyles = _this16.$el.attr('style');
|
3352
|
+
_this16.caption = _this16.el.getAttribute('data-caption') || '';
|
3306
3353
|
|
3307
3354
|
// Wrap
|
3308
|
-
|
3309
|
-
|
3355
|
+
_this16.$el.before(_this16.placeholder);
|
3356
|
+
_this16.placeholder.append(_this16.$el);
|
3310
3357
|
|
3311
|
-
|
3312
|
-
return
|
3358
|
+
_this16._setupEventHandlers();
|
3359
|
+
return _this16;
|
3313
3360
|
}
|
3314
3361
|
|
3315
3362
|
_createClass(Materialbox, [{
|
@@ -3322,6 +3369,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3322
3369
|
value: function destroy() {
|
3323
3370
|
this._removeEventHandlers();
|
3324
3371
|
this.el.M_Materialbox = undefined;
|
3372
|
+
|
3373
|
+
// Unwrap image
|
3374
|
+
$(this.placeholder).after(this.el).remove();
|
3375
|
+
|
3376
|
+
this.$el.removeAttr('style');
|
3325
3377
|
}
|
3326
3378
|
|
3327
3379
|
/**
|
@@ -3429,7 +3481,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3429
3481
|
}, {
|
3430
3482
|
key: "_animateImageIn",
|
3431
3483
|
value: function _animateImageIn() {
|
3432
|
-
var
|
3484
|
+
var _this17 = this;
|
3433
3485
|
|
3434
3486
|
var animOptions = {
|
3435
3487
|
targets: this.el,
|
@@ -3440,11 +3492,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3440
3492
|
duration: this.options.inDuration,
|
3441
3493
|
easing: 'easeOutQuad',
|
3442
3494
|
complete: function () {
|
3443
|
-
|
3495
|
+
_this17.doneAnimating = true;
|
3444
3496
|
|
3445
3497
|
// onOpenEnd callback
|
3446
|
-
if (typeof
|
3447
|
-
|
3498
|
+
if (typeof _this17.options.onOpenEnd === 'function') {
|
3499
|
+
_this17.options.onOpenEnd.call(_this17, _this17.el);
|
3448
3500
|
}
|
3449
3501
|
}
|
3450
3502
|
};
|
@@ -3469,7 +3521,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3469
3521
|
}, {
|
3470
3522
|
key: "_animateImageOut",
|
3471
3523
|
value: function _animateImageOut() {
|
3472
|
-
var
|
3524
|
+
var _this18 = this;
|
3473
3525
|
|
3474
3526
|
var animOptions = {
|
3475
3527
|
targets: this.el,
|
@@ -3480,7 +3532,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3480
3532
|
duration: this.options.outDuration,
|
3481
3533
|
easing: 'easeOutQuad',
|
3482
3534
|
complete: function () {
|
3483
|
-
|
3535
|
+
_this18.placeholder.css({
|
3484
3536
|
height: '',
|
3485
3537
|
width: '',
|
3486
3538
|
position: '',
|
@@ -3489,28 +3541,28 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3489
3541
|
});
|
3490
3542
|
|
3491
3543
|
// Revert to width or height attribute
|
3492
|
-
if (
|
3493
|
-
|
3544
|
+
if (_this18.attrWidth) {
|
3545
|
+
_this18.$el.attr('width', _this18.attrWidth);
|
3494
3546
|
}
|
3495
|
-
if (
|
3496
|
-
|
3547
|
+
if (_this18.attrHeight) {
|
3548
|
+
_this18.$el.attr('height', _this18.attrHeight);
|
3497
3549
|
}
|
3498
3550
|
|
3499
|
-
|
3500
|
-
|
3551
|
+
_this18.$el.removeAttr('style');
|
3552
|
+
_this18.originInlineStyles && _this18.$el.attr('style', _this18.originInlineStyles);
|
3501
3553
|
|
3502
3554
|
// Remove class
|
3503
|
-
|
3504
|
-
|
3555
|
+
_this18.$el.removeClass('active');
|
3556
|
+
_this18.doneAnimating = true;
|
3505
3557
|
|
3506
3558
|
// Remove overflow overrides on ancestors
|
3507
|
-
if (
|
3508
|
-
|
3559
|
+
if (_this18.ancestorsChanged.length) {
|
3560
|
+
_this18.ancestorsChanged.css('overflow', '');
|
3509
3561
|
}
|
3510
3562
|
|
3511
3563
|
// onCloseEnd callback
|
3512
|
-
if (typeof
|
3513
|
-
|
3564
|
+
if (typeof _this18.options.onCloseEnd === 'function') {
|
3565
|
+
_this18.options.onCloseEnd.call(_this18, _this18.el);
|
3514
3566
|
}
|
3515
3567
|
}
|
3516
3568
|
};
|
@@ -3527,7 +3579,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3527
3579
|
value: function _updateVars() {
|
3528
3580
|
this.windowWidth = window.innerWidth;
|
3529
3581
|
this.windowHeight = window.innerHeight;
|
3530
|
-
this.caption = this.el.getAttribute('data-caption') ||
|
3582
|
+
this.caption = this.el.getAttribute('data-caption') || '';
|
3531
3583
|
}
|
3532
3584
|
|
3533
3585
|
/**
|
@@ -3537,7 +3589,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3537
3589
|
}, {
|
3538
3590
|
key: "open",
|
3539
3591
|
value: function open() {
|
3540
|
-
var
|
3592
|
+
var _this19 = this;
|
3541
3593
|
|
3542
3594
|
this._updateVars();
|
3543
3595
|
this.originalWidth = this.el.getBoundingClientRect().width;
|
@@ -3587,8 +3639,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3587
3639
|
this.$overlay = $('<div id="materialbox-overlay"></div>').css({
|
3588
3640
|
opacity: 0
|
3589
3641
|
}).one('click', function () {
|
3590
|
-
if (
|
3591
|
-
|
3642
|
+
if (_this19.doneAnimating) {
|
3643
|
+
_this19.close();
|
3592
3644
|
}
|
3593
3645
|
});
|
3594
3646
|
|
@@ -3616,14 +3668,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3616
3668
|
});
|
3617
3669
|
|
3618
3670
|
// Add and animate caption if it exists
|
3619
|
-
if (this.caption !==
|
3671
|
+
if (this.caption !== '') {
|
3620
3672
|
if (this.$photocaption) {
|
3621
3673
|
anim.remove(this.$photoCaption[0]);
|
3622
3674
|
}
|
3623
3675
|
this.$photoCaption = $('<div class="materialbox-caption"></div>');
|
3624
3676
|
this.$photoCaption.text(this.caption);
|
3625
3677
|
$('body').append(this.$photoCaption);
|
3626
|
-
this.$photoCaption.css({
|
3678
|
+
this.$photoCaption.css({ display: 'inline' });
|
3627
3679
|
|
3628
3680
|
anim({
|
3629
3681
|
targets: this.$photoCaption[0],
|
@@ -3669,7 +3721,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3669
3721
|
}, {
|
3670
3722
|
key: "close",
|
3671
3723
|
value: function close() {
|
3672
|
-
var
|
3724
|
+
var _this20 = this;
|
3673
3725
|
|
3674
3726
|
this._updateVars();
|
3675
3727
|
this.doneAnimating = false;
|
@@ -3682,7 +3734,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3682
3734
|
anim.remove(this.el);
|
3683
3735
|
anim.remove(this.$overlay[0]);
|
3684
3736
|
|
3685
|
-
if (this.caption !==
|
3737
|
+
if (this.caption !== '') {
|
3686
3738
|
anim.remove(this.$photoCaption[0]);
|
3687
3739
|
}
|
3688
3740
|
|
@@ -3697,22 +3749,22 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3697
3749
|
duration: this.options.outDuration,
|
3698
3750
|
easing: 'easeOutQuad',
|
3699
3751
|
complete: function () {
|
3700
|
-
|
3701
|
-
|
3752
|
+
_this20.overlayActive = false;
|
3753
|
+
_this20.$overlay.remove();
|
3702
3754
|
}
|
3703
3755
|
});
|
3704
3756
|
|
3705
3757
|
this._animateImageOut();
|
3706
3758
|
|
3707
3759
|
// Remove Caption + reset css settings on image
|
3708
|
-
if (this.caption !==
|
3760
|
+
if (this.caption !== '') {
|
3709
3761
|
anim({
|
3710
3762
|
targets: this.$photoCaption[0],
|
3711
3763
|
opacity: 0,
|
3712
3764
|
duration: this.options.outDuration,
|
3713
3765
|
easing: 'easeOutQuad',
|
3714
3766
|
complete: function () {
|
3715
|
-
|
3767
|
+
_this20.$photoCaption.remove();
|
3716
3768
|
}
|
3717
3769
|
});
|
3718
3770
|
}
|
@@ -3762,30 +3814,30 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3762
3814
|
function Parallax(el, options) {
|
3763
3815
|
_classCallCheck(this, Parallax);
|
3764
3816
|
|
3765
|
-
var
|
3817
|
+
var _this21 = _possibleConstructorReturn(this, (Parallax.__proto__ || Object.getPrototypeOf(Parallax)).call(this, Parallax, el, options));
|
3766
3818
|
|
3767
|
-
|
3819
|
+
_this21.el.M_Parallax = _this21;
|
3768
3820
|
|
3769
3821
|
/**
|
3770
3822
|
* Options for the Parallax
|
3771
3823
|
* @member Parallax#options
|
3772
3824
|
* @prop {Number} responsiveThreshold
|
3773
3825
|
*/
|
3774
|
-
|
3775
|
-
|
3826
|
+
_this21.options = $.extend({}, Parallax.defaults, options);
|
3827
|
+
_this21._enabled = window.innerWidth > _this21.options.responsiveThreshold;
|
3776
3828
|
|
3777
|
-
|
3778
|
-
|
3829
|
+
_this21.$img = _this21.$el.find('img').first();
|
3830
|
+
_this21.$img.each(function () {
|
3779
3831
|
var el = this;
|
3780
|
-
if (el.complete) $(el).trigger(
|
3832
|
+
if (el.complete) $(el).trigger('load');
|
3781
3833
|
});
|
3782
3834
|
|
3783
|
-
|
3784
|
-
|
3785
|
-
|
3835
|
+
_this21._updateParallax();
|
3836
|
+
_this21._setupEventHandlers();
|
3837
|
+
_this21._setupStyles();
|
3786
3838
|
|
3787
|
-
Parallax._parallaxes.push(
|
3788
|
-
return
|
3839
|
+
Parallax._parallaxes.push(_this21);
|
3840
|
+
return _this21;
|
3789
3841
|
}
|
3790
3842
|
|
3791
3843
|
_createClass(Parallax, [{
|
@@ -3939,9 +3991,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3939
3991
|
function Tabs(el, options) {
|
3940
3992
|
_classCallCheck(this, Tabs);
|
3941
3993
|
|
3942
|
-
var
|
3994
|
+
var _this22 = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, Tabs, el, options));
|
3943
3995
|
|
3944
|
-
|
3996
|
+
_this22.el.M_Tabs = _this22;
|
3945
3997
|
|
3946
3998
|
/**
|
3947
3999
|
* Options for the Tabs
|
@@ -3951,23 +4003,26 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
3951
4003
|
* @prop {Boolean} swipeable
|
3952
4004
|
* @prop {Number} responsiveThreshold
|
3953
4005
|
*/
|
3954
|
-
|
4006
|
+
_this22.options = $.extend({}, Tabs.defaults, options);
|
3955
4007
|
|
3956
4008
|
// Setup
|
3957
|
-
|
3958
|
-
|
3959
|
-
|
3960
|
-
|
3961
|
-
|
3962
|
-
|
3963
|
-
|
3964
|
-
_this21._setupSwipeableTabs();
|
4009
|
+
_this22.$tabLinks = _this22.$el.children('li.tab').children('a');
|
4010
|
+
_this22.index = 0;
|
4011
|
+
_this22._setupActiveTabLink();
|
4012
|
+
|
4013
|
+
// Setup tabs content
|
4014
|
+
if (_this22.options.swipeable) {
|
4015
|
+
_this22._setupSwipeableTabs();
|
3965
4016
|
} else {
|
3966
|
-
|
4017
|
+
_this22._setupNormalTabs();
|
3967
4018
|
}
|
3968
4019
|
|
3969
|
-
|
3970
|
-
|
4020
|
+
// Setup tabs indicator after content to ensure accurate widths
|
4021
|
+
_this22._setTabsAndTabWidth();
|
4022
|
+
_this22._createIndicator();
|
4023
|
+
|
4024
|
+
_this22._setupEventHandlers();
|
4025
|
+
return _this22;
|
3971
4026
|
}
|
3972
4027
|
|
3973
4028
|
_createClass(Tabs, [{
|
@@ -4038,7 +4093,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4038
4093
|
}, {
|
4039
4094
|
key: "_handleTabClick",
|
4040
4095
|
value: function _handleTabClick(e) {
|
4041
|
-
var
|
4096
|
+
var _this23 = this;
|
4042
4097
|
|
4043
4098
|
var tab = $(e.target).closest('li.tab');
|
4044
4099
|
var tabLink = $(e.target).closest('a');
|
@@ -4054,12 +4109,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4054
4109
|
}
|
4055
4110
|
|
4056
4111
|
// Act as regular link if target attribute is specified.
|
4057
|
-
if (!!tabLink.attr(
|
4112
|
+
if (!!tabLink.attr('target')) {
|
4058
4113
|
return;
|
4059
4114
|
}
|
4060
4115
|
|
4061
|
-
this._setTabsAndTabWidth();
|
4062
|
-
|
4063
4116
|
// Make the old tab inactive.
|
4064
4117
|
this.$activeTabLink.removeClass('active');
|
4065
4118
|
var $oldContent = this.$content;
|
@@ -4078,8 +4131,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4078
4131
|
if (this.options.swipeable) {
|
4079
4132
|
if (this._tabsCarousel) {
|
4080
4133
|
this._tabsCarousel.set(this.index, function () {
|
4081
|
-
if (typeof
|
4082
|
-
|
4134
|
+
if (typeof _this23.options.onShow === 'function') {
|
4135
|
+
_this23.options.onShow.call(_this23, _this23.$content[0]);
|
4083
4136
|
}
|
4084
4137
|
});
|
4085
4138
|
}
|
@@ -4098,6 +4151,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4098
4151
|
}
|
4099
4152
|
}
|
4100
4153
|
|
4154
|
+
// Update widths after content is swapped (scrollbar bugfix)
|
4155
|
+
this._setTabsAndTabWidth();
|
4156
|
+
|
4101
4157
|
// Update indicator
|
4102
4158
|
this._animateIndicator(prevIndex);
|
4103
4159
|
|
@@ -4112,7 +4168,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4112
4168
|
}, {
|
4113
4169
|
key: "_createIndicator",
|
4114
4170
|
value: function _createIndicator() {
|
4115
|
-
var
|
4171
|
+
var _this24 = this;
|
4116
4172
|
|
4117
4173
|
var indicator = document.createElement('li');
|
4118
4174
|
indicator.classList.add('indicator');
|
@@ -4121,8 +4177,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4121
4177
|
this._indicator = indicator;
|
4122
4178
|
|
4123
4179
|
setTimeout(function () {
|
4124
|
-
|
4125
|
-
|
4180
|
+
_this24._indicator.style.left = _this24._calcLeftPos(_this24.$activeTabLink) + 'px';
|
4181
|
+
_this24._indicator.style.right = _this24._calcRightPos(_this24.$activeTabLink) + 'px';
|
4126
4182
|
}, 0);
|
4127
4183
|
}
|
4128
4184
|
|
@@ -4162,7 +4218,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4162
4218
|
}, {
|
4163
4219
|
key: "_setupSwipeableTabs",
|
4164
4220
|
value: function _setupSwipeableTabs() {
|
4165
|
-
var
|
4221
|
+
var _this25 = this;
|
4166
4222
|
|
4167
4223
|
// Change swipeable according to responsive threshold
|
4168
4224
|
if (window.innerWidth > this.options.responsiveThreshold) {
|
@@ -4188,14 +4244,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4188
4244
|
fullWidth: true,
|
4189
4245
|
noWrap: true,
|
4190
4246
|
onCycleTo: function (item) {
|
4191
|
-
var prevIndex =
|
4192
|
-
|
4193
|
-
|
4194
|
-
|
4195
|
-
|
4196
|
-
|
4197
|
-
if (typeof
|
4198
|
-
|
4247
|
+
var prevIndex = _this25.index;
|
4248
|
+
_this25.index = $(item).index();
|
4249
|
+
_this25.$activeTabLink.removeClass('active');
|
4250
|
+
_this25.$activeTabLink = _this25.$tabLinks.eq(_this25.index);
|
4251
|
+
_this25.$activeTabLink.addClass('active');
|
4252
|
+
_this25._animateIndicator(prevIndex);
|
4253
|
+
if (typeof _this25.options.onShow === 'function') {
|
4254
|
+
_this25.options.onShow.call(_this25, _this25.$content[0]);
|
4199
4255
|
}
|
4200
4256
|
}
|
4201
4257
|
});
|
@@ -4290,6 +4346,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4290
4346
|
}, {
|
4291
4347
|
key: "updateTabIndicator",
|
4292
4348
|
value: function updateTabIndicator() {
|
4349
|
+
this._setTabsAndTabWidth();
|
4293
4350
|
this._animateIndicator(this.index);
|
4294
4351
|
}
|
4295
4352
|
|
@@ -4367,7 +4424,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4367
4424
|
return Tabs;
|
4368
4425
|
}(Component);
|
4369
4426
|
|
4370
|
-
|
4427
|
+
M.Tabs = Tabs;
|
4371
4428
|
|
4372
4429
|
if (M.jQueryLoaded) {
|
4373
4430
|
M.initializeJqueryWrapper(Tabs, 'tabs', 'M_Tabs');
|
@@ -4404,17 +4461,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4404
4461
|
function Tooltip(el, options) {
|
4405
4462
|
_classCallCheck(this, Tooltip);
|
4406
4463
|
|
4407
|
-
var
|
4464
|
+
var _this26 = _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).call(this, Tooltip, el, options));
|
4408
4465
|
|
4409
|
-
|
4410
|
-
|
4466
|
+
_this26.el.M_Tooltip = _this26;
|
4467
|
+
_this26.options = $.extend({}, Tooltip.defaults, options);
|
4411
4468
|
|
4412
|
-
|
4413
|
-
|
4414
|
-
|
4415
|
-
|
4416
|
-
|
4417
|
-
return
|
4469
|
+
_this26.isOpen = false;
|
4470
|
+
_this26.isHovered = false;
|
4471
|
+
_this26.isFocused = false;
|
4472
|
+
_this26._appendTooltipEl();
|
4473
|
+
_this26._setupEventHandlers();
|
4474
|
+
return _this26;
|
4418
4475
|
}
|
4419
4476
|
|
4420
4477
|
_createClass(Tooltip, [{
|
@@ -4469,16 +4526,16 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4469
4526
|
}
|
4470
4527
|
}, {
|
4471
4528
|
key: "open",
|
4472
|
-
value: function open() {
|
4529
|
+
value: function open(isManual) {
|
4473
4530
|
if (this.isOpen) {
|
4474
4531
|
return;
|
4475
4532
|
}
|
4476
|
-
|
4533
|
+
isManual = isManual === undefined ? true : undefined; // Default value true
|
4477
4534
|
this.isOpen = true;
|
4478
4535
|
// Update tooltip content with HTML attribute options
|
4479
4536
|
this.options = $.extend({}, this.options, this._getAttributeOptions());
|
4480
4537
|
this._updateTooltipContent();
|
4481
|
-
this._setEnterDelayTimeout();
|
4538
|
+
this._setEnterDelayTimeout(isManual);
|
4482
4539
|
}
|
4483
4540
|
}, {
|
4484
4541
|
key: "close",
|
@@ -4487,6 +4544,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4487
4544
|
return;
|
4488
4545
|
}
|
4489
4546
|
|
4547
|
+
this.isHovered = false;
|
4548
|
+
this.isFocused = false;
|
4490
4549
|
this.isOpen = false;
|
4491
4550
|
this._setExitDelayTimeout();
|
4492
4551
|
}
|
@@ -4498,16 +4557,16 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4498
4557
|
}, {
|
4499
4558
|
key: "_setExitDelayTimeout",
|
4500
4559
|
value: function _setExitDelayTimeout() {
|
4501
|
-
var
|
4560
|
+
var _this27 = this;
|
4502
4561
|
|
4503
4562
|
clearTimeout(this._exitDelayTimeout);
|
4504
4563
|
|
4505
4564
|
this._exitDelayTimeout = setTimeout(function () {
|
4506
|
-
if (
|
4565
|
+
if (_this27.isHovered || _this27.isFocused) {
|
4507
4566
|
return;
|
4508
4567
|
}
|
4509
4568
|
|
4510
|
-
|
4569
|
+
_this27._animateOut();
|
4511
4570
|
}, this.options.exitDelay);
|
4512
4571
|
}
|
4513
4572
|
|
@@ -4517,17 +4576,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4517
4576
|
|
4518
4577
|
}, {
|
4519
4578
|
key: "_setEnterDelayTimeout",
|
4520
|
-
value: function _setEnterDelayTimeout() {
|
4521
|
-
var
|
4579
|
+
value: function _setEnterDelayTimeout(isManual) {
|
4580
|
+
var _this28 = this;
|
4522
4581
|
|
4523
4582
|
clearTimeout(this._enterDelayTimeout);
|
4524
4583
|
|
4525
4584
|
this._enterDelayTimeout = setTimeout(function () {
|
4526
|
-
if (!
|
4585
|
+
if (!_this28.isHovered && !_this28.isFocused && !isManual) {
|
4527
4586
|
return;
|
4528
4587
|
}
|
4529
4588
|
|
4530
|
-
|
4589
|
+
_this28._animateIn();
|
4531
4590
|
}, this.options.enterDelay);
|
4532
4591
|
}
|
4533
4592
|
}, {
|
@@ -4640,19 +4699,23 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
4640
4699
|
key: "_handleMouseEnter",
|
4641
4700
|
value: function _handleMouseEnter() {
|
4642
4701
|
this.isHovered = true;
|
4643
|
-
this.
|
4702
|
+
this.isFocused = false; // Allows close of tooltip when opened by focus.
|
4703
|
+
this.open(false);
|
4644
4704
|
}
|
4645
4705
|
}, {
|
4646
4706
|
key: "_handleMouseLeave",
|
4647
4707
|
value: function _handleMouseLeave() {
|
4648
4708
|
this.isHovered = false;
|
4709
|
+
this.isFocused = false; // Allows close of tooltip when opened by focus.
|
4649
4710
|
this.close();
|
4650
4711
|
}
|
4651
4712
|
}, {
|
4652
4713
|
key: "_handleFocus",
|
4653
4714
|
value: function _handleFocus() {
|
4654
|
-
|
4655
|
-
|
4715
|
+
if (M.tabPressed) {
|
4716
|
+
this.isFocused = true;
|
4717
|
+
this.open(false);
|
4718
|
+
}
|
4656
4719
|
}
|
4657
4720
|
}, {
|
4658
4721
|
key: "_handleBlur",
|
@@ -5085,6 +5148,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5085
5148
|
var toastElement = this._createToast();
|
5086
5149
|
toastElement.M_Toast = this;
|
5087
5150
|
this.el = toastElement;
|
5151
|
+
this.$el = $(toastElement);
|
5088
5152
|
this._animateIn();
|
5089
5153
|
this._setTimer();
|
5090
5154
|
}
|
@@ -5135,7 +5199,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5135
5199
|
targets: this.el,
|
5136
5200
|
top: 0,
|
5137
5201
|
opacity: 1,
|
5138
|
-
duration:
|
5202
|
+
duration: this.options.inDuration,
|
5139
5203
|
easing: 'easeOutCubic'
|
5140
5204
|
});
|
5141
5205
|
}
|
@@ -5148,18 +5212,18 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5148
5212
|
}, {
|
5149
5213
|
key: "_setTimer",
|
5150
5214
|
value: function _setTimer() {
|
5151
|
-
var
|
5215
|
+
var _this29 = this;
|
5152
5216
|
|
5153
5217
|
if (this.timeRemaining !== Infinity) {
|
5154
5218
|
this.counterInterval = setInterval(function () {
|
5155
5219
|
// If toast is not being dragged, decrease its time remaining
|
5156
|
-
if (!
|
5157
|
-
|
5220
|
+
if (!_this29.panning) {
|
5221
|
+
_this29.timeRemaining -= 20;
|
5158
5222
|
}
|
5159
5223
|
|
5160
5224
|
// Animate toast out
|
5161
|
-
if (
|
5162
|
-
|
5225
|
+
if (_this29.timeRemaining <= 0) {
|
5226
|
+
_this29.dismiss();
|
5163
5227
|
}
|
5164
5228
|
}, 20);
|
5165
5229
|
}
|
@@ -5172,7 +5236,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5172
5236
|
}, {
|
5173
5237
|
key: "dismiss",
|
5174
5238
|
value: function dismiss() {
|
5175
|
-
var
|
5239
|
+
var _this30 = this;
|
5176
5240
|
|
5177
5241
|
window.clearInterval(this.counterInterval);
|
5178
5242
|
var activationDistance = this.el.offsetWidth * this.options.activationPercent;
|
@@ -5191,12 +5255,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5191
5255
|
easing: 'easeOutExpo',
|
5192
5256
|
complete: function () {
|
5193
5257
|
// Call the optional callback
|
5194
|
-
if (typeof
|
5195
|
-
|
5258
|
+
if (typeof _this30.options.completeCallback === 'function') {
|
5259
|
+
_this30.options.completeCallback();
|
5196
5260
|
}
|
5197
5261
|
// Remove toast from DOM
|
5198
|
-
|
5199
|
-
Toast._toasts.splice(Toast._toasts.indexOf(
|
5262
|
+
_this30.$el.remove();
|
5263
|
+
Toast._toasts.splice(Toast._toasts.indexOf(_this30), 1);
|
5200
5264
|
if (Toast._toasts.length === 0) {
|
5201
5265
|
Toast._removeContainer();
|
5202
5266
|
}
|
@@ -5249,7 +5313,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5249
5313
|
document.removeEventListener('mousemove', Toast._onDragMove);
|
5250
5314
|
document.removeEventListener('mouseup', Toast._onDragEnd);
|
5251
5315
|
|
5252
|
-
Toast._container.
|
5316
|
+
$(Toast._container).remove();
|
5253
5317
|
Toast._container = null;
|
5254
5318
|
}
|
5255
5319
|
|
@@ -5422,10 +5486,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5422
5486
|
function Sidenav(el, options) {
|
5423
5487
|
_classCallCheck(this, Sidenav);
|
5424
5488
|
|
5425
|
-
var
|
5489
|
+
var _this31 = _possibleConstructorReturn(this, (Sidenav.__proto__ || Object.getPrototypeOf(Sidenav)).call(this, Sidenav, el, options));
|
5426
5490
|
|
5427
|
-
|
5428
|
-
|
5491
|
+
_this31.el.M_Sidenav = _this31;
|
5492
|
+
_this31.id = _this31.$el.attr('id');
|
5429
5493
|
|
5430
5494
|
/**
|
5431
5495
|
* Options for the Sidenav
|
@@ -5439,38 +5503,38 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5439
5503
|
* @prop {Function} onCloseStart - Function called when sidenav starts exiting
|
5440
5504
|
* @prop {Function} onCloseEnd - Function called when sidenav finishes exiting
|
5441
5505
|
*/
|
5442
|
-
|
5506
|
+
_this31.options = $.extend({}, Sidenav.defaults, options);
|
5443
5507
|
|
5444
5508
|
/**
|
5445
5509
|
* Describes open/close state of Sidenav
|
5446
5510
|
* @type {Boolean}
|
5447
5511
|
*/
|
5448
|
-
|
5512
|
+
_this31.isOpen = false;
|
5449
5513
|
|
5450
5514
|
/**
|
5451
5515
|
* Describes if Sidenav is fixed
|
5452
5516
|
* @type {Boolean}
|
5453
5517
|
*/
|
5454
|
-
|
5518
|
+
_this31.isFixed = _this31.el.classList.contains('sidenav-fixed');
|
5455
5519
|
|
5456
5520
|
/**
|
5457
5521
|
* Describes if Sidenav is being draggeed
|
5458
5522
|
* @type {Boolean}
|
5459
5523
|
*/
|
5460
|
-
|
5524
|
+
_this31.isDragged = false;
|
5461
5525
|
|
5462
5526
|
// Window size variables for window resize checks
|
5463
|
-
|
5464
|
-
|
5527
|
+
_this31.lastWindowWidth = window.innerWidth;
|
5528
|
+
_this31.lastWindowHeight = window.innerHeight;
|
5465
5529
|
|
5466
|
-
|
5467
|
-
|
5468
|
-
|
5469
|
-
|
5470
|
-
|
5530
|
+
_this31._createOverlay();
|
5531
|
+
_this31._createDragTarget();
|
5532
|
+
_this31._setupEventHandlers();
|
5533
|
+
_this31._setupClasses();
|
5534
|
+
_this31._setupFixed();
|
5471
5535
|
|
5472
|
-
Sidenav._sidenavs.push(
|
5473
|
-
return
|
5536
|
+
Sidenav._sidenavs.push(_this31);
|
5537
|
+
return _this31;
|
5474
5538
|
}
|
5475
5539
|
|
5476
5540
|
_createClass(Sidenav, [{
|
@@ -5482,9 +5546,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5482
5546
|
*/
|
5483
5547
|
value: function destroy() {
|
5484
5548
|
this._removeEventHandlers();
|
5549
|
+
this._enableBodyScrolling();
|
5485
5550
|
this._overlay.parentNode.removeChild(this._overlay);
|
5486
5551
|
this.dragTarget.parentNode.removeChild(this.dragTarget);
|
5487
5552
|
this.el.M_Sidenav = undefined;
|
5553
|
+
this.el.style.transform = '';
|
5488
5554
|
|
5489
5555
|
var index = Sidenav._sidenavs.indexOf(this);
|
5490
5556
|
if (index >= 0) {
|
@@ -5673,7 +5739,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5673
5739
|
key: "_handleDragTargetRelease",
|
5674
5740
|
value: function _handleDragTargetRelease() {
|
5675
5741
|
if (this.isDragged) {
|
5676
|
-
if (this.percentOpen > .
|
5742
|
+
if (this.percentOpen > 0.2) {
|
5677
5743
|
this.open();
|
5678
5744
|
} else {
|
5679
5745
|
this._animateOut();
|
@@ -5740,7 +5806,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5740
5806
|
key: "_handleCloseRelease",
|
5741
5807
|
value: function _handleCloseRelease() {
|
5742
5808
|
if (this.isOpen && this.isDragged) {
|
5743
|
-
if (this.percentOpen > .
|
5809
|
+
if (this.percentOpen > 0.8) {
|
5744
5810
|
this._animateIn();
|
5745
5811
|
} else {
|
5746
5812
|
this.close();
|
@@ -5905,7 +5971,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5905
5971
|
}, {
|
5906
5972
|
key: "_animateSidenavIn",
|
5907
5973
|
value: function _animateSidenavIn() {
|
5908
|
-
var
|
5974
|
+
var _this32 = this;
|
5909
5975
|
|
5910
5976
|
var slideOutPercent = this.options.edge === 'left' ? -1 : 1;
|
5911
5977
|
if (this.isDragged) {
|
@@ -5920,8 +5986,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5920
5986
|
easing: 'easeOutQuad',
|
5921
5987
|
complete: function () {
|
5922
5988
|
// Run onOpenEnd callback
|
5923
|
-
if (typeof
|
5924
|
-
|
5989
|
+
if (typeof _this32.options.onOpenEnd === 'function') {
|
5990
|
+
_this32.options.onOpenEnd.call(_this32, _this32.el);
|
5925
5991
|
}
|
5926
5992
|
}
|
5927
5993
|
});
|
@@ -5955,7 +6021,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5955
6021
|
}, {
|
5956
6022
|
key: "_animateSidenavOut",
|
5957
6023
|
value: function _animateSidenavOut() {
|
5958
|
-
var
|
6024
|
+
var _this33 = this;
|
5959
6025
|
|
5960
6026
|
var endPercent = this.options.edge === 'left' ? -1 : 1;
|
5961
6027
|
var slideOutPercent = 0;
|
@@ -5971,8 +6037,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5971
6037
|
easing: 'easeOutQuad',
|
5972
6038
|
complete: function () {
|
5973
6039
|
// Run onOpenEnd callback
|
5974
|
-
if (typeof
|
5975
|
-
|
6040
|
+
if (typeof _this33.options.onCloseEnd === 'function') {
|
6041
|
+
_this33.options.onCloseEnd.call(_this33, _this33.el);
|
5976
6042
|
}
|
5977
6043
|
}
|
5978
6044
|
});
|
@@ -5980,7 +6046,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5980
6046
|
}, {
|
5981
6047
|
key: "_animateOverlayOut",
|
5982
6048
|
value: function _animateOverlayOut() {
|
5983
|
-
var
|
6049
|
+
var _this34 = this;
|
5984
6050
|
|
5985
6051
|
anim.remove(this._overlay);
|
5986
6052
|
anim({
|
@@ -5989,7 +6055,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
5989
6055
|
duration: this.options.outDuration,
|
5990
6056
|
easing: 'easeOutQuad',
|
5991
6057
|
complete: function () {
|
5992
|
-
$(
|
6058
|
+
$(_this34._overlay).css('display', 'none');
|
5993
6059
|
}
|
5994
6060
|
});
|
5995
6061
|
}
|
@@ -6028,7 +6094,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6028
6094
|
|
6029
6095
|
Sidenav._sidenavs = [];
|
6030
6096
|
|
6031
|
-
|
6097
|
+
M.Sidenav = Sidenav;
|
6032
6098
|
|
6033
6099
|
if (M.jQueryLoaded) {
|
6034
6100
|
M.initializeJqueryWrapper(Sidenav, 'sidenav', 'M_Sidenav');
|
@@ -6063,9 +6129,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6063
6129
|
function ScrollSpy(el, options) {
|
6064
6130
|
_classCallCheck(this, ScrollSpy);
|
6065
6131
|
|
6066
|
-
var
|
6132
|
+
var _this35 = _possibleConstructorReturn(this, (ScrollSpy.__proto__ || Object.getPrototypeOf(ScrollSpy)).call(this, ScrollSpy, el, options));
|
6067
6133
|
|
6068
|
-
|
6134
|
+
_this35.el.M_ScrollSpy = _this35;
|
6069
6135
|
|
6070
6136
|
/**
|
6071
6137
|
* Options for the modal
|
@@ -6075,17 +6141,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6075
6141
|
* @prop {String} [activeClass='active'] - Class applied to active elements
|
6076
6142
|
* @prop {Function} [getActiveElement] - Used to find active element
|
6077
6143
|
*/
|
6078
|
-
|
6144
|
+
_this35.options = $.extend({}, ScrollSpy.defaults, options);
|
6079
6145
|
|
6080
6146
|
// setup
|
6081
|
-
ScrollSpy._elements.push(
|
6147
|
+
ScrollSpy._elements.push(_this35);
|
6082
6148
|
ScrollSpy._count++;
|
6083
6149
|
ScrollSpy._increment++;
|
6084
|
-
|
6085
|
-
|
6086
|
-
|
6087
|
-
|
6088
|
-
return
|
6150
|
+
_this35.tickId = -1;
|
6151
|
+
_this35.id = ScrollSpy._increment;
|
6152
|
+
_this35._setupEventHandlers();
|
6153
|
+
_this35._handleWindowScroll();
|
6154
|
+
return _this35;
|
6089
6155
|
}
|
6090
6156
|
|
6091
6157
|
_createClass(ScrollSpy, [{
|
@@ -6238,7 +6304,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6238
6304
|
}, {
|
6239
6305
|
key: "_exit",
|
6240
6306
|
value: function _exit() {
|
6241
|
-
var
|
6307
|
+
var _this36 = this;
|
6242
6308
|
|
6243
6309
|
ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (value) {
|
6244
6310
|
return value.height() != 0;
|
@@ -6248,7 +6314,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6248
6314
|
$(this.options.getActiveElement(ScrollSpy._visibleElements[0].attr('id'))).removeClass(this.options.activeClass);
|
6249
6315
|
|
6250
6316
|
ScrollSpy._visibleElements = ScrollSpy._visibleElements.filter(function (el) {
|
6251
|
-
return el.attr('id') !=
|
6317
|
+
return el.attr('id') != _this36.$el.attr('id');
|
6252
6318
|
});
|
6253
6319
|
if (ScrollSpy._visibleElements[0]) {
|
6254
6320
|
// Check if empty
|
@@ -6383,9 +6449,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6383
6449
|
function Autocomplete(el, options) {
|
6384
6450
|
_classCallCheck(this, Autocomplete);
|
6385
6451
|
|
6386
|
-
var
|
6452
|
+
var _this37 = _possibleConstructorReturn(this, (Autocomplete.__proto__ || Object.getPrototypeOf(Autocomplete)).call(this, Autocomplete, el, options));
|
6387
6453
|
|
6388
|
-
|
6454
|
+
_this37.el.M_Autocomplete = _this37;
|
6389
6455
|
|
6390
6456
|
/**
|
6391
6457
|
* Options for the autocomplete
|
@@ -6399,19 +6465,20 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6399
6465
|
* @prop {Boolean} noWrap
|
6400
6466
|
* @prop {Function} onCycleTo
|
6401
6467
|
*/
|
6402
|
-
|
6468
|
+
_this37.options = $.extend({}, Autocomplete.defaults, options);
|
6403
6469
|
|
6404
6470
|
// Setup
|
6405
|
-
|
6406
|
-
|
6407
|
-
|
6408
|
-
|
6409
|
-
|
6410
|
-
|
6411
|
-
|
6412
|
-
|
6413
|
-
|
6414
|
-
|
6471
|
+
_this37.isOpen = false;
|
6472
|
+
_this37.count = 0;
|
6473
|
+
_this37.activeIndex = -1;
|
6474
|
+
_this37.oldVal;
|
6475
|
+
_this37.$inputField = _this37.$el.closest('.input-field');
|
6476
|
+
_this37.$active = $();
|
6477
|
+
_this37._mousedown = false;
|
6478
|
+
_this37._setupDropdown();
|
6479
|
+
|
6480
|
+
_this37._setupEventHandlers();
|
6481
|
+
return _this37;
|
6415
6482
|
}
|
6416
6483
|
|
6417
6484
|
_createClass(Autocomplete, [{
|
@@ -6437,16 +6504,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6437
6504
|
this._handleInputBlurBound = this._handleInputBlur.bind(this);
|
6438
6505
|
this._handleInputKeyupAndFocusBound = this._handleInputKeyupAndFocus.bind(this);
|
6439
6506
|
this._handleInputKeydownBound = this._handleInputKeydown.bind(this);
|
6507
|
+
this._handleInputClickBound = this._handleInputClick.bind(this);
|
6440
6508
|
this._handleContainerMousedownAndTouchstartBound = this._handleContainerMousedownAndTouchstart.bind(this);
|
6509
|
+
this._handleContainerMouseupAndTouchendBound = this._handleContainerMouseupAndTouchend.bind(this);
|
6441
6510
|
|
6442
6511
|
this.el.addEventListener('blur', this._handleInputBlurBound);
|
6443
6512
|
this.el.addEventListener('keyup', this._handleInputKeyupAndFocusBound);
|
6444
6513
|
this.el.addEventListener('focus', this._handleInputKeyupAndFocusBound);
|
6445
6514
|
this.el.addEventListener('keydown', this._handleInputKeydownBound);
|
6515
|
+
this.el.addEventListener('click', this._handleInputClickBound);
|
6446
6516
|
this.container.addEventListener('mousedown', this._handleContainerMousedownAndTouchstartBound);
|
6517
|
+
this.container.addEventListener('mouseup', this._handleContainerMouseupAndTouchendBound);
|
6447
6518
|
|
6448
6519
|
if (typeof window.ontouchstart !== 'undefined') {
|
6449
6520
|
this.container.addEventListener('touchstart', this._handleContainerMousedownAndTouchstartBound);
|
6521
|
+
this.container.addEventListener('touchend', this._handleContainerMouseupAndTouchendBound);
|
6450
6522
|
}
|
6451
6523
|
}
|
6452
6524
|
|
@@ -6461,10 +6533,13 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6461
6533
|
this.el.removeEventListener('keyup', this._handleInputKeyupAndFocusBound);
|
6462
6534
|
this.el.removeEventListener('focus', this._handleInputKeyupAndFocusBound);
|
6463
6535
|
this.el.removeEventListener('keydown', this._handleInputKeydownBound);
|
6536
|
+
this.el.removeEventListener('click', this._handleInputClickBound);
|
6464
6537
|
this.container.removeEventListener('mousedown', this._handleContainerMousedownAndTouchstartBound);
|
6538
|
+
this.container.removeEventListener('mouseup', this._handleContainerMouseupAndTouchendBound);
|
6465
6539
|
|
6466
6540
|
if (typeof window.ontouchstart !== 'undefined') {
|
6467
6541
|
this.container.removeEventListener('touchstart', this._handleContainerMousedownAndTouchstartBound);
|
6542
|
+
this.container.removeEventListener('touchend', this._handleContainerMouseupAndTouchendBound);
|
6468
6543
|
}
|
6469
6544
|
}
|
6470
6545
|
|
@@ -6475,6 +6550,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6475
6550
|
}, {
|
6476
6551
|
key: "_setupDropdown",
|
6477
6552
|
value: function _setupDropdown() {
|
6553
|
+
var _this38 = this;
|
6554
|
+
|
6478
6555
|
this.container = document.createElement('ul');
|
6479
6556
|
this.container.id = "autocomplete-options-" + M.guid();
|
6480
6557
|
$(this.container).addClass('autocomplete-content dropdown-content');
|
@@ -6484,7 +6561,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6484
6561
|
this.dropdown = M.Dropdown.init(this.el, {
|
6485
6562
|
autoFocus: false,
|
6486
6563
|
closeOnClick: false,
|
6487
|
-
coverTrigger: false
|
6564
|
+
coverTrigger: false,
|
6565
|
+
onItemClick: function (itemEl) {
|
6566
|
+
_this38.selectOption($(itemEl));
|
6567
|
+
}
|
6488
6568
|
});
|
6489
6569
|
|
6490
6570
|
// Sketchy removal of dropdown click handler
|
@@ -6508,8 +6588,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6508
6588
|
}, {
|
6509
6589
|
key: "_handleInputBlur",
|
6510
6590
|
value: function _handleInputBlur() {
|
6511
|
-
this.
|
6512
|
-
|
6591
|
+
if (!this._mousedown) {
|
6592
|
+
this.close();
|
6593
|
+
this._resetAutocomplete();
|
6594
|
+
}
|
6513
6595
|
}
|
6514
6596
|
|
6515
6597
|
/**
|
@@ -6520,8 +6602,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6520
6602
|
}, {
|
6521
6603
|
key: "_handleInputKeyupAndFocus",
|
6522
6604
|
value: function _handleInputKeyupAndFocus(e) {
|
6523
|
-
var _this37 = this;
|
6524
|
-
|
6525
6605
|
if (e.type === 'keyup') {
|
6526
6606
|
Autocomplete._keydown = false;
|
6527
6607
|
}
|
@@ -6535,25 +6615,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6535
6615
|
}
|
6536
6616
|
|
6537
6617
|
// Check if the input isn't empty
|
6538
|
-
if
|
6539
|
-
|
6540
|
-
|
6541
|
-
if (val.length >= this.options.minLength) {
|
6542
|
-
this.isOpen = true;
|
6543
|
-
this._renderDropdown(this.options.data, val);
|
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
|
-
}
|
6618
|
+
// Check if focus triggered by tab
|
6619
|
+
if (this.oldVal !== val && (M.tabPressed || e.type !== 'focus')) {
|
6620
|
+
this.open();
|
6557
6621
|
}
|
6558
6622
|
|
6559
6623
|
// Update oldVal
|
@@ -6576,7 +6640,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6576
6640
|
numItems = $(this.container).children('li').length;
|
6577
6641
|
|
6578
6642
|
// select element on Enter
|
6579
|
-
if (keyCode ===
|
6643
|
+
if (keyCode === M.keys.ENTER && this.activeIndex >= 0) {
|
6580
6644
|
liElement = $(this.container).children('li').eq(this.activeIndex);
|
6581
6645
|
if (liElement.length) {
|
6582
6646
|
this.selectOption(liElement);
|
@@ -6586,14 +6650,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6586
6650
|
}
|
6587
6651
|
|
6588
6652
|
// Capture up and down key
|
6589
|
-
if (keyCode ===
|
6653
|
+
if (keyCode === M.keys.ARROW_UP || keyCode === M.keys.ARROW_DOWN) {
|
6590
6654
|
e.preventDefault();
|
6591
6655
|
|
6592
|
-
if (keyCode ===
|
6656
|
+
if (keyCode === M.keys.ARROW_UP && this.activeIndex > 0) {
|
6593
6657
|
this.activeIndex--;
|
6594
6658
|
}
|
6595
6659
|
|
6596
|
-
if (keyCode ===
|
6660
|
+
if (keyCode === M.keys.ARROW_DOWN && this.activeIndex < numItems - 1) {
|
6597
6661
|
this.activeIndex++;
|
6598
6662
|
}
|
6599
6663
|
|
@@ -6605,6 +6669,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6605
6669
|
}
|
6606
6670
|
}
|
6607
6671
|
|
6672
|
+
/**
|
6673
|
+
* Handle Input Click
|
6674
|
+
* @param {Event} e
|
6675
|
+
*/
|
6676
|
+
|
6677
|
+
}, {
|
6678
|
+
key: "_handleInputClick",
|
6679
|
+
value: function _handleInputClick(e) {
|
6680
|
+
this.open();
|
6681
|
+
}
|
6682
|
+
|
6608
6683
|
/**
|
6609
6684
|
* Handle Container Mousedown and Touchstart
|
6610
6685
|
* @param {Event} e
|
@@ -6613,8 +6688,18 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6613
6688
|
}, {
|
6614
6689
|
key: "_handleContainerMousedownAndTouchstart",
|
6615
6690
|
value: function _handleContainerMousedownAndTouchstart(e) {
|
6616
|
-
|
6617
|
-
|
6691
|
+
this._mousedown = true;
|
6692
|
+
}
|
6693
|
+
|
6694
|
+
/**
|
6695
|
+
* Handle Container Mouseup and Touchend
|
6696
|
+
* @param {Event} e
|
6697
|
+
*/
|
6698
|
+
|
6699
|
+
}, {
|
6700
|
+
key: "_handleContainerMouseupAndTouchend",
|
6701
|
+
value: function _handleContainerMouseupAndTouchend(e) {
|
6702
|
+
this._mousedown = false;
|
6618
6703
|
}
|
6619
6704
|
|
6620
6705
|
/**
|
@@ -6625,7 +6710,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6625
6710
|
key: "_highlight",
|
6626
6711
|
value: function _highlight(string, $el) {
|
6627
6712
|
var img = $el.find('img');
|
6628
|
-
var matchStart = $el.text().toLowerCase().indexOf(
|
6713
|
+
var matchStart = $el.text().toLowerCase().indexOf('' + string.toLowerCase() + ''),
|
6629
6714
|
matchEnd = matchStart + string.length - 1,
|
6630
6715
|
beforeMatch = $el.text().slice(0, matchStart),
|
6631
6716
|
matchText = $el.text().slice(matchStart, matchEnd + 1),
|
@@ -6658,6 +6743,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6658
6743
|
this._resetCurrentElement();
|
6659
6744
|
this.oldVal = null;
|
6660
6745
|
this.isOpen = false;
|
6746
|
+
this._mousedown = false;
|
6661
6747
|
}
|
6662
6748
|
|
6663
6749
|
/**
|
@@ -6672,7 +6758,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6672
6758
|
this.el.value = text;
|
6673
6759
|
this.$el.trigger('change');
|
6674
6760
|
this._resetAutocomplete();
|
6675
|
-
this.
|
6761
|
+
this.close();
|
6676
6762
|
|
6677
6763
|
// Handle onAutocomplete callback.
|
6678
6764
|
if (typeof this.options.onAutocomplete === 'function') {
|
@@ -6689,7 +6775,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6689
6775
|
}, {
|
6690
6776
|
key: "_renderDropdown",
|
6691
6777
|
value: function _renderDropdown(data, val) {
|
6692
|
-
var
|
6778
|
+
var _this39 = this;
|
6693
6779
|
|
6694
6780
|
this._resetAutocomplete();
|
6695
6781
|
|
@@ -6714,17 +6800,19 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6714
6800
|
}
|
6715
6801
|
|
6716
6802
|
// Sort
|
6717
|
-
|
6718
|
-
|
6719
|
-
|
6720
|
-
|
6803
|
+
if (this.options.sortFunction) {
|
6804
|
+
var sortFunctionBound = function (a, b) {
|
6805
|
+
return _this39.options.sortFunction(a.key.toLowerCase(), b.key.toLowerCase(), val.toLowerCase());
|
6806
|
+
};
|
6807
|
+
matchingData.sort(sortFunctionBound);
|
6808
|
+
}
|
6721
6809
|
|
6722
6810
|
// Render
|
6723
6811
|
for (var i = 0; i < matchingData.length; i++) {
|
6724
6812
|
var _entry = matchingData[i];
|
6725
6813
|
var $autocompleteOption = $('<li></li>');
|
6726
6814
|
if (!!_entry.data) {
|
6727
|
-
$autocompleteOption.append(
|
6815
|
+
$autocompleteOption.append("<img src=\"" + _entry.data + "\" class=\"right circle\"><span>" + _entry.key + "</span>");
|
6728
6816
|
} else {
|
6729
6817
|
$autocompleteOption.append('<span>' + _entry.key + '</span>');
|
6730
6818
|
}
|
@@ -6734,6 +6822,41 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6734
6822
|
}
|
6735
6823
|
}
|
6736
6824
|
|
6825
|
+
/**
|
6826
|
+
* Open Autocomplete Dropdown
|
6827
|
+
*/
|
6828
|
+
|
6829
|
+
}, {
|
6830
|
+
key: "open",
|
6831
|
+
value: function open() {
|
6832
|
+
var val = this.el.value.toLowerCase();
|
6833
|
+
|
6834
|
+
this._resetAutocomplete();
|
6835
|
+
|
6836
|
+
if (val.length >= this.options.minLength) {
|
6837
|
+
this.isOpen = true;
|
6838
|
+
this._renderDropdown(this.options.data, val);
|
6839
|
+
}
|
6840
|
+
|
6841
|
+
// Open dropdown
|
6842
|
+
if (!this.dropdown.isOpen) {
|
6843
|
+
this.dropdown.open();
|
6844
|
+
} else {
|
6845
|
+
// Recalculate dropdown when its already open
|
6846
|
+
this.dropdown.recalculateDimensions();
|
6847
|
+
}
|
6848
|
+
}
|
6849
|
+
|
6850
|
+
/**
|
6851
|
+
* Close Autocomplete Dropdown
|
6852
|
+
*/
|
6853
|
+
|
6854
|
+
}, {
|
6855
|
+
key: "close",
|
6856
|
+
value: function close() {
|
6857
|
+
this.dropdown.close();
|
6858
|
+
}
|
6859
|
+
|
6737
6860
|
/**
|
6738
6861
|
* Update Data
|
6739
6862
|
* @param {Object} data
|
@@ -6836,7 +6959,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6836
6959
|
}
|
6837
6960
|
|
6838
6961
|
if (!$textarea.length) {
|
6839
|
-
console.error(
|
6962
|
+
console.error('No textarea element found');
|
6840
6963
|
return;
|
6841
6964
|
}
|
6842
6965
|
|
@@ -6952,8 +7075,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6952
7075
|
formReset.find('select').each(function () {
|
6953
7076
|
// check if initialized
|
6954
7077
|
if (this.M_FormSelect) {
|
6955
|
-
|
6956
|
-
$(this).siblings('input.select-dropdown')[0].value = reset_text;
|
7078
|
+
$(this).trigger('change');
|
6957
7079
|
}
|
6958
7080
|
});
|
6959
7081
|
}, 0);
|
@@ -6977,10 +7099,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
6977
7099
|
document.addEventListener('blur', function (e) {
|
6978
7100
|
var $inputElement = $(e.target);
|
6979
7101
|
if ($inputElement.is(input_selector)) {
|
6980
|
-
var selector =
|
7102
|
+
var selector = '.prefix';
|
6981
7103
|
|
6982
7104
|
if ($inputElement[0].value.length === 0 && $inputElement[0].validity.badInput !== true && $inputElement.attr('placeholder') === null) {
|
6983
|
-
selector +=
|
7105
|
+
selector += ', label';
|
6984
7106
|
}
|
6985
7107
|
$inputElement.siblings(selector).removeClass('active');
|
6986
7108
|
M.validate_field($inputElement);
|
@@ -7029,7 +7151,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7029
7151
|
for (var i = 0; i < files.length; i++) {
|
7030
7152
|
file_names.push(files[i].name);
|
7031
7153
|
}
|
7032
|
-
path_input[0].value = file_names.join(
|
7154
|
+
path_input[0].value = file_names.join(', ');
|
7033
7155
|
path_input.trigger('change');
|
7034
7156
|
});
|
7035
7157
|
}); // End of $(document).ready
|
@@ -7061,9 +7183,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7061
7183
|
function Slider(el, options) {
|
7062
7184
|
_classCallCheck(this, Slider);
|
7063
7185
|
|
7064
|
-
var
|
7186
|
+
var _this40 = _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).call(this, Slider, el, options));
|
7065
7187
|
|
7066
|
-
|
7188
|
+
_this40.el.M_Slider = _this40;
|
7067
7189
|
|
7068
7190
|
/**
|
7069
7191
|
* Options for the modal
|
@@ -7073,27 +7195,27 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7073
7195
|
* @prop {Number} [duration=500] - Length in ms of slide transition
|
7074
7196
|
* @prop {Number} [interval=6000] - Length in ms of slide interval
|
7075
7197
|
*/
|
7076
|
-
|
7198
|
+
_this40.options = $.extend({}, Slider.defaults, options);
|
7077
7199
|
|
7078
7200
|
// setup
|
7079
|
-
|
7080
|
-
|
7081
|
-
|
7201
|
+
_this40.$slider = _this40.$el.find('.slides');
|
7202
|
+
_this40.$slides = _this40.$slider.children('li');
|
7203
|
+
_this40.activeIndex = _this40.$slides.filter(function (item) {
|
7082
7204
|
return $(item).hasClass('active');
|
7083
7205
|
}).first().index();
|
7084
|
-
if (
|
7085
|
-
|
7206
|
+
if (_this40.activeIndex != -1) {
|
7207
|
+
_this40.$active = _this40.$slides.eq(_this40.activeIndex);
|
7086
7208
|
}
|
7087
7209
|
|
7088
|
-
|
7210
|
+
_this40._setSliderHeight();
|
7089
7211
|
|
7090
7212
|
// Set initial positions of captions
|
7091
|
-
|
7092
|
-
|
7213
|
+
_this40.$slides.find('.caption').each(function (el) {
|
7214
|
+
_this40._animateCaptionIn(el, 0);
|
7093
7215
|
});
|
7094
7216
|
|
7095
7217
|
// Move img src into background-image
|
7096
|
-
|
7218
|
+
_this40.$slides.find('img').each(function (el) {
|
7097
7219
|
var placeholderBase64 = '';
|
7098
7220
|
if ($(el).attr('src') !== placeholderBase64) {
|
7099
7221
|
$(el).css('background-image', 'url("' + $(el).attr('src') + '")');
|
@@ -7101,46 +7223,46 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7101
7223
|
}
|
7102
7224
|
});
|
7103
7225
|
|
7104
|
-
|
7226
|
+
_this40._setupIndicators();
|
7105
7227
|
|
7106
7228
|
// Show active slide
|
7107
|
-
if (
|
7108
|
-
|
7229
|
+
if (_this40.$active) {
|
7230
|
+
_this40.$active.css('display', 'block');
|
7109
7231
|
} else {
|
7110
|
-
|
7232
|
+
_this40.$slides.first().addClass('active');
|
7111
7233
|
anim({
|
7112
|
-
targets:
|
7234
|
+
targets: _this40.$slides.first()[0],
|
7113
7235
|
opacity: 1,
|
7114
|
-
duration:
|
7236
|
+
duration: _this40.options.duration,
|
7115
7237
|
easing: 'easeOutQuad'
|
7116
7238
|
});
|
7117
7239
|
|
7118
|
-
|
7119
|
-
|
7240
|
+
_this40.activeIndex = 0;
|
7241
|
+
_this40.$active = _this40.$slides.eq(_this40.activeIndex);
|
7120
7242
|
|
7121
7243
|
// Update indicators
|
7122
|
-
if (
|
7123
|
-
|
7244
|
+
if (_this40.options.indicators) {
|
7245
|
+
_this40.$indicators.eq(_this40.activeIndex).addClass('active');
|
7124
7246
|
}
|
7125
7247
|
}
|
7126
7248
|
|
7127
7249
|
// Adjust height to current slide
|
7128
|
-
|
7250
|
+
_this40.$active.find('img').each(function (el) {
|
7129
7251
|
anim({
|
7130
|
-
targets:
|
7252
|
+
targets: _this40.$active.find('.caption')[0],
|
7131
7253
|
opacity: 1,
|
7132
7254
|
translateX: 0,
|
7133
7255
|
translateY: 0,
|
7134
|
-
duration:
|
7256
|
+
duration: _this40.options.duration,
|
7135
7257
|
easing: 'easeOutQuad'
|
7136
7258
|
});
|
7137
7259
|
});
|
7138
7260
|
|
7139
|
-
|
7261
|
+
_this40._setupEventHandlers();
|
7140
7262
|
|
7141
7263
|
// auto scroll
|
7142
|
-
|
7143
|
-
return
|
7264
|
+
_this40.start();
|
7265
|
+
return _this40;
|
7144
7266
|
}
|
7145
7267
|
|
7146
7268
|
_createClass(Slider, [{
|
@@ -7164,14 +7286,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7164
7286
|
}, {
|
7165
7287
|
key: "_setupEventHandlers",
|
7166
7288
|
value: function _setupEventHandlers() {
|
7167
|
-
var
|
7289
|
+
var _this41 = this;
|
7168
7290
|
|
7169
7291
|
this._handleIntervalBound = this._handleInterval.bind(this);
|
7170
7292
|
this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
|
7171
7293
|
|
7172
7294
|
if (this.options.indicators) {
|
7173
7295
|
this.$indicators.each(function (el) {
|
7174
|
-
el.addEventListener('click',
|
7296
|
+
el.addEventListener('click', _this41._handleIndicatorClickBound);
|
7175
7297
|
});
|
7176
7298
|
}
|
7177
7299
|
}
|
@@ -7183,11 +7305,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7183
7305
|
}, {
|
7184
7306
|
key: "_removeEventHandlers",
|
7185
7307
|
value: function _removeEventHandlers() {
|
7186
|
-
var
|
7308
|
+
var _this42 = this;
|
7187
7309
|
|
7188
7310
|
if (this.options.indicators) {
|
7189
7311
|
this.$indicators.each(function (el) {
|
7190
|
-
el.removeEventListener('click',
|
7312
|
+
el.removeEventListener('click', _this42._handleIndicatorClickBound);
|
7191
7313
|
});
|
7192
7314
|
}
|
7193
7315
|
}
|
@@ -7212,7 +7334,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7212
7334
|
key: "_handleInterval",
|
7213
7335
|
value: function _handleInterval() {
|
7214
7336
|
var newActiveIndex = this.$slider.find('.active').index();
|
7215
|
-
if (this.$slides.length === newActiveIndex + 1) newActiveIndex = 0;
|
7337
|
+
if (this.$slides.length === newActiveIndex + 1) newActiveIndex = 0;
|
7338
|
+
// loop to start
|
7216
7339
|
else newActiveIndex += 1;
|
7217
7340
|
|
7218
7341
|
this.set(newActiveIndex);
|
@@ -7271,13 +7394,13 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7271
7394
|
}, {
|
7272
7395
|
key: "_setupIndicators",
|
7273
7396
|
value: function _setupIndicators() {
|
7274
|
-
var
|
7397
|
+
var _this43 = this;
|
7275
7398
|
|
7276
7399
|
if (this.options.indicators) {
|
7277
7400
|
this.$indicators = $('<ul class="indicators"></ul>');
|
7278
7401
|
this.$slides.each(function (el, index) {
|
7279
7402
|
var $indicator = $('<li class="indicator-item"></li>');
|
7280
|
-
|
7403
|
+
_this43.$indicators.append($indicator[0]);
|
7281
7404
|
});
|
7282
7405
|
this.$el.append(this.$indicators[0]);
|
7283
7406
|
this.$indicators = this.$indicators.children('li.indicator-item');
|
@@ -7302,7 +7425,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7302
7425
|
}, {
|
7303
7426
|
key: "set",
|
7304
7427
|
value: function set(index) {
|
7305
|
-
var
|
7428
|
+
var _this44 = this;
|
7306
7429
|
|
7307
7430
|
// Wrap around indices.
|
7308
7431
|
if (index >= this.$slides.length) index = 0;else if (index < 0) index = this.$slides.length - 1;
|
@@ -7319,7 +7442,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7319
7442
|
duration: this.options.duration,
|
7320
7443
|
easing: 'easeOutQuad',
|
7321
7444
|
complete: function () {
|
7322
|
-
|
7445
|
+
_this44.$slides.not('.active').each(function (el) {
|
7323
7446
|
anim({
|
7324
7447
|
targets: el,
|
7325
7448
|
opacity: 0,
|
@@ -7518,9 +7641,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7518
7641
|
function Chips(el, options) {
|
7519
7642
|
_classCallCheck(this, Chips);
|
7520
7643
|
|
7521
|
-
var
|
7644
|
+
var _this45 = _possibleConstructorReturn(this, (Chips.__proto__ || Object.getPrototypeOf(Chips)).call(this, Chips, el, options));
|
7522
7645
|
|
7523
|
-
|
7646
|
+
_this45.el.M_Chips = _this45;
|
7524
7647
|
|
7525
7648
|
/**
|
7526
7649
|
* Options for the modal
|
@@ -7530,34 +7653,34 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7530
7653
|
* @prop {String} secondaryPlaceholder
|
7531
7654
|
* @prop {Object} autocompleteOptions
|
7532
7655
|
*/
|
7533
|
-
|
7656
|
+
_this45.options = $.extend({}, Chips.defaults, options);
|
7534
7657
|
|
7535
|
-
|
7536
|
-
|
7537
|
-
|
7538
|
-
|
7539
|
-
|
7658
|
+
_this45.$el.addClass('chips input-field');
|
7659
|
+
_this45.chipsData = [];
|
7660
|
+
_this45.$chips = $();
|
7661
|
+
_this45._setupInput();
|
7662
|
+
_this45.hasAutocomplete = Object.keys(_this45.options.autocompleteOptions).length > 0;
|
7540
7663
|
|
7541
7664
|
// Set input id
|
7542
|
-
if (!
|
7543
|
-
|
7665
|
+
if (!_this45.$input.attr('id')) {
|
7666
|
+
_this45.$input.attr('id', M.guid());
|
7544
7667
|
}
|
7545
7668
|
|
7546
7669
|
// Render initial chips
|
7547
|
-
if (
|
7548
|
-
|
7549
|
-
|
7670
|
+
if (_this45.options.data.length) {
|
7671
|
+
_this45.chipsData = _this45.options.data;
|
7672
|
+
_this45._renderChips(_this45.chipsData);
|
7550
7673
|
}
|
7551
7674
|
|
7552
7675
|
// Setup autocomplete if needed
|
7553
|
-
if (
|
7554
|
-
|
7676
|
+
if (_this45.hasAutocomplete) {
|
7677
|
+
_this45._setupAutocomplete();
|
7555
7678
|
}
|
7556
7679
|
|
7557
|
-
|
7558
|
-
|
7559
|
-
|
7560
|
-
return
|
7680
|
+
_this45._setPlaceholder();
|
7681
|
+
_this45._setupLabel();
|
7682
|
+
_this45._setupEventHandlers();
|
7683
|
+
return _this45;
|
7561
7684
|
}
|
7562
7685
|
|
7563
7686
|
_createClass(Chips, [{
|
@@ -7760,14 +7883,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
7760
7883
|
}, {
|
7761
7884
|
key: "_setupAutocomplete",
|
7762
7885
|
value: function _setupAutocomplete() {
|
7763
|
-
var
|
7886
|
+
var _this46 = this;
|
7764
7887
|
|
7765
7888
|
this.options.autocompleteOptions.onAutocomplete = function (val) {
|
7766
|
-
|
7889
|
+
_this46.addChip({
|
7767
7890
|
tag: val
|
7768
7891
|
});
|
7769
|
-
|
7770
|
-
|
7892
|
+
_this46.$input[0].value = '';
|
7893
|
+
_this46.$input[0].focus();
|
7771
7894
|
};
|
7772
7895
|
|
7773
7896
|
this.autocomplete = M.Autocomplete.init(this.$input[0], this.options.autocompleteOptions);
|
@@ -8062,21 +8185,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8062
8185
|
function Pushpin(el, options) {
|
8063
8186
|
_classCallCheck(this, Pushpin);
|
8064
8187
|
|
8065
|
-
var
|
8188
|
+
var _this47 = _possibleConstructorReturn(this, (Pushpin.__proto__ || Object.getPrototypeOf(Pushpin)).call(this, Pushpin, el, options));
|
8066
8189
|
|
8067
|
-
|
8190
|
+
_this47.el.M_Pushpin = _this47;
|
8068
8191
|
|
8069
8192
|
/**
|
8070
8193
|
* Options for the modal
|
8071
8194
|
* @member Pushpin#options
|
8072
8195
|
*/
|
8073
|
-
|
8196
|
+
_this47.options = $.extend({}, Pushpin.defaults, options);
|
8074
8197
|
|
8075
|
-
|
8076
|
-
Pushpin._pushpins.push(
|
8077
|
-
|
8078
|
-
|
8079
|
-
return
|
8198
|
+
_this47.originalOffset = _this47.el.offsetTop;
|
8199
|
+
Pushpin._pushpins.push(_this47);
|
8200
|
+
_this47._setupEventHandlers();
|
8201
|
+
_this47._updatePosition();
|
8202
|
+
return _this47;
|
8080
8203
|
}
|
8081
8204
|
|
8082
8205
|
_createClass(Pushpin, [{
|
@@ -8112,7 +8235,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8112
8235
|
|
8113
8236
|
if (this.options.top <= scrolled && this.options.bottom >= scrolled && !this.el.classList.contains('pinned')) {
|
8114
8237
|
this._removePinClasses();
|
8115
|
-
|
8116
8238
|
this.el.style.top = this.options.offset + "px";
|
8117
8239
|
this.el.classList.add('pinned');
|
8118
8240
|
|
@@ -8149,7 +8271,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8149
8271
|
}, {
|
8150
8272
|
key: "_removePinClasses",
|
8151
8273
|
value: function _removePinClasses() {
|
8152
|
-
|
8274
|
+
// IE 11 bug (can't remove multiple classes in one line)
|
8275
|
+
this.el.classList.remove('pin-top');
|
8276
|
+
this.el.classList.remove('pinned');
|
8277
|
+
this.el.classList.remove('pin-bottom');
|
8153
8278
|
}
|
8154
8279
|
}], [{
|
8155
8280
|
key: "init",
|
@@ -8227,9 +8352,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8227
8352
|
function FloatingActionButton(el, options) {
|
8228
8353
|
_classCallCheck(this, FloatingActionButton);
|
8229
8354
|
|
8230
|
-
var
|
8355
|
+
var _this48 = _possibleConstructorReturn(this, (FloatingActionButton.__proto__ || Object.getPrototypeOf(FloatingActionButton)).call(this, FloatingActionButton, el, options));
|
8231
8356
|
|
8232
|
-
|
8357
|
+
_this48.el.M_FloatingActionButton = _this48;
|
8233
8358
|
|
8234
8359
|
/**
|
8235
8360
|
* Options for the fab
|
@@ -8238,30 +8363,28 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8238
8363
|
* @prop {Boolean} [hoverEnabled=true] - Enable hover vs click
|
8239
8364
|
* @prop {Boolean} [toolbarEnabled=false] - Enable toolbar transition
|
8240
8365
|
*/
|
8241
|
-
|
8242
|
-
|
8243
|
-
|
8244
|
-
|
8245
|
-
|
8246
|
-
|
8247
|
-
|
8248
|
-
|
8249
|
-
|
8250
|
-
|
8251
|
-
|
8252
|
-
|
8253
|
-
|
8254
|
-
|
8255
|
-
|
8256
|
-
} else if (
|
8257
|
-
|
8258
|
-
_this47.offsetY = -40;
|
8366
|
+
_this48.options = $.extend({}, FloatingActionButton.defaults, options);
|
8367
|
+
|
8368
|
+
_this48.isOpen = false;
|
8369
|
+
_this48.$anchor = _this48.$el.children('a').first();
|
8370
|
+
_this48.$menu = _this48.$el.children('ul').first();
|
8371
|
+
_this48.$floatingBtns = _this48.$el.find('ul .btn-floating');
|
8372
|
+
_this48.$floatingBtnsReverse = _this48.$el.find('ul .btn-floating').reverse();
|
8373
|
+
_this48.offsetY = 0;
|
8374
|
+
_this48.offsetX = 0;
|
8375
|
+
|
8376
|
+
_this48.$el.addClass("direction-" + _this48.options.direction);
|
8377
|
+
if (_this48.options.direction === 'top') {
|
8378
|
+
_this48.offsetY = 40;
|
8379
|
+
} else if (_this48.options.direction === 'right') {
|
8380
|
+
_this48.offsetX = -40;
|
8381
|
+
} else if (_this48.options.direction === 'bottom') {
|
8382
|
+
_this48.offsetY = -40;
|
8259
8383
|
} else {
|
8260
|
-
|
8261
|
-
_this47.offsetX = 40;
|
8384
|
+
_this48.offsetX = 40;
|
8262
8385
|
}
|
8263
|
-
|
8264
|
-
return
|
8386
|
+
_this48._setupEventHandlers();
|
8387
|
+
return _this48;
|
8265
8388
|
}
|
8266
8389
|
|
8267
8390
|
_createClass(FloatingActionButton, [{
|
@@ -8384,7 +8507,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8384
8507
|
}, {
|
8385
8508
|
key: "_animateInFAB",
|
8386
8509
|
value: function _animateInFAB() {
|
8387
|
-
var
|
8510
|
+
var _this49 = this;
|
8388
8511
|
|
8389
8512
|
this.$el.addClass('active');
|
8390
8513
|
|
@@ -8393,9 +8516,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8393
8516
|
anim({
|
8394
8517
|
targets: el,
|
8395
8518
|
opacity: 1,
|
8396
|
-
scale: [.4, 1],
|
8397
|
-
translateY: [
|
8398
|
-
translateX: [
|
8519
|
+
scale: [0.4, 1],
|
8520
|
+
translateY: [_this49.offsetY, 0],
|
8521
|
+
translateX: [_this49.offsetX, 0],
|
8399
8522
|
duration: 275,
|
8400
8523
|
delay: time,
|
8401
8524
|
easing: 'easeInOutQuad'
|
@@ -8411,20 +8534,20 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8411
8534
|
}, {
|
8412
8535
|
key: "_animateOutFAB",
|
8413
8536
|
value: function _animateOutFAB() {
|
8414
|
-
var
|
8537
|
+
var _this50 = this;
|
8415
8538
|
|
8416
8539
|
this.$floatingBtnsReverse.each(function (el) {
|
8417
8540
|
anim.remove(el);
|
8418
8541
|
anim({
|
8419
8542
|
targets: el,
|
8420
8543
|
opacity: 0,
|
8421
|
-
scale: .4,
|
8422
|
-
translateY:
|
8423
|
-
translateX:
|
8544
|
+
scale: 0.4,
|
8545
|
+
translateY: _this50.offsetY,
|
8546
|
+
translateX: _this50.offsetX,
|
8424
8547
|
duration: 175,
|
8425
8548
|
easing: 'easeOutQuad',
|
8426
8549
|
complete: function () {
|
8427
|
-
|
8550
|
+
_this50.$el.removeClass('active');
|
8428
8551
|
}
|
8429
8552
|
});
|
8430
8553
|
});
|
@@ -8437,7 +8560,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8437
8560
|
}, {
|
8438
8561
|
key: "_animateInToolbar",
|
8439
8562
|
value: function _animateInToolbar() {
|
8440
|
-
var
|
8563
|
+
var _this51 = this;
|
8441
8564
|
|
8442
8565
|
var scaleFactor = void 0;
|
8443
8566
|
var windowWidth = window.innerWidth;
|
@@ -8473,18 +8596,18 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8473
8596
|
});
|
8474
8597
|
|
8475
8598
|
setTimeout(function () {
|
8476
|
-
|
8599
|
+
_this51.$el.css({
|
8477
8600
|
transform: '',
|
8478
8601
|
transition: 'transform .2s cubic-bezier(0.550, 0.085, 0.680, 0.530), background-color 0s linear .2s'
|
8479
8602
|
});
|
8480
|
-
|
8603
|
+
_this51.$anchor.css({
|
8481
8604
|
overflow: 'visible',
|
8482
8605
|
transform: '',
|
8483
8606
|
transition: 'transform .2s'
|
8484
8607
|
});
|
8485
8608
|
|
8486
8609
|
setTimeout(function () {
|
8487
|
-
|
8610
|
+
_this51.$el.css({
|
8488
8611
|
overflow: 'hidden',
|
8489
8612
|
'background-color': fabColor
|
8490
8613
|
});
|
@@ -8492,14 +8615,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8492
8615
|
transform: 'scale(' + scaleFactor + ')',
|
8493
8616
|
transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
|
8494
8617
|
});
|
8495
|
-
|
8618
|
+
_this51.$menu.children('li').children('a').css({
|
8496
8619
|
opacity: 1
|
8497
8620
|
});
|
8498
8621
|
|
8499
8622
|
// Scroll to close.
|
8500
|
-
|
8501
|
-
window.addEventListener('scroll',
|
8502
|
-
document.body.addEventListener('click',
|
8623
|
+
_this51._handleDocumentClickBound = _this51._handleDocumentClick.bind(_this51);
|
8624
|
+
window.addEventListener('scroll', _this51._handleCloseBound, true);
|
8625
|
+
document.body.addEventListener('click', _this51._handleDocumentClickBound, true);
|
8503
8626
|
}, 100);
|
8504
8627
|
}, 0);
|
8505
8628
|
}
|
@@ -8511,7 +8634,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8511
8634
|
}, {
|
8512
8635
|
key: "_animateOutToolbar",
|
8513
8636
|
value: function _animateOutToolbar() {
|
8514
|
-
var
|
8637
|
+
var _this52 = this;
|
8515
8638
|
|
8516
8639
|
var windowWidth = window.innerWidth;
|
8517
8640
|
var windowHeight = window.innerHeight;
|
@@ -8542,26 +8665,26 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8542
8665
|
backdrop.remove();
|
8543
8666
|
|
8544
8667
|
// Set initial state.
|
8545
|
-
|
8668
|
+
_this52.$el.css({
|
8546
8669
|
'text-align': '',
|
8547
8670
|
width: '',
|
8548
8671
|
bottom: '',
|
8549
8672
|
left: '',
|
8550
8673
|
overflow: '',
|
8551
8674
|
'background-color': '',
|
8552
|
-
transform: 'translate3d(' + -
|
8675
|
+
transform: 'translate3d(' + -_this52.offsetX + 'px,0,0)'
|
8553
8676
|
});
|
8554
|
-
|
8677
|
+
_this52.$anchor.css({
|
8555
8678
|
overflow: '',
|
8556
|
-
transform: 'translate3d(0,' +
|
8679
|
+
transform: 'translate3d(0,' + _this52.offsetY + 'px,0)'
|
8557
8680
|
});
|
8558
8681
|
|
8559
8682
|
setTimeout(function () {
|
8560
|
-
|
8683
|
+
_this52.$el.css({
|
8561
8684
|
transform: 'translate3d(0,0,0)',
|
8562
8685
|
transition: 'transform .2s'
|
8563
8686
|
});
|
8564
|
-
|
8687
|
+
_this52.$anchor.css({
|
8565
8688
|
transform: 'translate3d(0,0,0)',
|
8566
8689
|
transition: 'transform .2s cubic-bezier(0.550, 0.055, 0.675, 0.190)'
|
8567
8690
|
});
|
@@ -8604,6 +8727,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8604
8727
|
'use strict';
|
8605
8728
|
|
8606
8729
|
var _defaults = {
|
8730
|
+
// Close when date is selected
|
8731
|
+
autoClose: false,
|
8607
8732
|
|
8608
8733
|
// the default output format for the input field value
|
8609
8734
|
format: 'mmm dd, yyyy',
|
@@ -8696,53 +8821,51 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8696
8821
|
function Datepicker(el, options) {
|
8697
8822
|
_classCallCheck(this, Datepicker);
|
8698
8823
|
|
8699
|
-
var
|
8824
|
+
var _this53 = _possibleConstructorReturn(this, (Datepicker.__proto__ || Object.getPrototypeOf(Datepicker)).call(this, Datepicker, el, options));
|
8700
8825
|
|
8701
|
-
|
8826
|
+
_this53.el.M_Datepicker = _this53;
|
8702
8827
|
|
8703
|
-
|
8828
|
+
_this53.options = $.extend({}, Datepicker.defaults, options);
|
8704
8829
|
|
8705
8830
|
// make sure i18n defaults are not lost when only few i18n option properties are passed
|
8706
8831
|
if (!!options && options.hasOwnProperty('i18n') && typeof options.i18n === 'object') {
|
8707
|
-
|
8832
|
+
_this53.options.i18n = $.extend({}, Datepicker.defaults.i18n, options.i18n);
|
8708
8833
|
}
|
8709
8834
|
|
8710
8835
|
// Remove time component from minDate and maxDate options
|
8711
|
-
if (
|
8712
|
-
if (
|
8836
|
+
if (_this53.options.minDate) _this53.options.minDate.setHours(0, 0, 0, 0);
|
8837
|
+
if (_this53.options.maxDate) _this53.options.maxDate.setHours(0, 0, 0, 0);
|
8713
8838
|
|
8714
|
-
|
8839
|
+
_this53.id = M.guid();
|
8715
8840
|
|
8716
|
-
|
8717
|
-
|
8718
|
-
|
8841
|
+
_this53._setupVariables();
|
8842
|
+
_this53._insertHTMLIntoDOM();
|
8843
|
+
_this53._setupModal();
|
8719
8844
|
|
8720
|
-
|
8845
|
+
_this53._setupEventHandlers();
|
8721
8846
|
|
8722
|
-
if (!
|
8723
|
-
|
8724
|
-
_this52.options.setDefaultDate = true;
|
8847
|
+
if (!_this53.options.defaultDate) {
|
8848
|
+
_this53.options.defaultDate = new Date(Date.parse(_this53.el.value));
|
8725
8849
|
}
|
8726
8850
|
|
8727
|
-
var defDate =
|
8728
|
-
|
8851
|
+
var defDate = _this53.options.defaultDate;
|
8729
8852
|
if (Datepicker._isDate(defDate)) {
|
8730
|
-
if (
|
8731
|
-
|
8853
|
+
if (_this53.options.setDefaultDate) {
|
8854
|
+
_this53.setDate(defDate, true);
|
8855
|
+
_this53.setInputValue();
|
8732
8856
|
} else {
|
8733
|
-
|
8857
|
+
_this53.gotoDate(defDate);
|
8734
8858
|
}
|
8735
8859
|
} else {
|
8736
|
-
|
8860
|
+
_this53.gotoDate(new Date());
|
8737
8861
|
}
|
8738
8862
|
|
8739
8863
|
/**
|
8740
8864
|
* Describes open/close state of datepicker
|
8741
8865
|
* @type {Boolean}
|
8742
8866
|
*/
|
8743
|
-
|
8744
|
-
|
8745
|
-
return _this52;
|
8867
|
+
_this53.isOpen = false;
|
8868
|
+
return _this53;
|
8746
8869
|
}
|
8747
8870
|
|
8748
8871
|
_createClass(Datepicker, [{
|
@@ -8762,11 +8885,11 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8762
8885
|
}, {
|
8763
8886
|
key: "destroySelects",
|
8764
8887
|
value: function destroySelects() {
|
8765
|
-
var oldYearSelect = this.calendarEl.querySelector('.
|
8888
|
+
var oldYearSelect = this.calendarEl.querySelector('.orig-select-year');
|
8766
8889
|
if (oldYearSelect) {
|
8767
8890
|
M.FormSelect.getInstance(oldYearSelect).destroy();
|
8768
8891
|
}
|
8769
|
-
var oldMonthSelect = this.calendarEl.querySelector('.
|
8892
|
+
var oldMonthSelect = this.calendarEl.querySelector('.orig-select-month');
|
8770
8893
|
if (oldMonthSelect) {
|
8771
8894
|
M.FormSelect.getInstance(oldMonthSelect).destroy();
|
8772
8895
|
}
|
@@ -8791,19 +8914,19 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8791
8914
|
}, {
|
8792
8915
|
key: "_setupModal",
|
8793
8916
|
value: function _setupModal() {
|
8794
|
-
var
|
8917
|
+
var _this54 = this;
|
8795
8918
|
|
8796
8919
|
this.modalEl.id = 'modal-' + this.id;
|
8797
8920
|
this.modal = M.Modal.init(this.modalEl, {
|
8798
8921
|
onCloseEnd: function () {
|
8799
|
-
|
8922
|
+
_this54.isOpen = false;
|
8800
8923
|
}
|
8801
8924
|
});
|
8802
8925
|
}
|
8803
8926
|
}, {
|
8804
8927
|
key: "toString",
|
8805
8928
|
value: function toString(format) {
|
8806
|
-
var
|
8929
|
+
var _this55 = this;
|
8807
8930
|
|
8808
8931
|
format = format || this.options.format;
|
8809
8932
|
if (!Datepicker._isDate(this.date)) {
|
@@ -8812,8 +8935,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8812
8935
|
|
8813
8936
|
var formatArray = format.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g);
|
8814
8937
|
var formattedDate = formatArray.map(function (label) {
|
8815
|
-
if (
|
8816
|
-
return
|
8938
|
+
if (_this55.formats[label]) {
|
8939
|
+
return _this55.formats[label]();
|
8817
8940
|
}
|
8818
8941
|
|
8819
8942
|
return label;
|
@@ -8901,9 +9024,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8901
9024
|
month: date.getMonth(),
|
8902
9025
|
year: date.getFullYear()
|
8903
9026
|
}];
|
8904
|
-
// if (this.options.mainCalendar === 'right') {
|
8905
|
-
// this.calendars[0].month += 1 - this.options.numberOfMonths;
|
8906
|
-
// }
|
8907
9027
|
}
|
8908
9028
|
|
8909
9029
|
this.adjustCalendars();
|
@@ -8912,12 +9032,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
8912
9032
|
key: "adjustCalendars",
|
8913
9033
|
value: function adjustCalendars() {
|
8914
9034
|
this.calendars[0] = this.adjustCalendar(this.calendars[0]);
|
8915
|
-
// for (let c = 1; c < this.options.numberOfMonths; c++) {
|
8916
|
-
// this.calendars[c] = this.adjustCalendar({
|
8917
|
-
// month: this.calendars[0].month + c,
|
8918
|
-
// year: this.calendars[0].year
|
8919
|
-
// });
|
8920
|
-
// }
|
8921
9035
|
this.draw();
|
8922
9036
|
}
|
8923
9037
|
}, {
|
@@ -9061,12 +9175,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9061
9175
|
if (opts.isEndRange) {
|
9062
9176
|
arr.push('is-endrange');
|
9063
9177
|
}
|
9064
|
-
return
|
9178
|
+
return "<td data-day=\"" + opts.day + "\" class=\"" + arr.join(' ') + "\" aria-selected=\"" + ariaSelected + "\">" + ("<button class=\"datepicker-day-button\" type=\"button\" data-year=\"" + opts.year + "\" data-month=\"" + opts.month + "\" data-day=\"" + opts.day + "\">" + opts.day + "</button>") + '</td>';
|
9065
9179
|
}
|
9066
9180
|
}, {
|
9067
9181
|
key: "renderRow",
|
9068
9182
|
value: function renderRow(days, isRTL, isRowSelected) {
|
9069
|
-
return '<tr class="
|
9183
|
+
return '<tr class="datepicker-row' + (isRowSelected ? ' is-selected' : '') + '">' + (isRTL ? days.reverse() : days).join('') + '</tr>';
|
9070
9184
|
}
|
9071
9185
|
}, {
|
9072
9186
|
key: "renderTable",
|
@@ -9079,7 +9193,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9079
9193
|
var i = void 0,
|
9080
9194
|
arr = [];
|
9081
9195
|
for (i = 0; i < 7; i++) {
|
9082
|
-
arr.push(
|
9196
|
+
arr.push("<th scope=\"col\"><abbr title=\"" + this.renderDayName(opts, i) + "\">" + this.renderDayName(opts, i, true) + "</abbr></th>");
|
9083
9197
|
}
|
9084
9198
|
return '<thead><tr>' + (opts.isRTL ? arr.reverse() : arr).join('') + '</tr></thead>';
|
9085
9199
|
}
|
@@ -9107,7 +9221,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9107
9221
|
arr.push('<option value="' + (year === refYear ? i - c : 12 + i - c) + '"' + (i === month ? ' selected="selected"' : '') + (isMinYear && i < opts.minMonth || isMaxYear && i > opts.maxMonth ? 'disabled="disabled"' : '') + '>' + opts.i18n.months[i] + '</option>');
|
9108
9222
|
}
|
9109
9223
|
|
9110
|
-
monthHtml = '<select class="
|
9224
|
+
monthHtml = '<select class="datepicker-select orig-select-month" tabindex="-1">' + arr.join('') + '</select>';
|
9111
9225
|
|
9112
9226
|
if ($.isArray(opts.yearRange)) {
|
9113
9227
|
i = opts.yearRange[0];
|
@@ -9119,14 +9233,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9119
9233
|
|
9120
9234
|
for (arr = []; i < j && i <= opts.maxYear; i++) {
|
9121
9235
|
if (i >= opts.minYear) {
|
9122
|
-
arr.push(
|
9236
|
+
arr.push("<option value=\"" + i + "\" " + (i === year ? 'selected="selected"' : '') + ">" + i + "</option>");
|
9123
9237
|
}
|
9124
9238
|
}
|
9125
9239
|
|
9126
|
-
yearHtml =
|
9240
|
+
yearHtml = "<select class=\"datepicker-select orig-select-year\" tabindex=\"-1\">" + arr.join('') + "</select>";
|
9127
9241
|
|
9128
9242
|
var leftArrow = '<svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"/><path d="M0-.5h24v24H0z" fill="none"/></svg>';
|
9129
|
-
html +=
|
9243
|
+
html += "<button class=\"month-prev" + (prev ? '' : ' is-disabled') + "\" type=\"button\">" + leftArrow + "</button>";
|
9130
9244
|
|
9131
9245
|
html += '<div class="selects-container">';
|
9132
9246
|
if (opts.showMonthAfterYear) {
|
@@ -9144,10 +9258,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9144
9258
|
next = false;
|
9145
9259
|
}
|
9146
9260
|
|
9147
|
-
// if (c === (this.options.numberOfMonths - 1) ) {
|
9148
9261
|
var rightArrow = '<svg fill="#000000" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"/><path d="M0-.25h24v24H0z" fill="none"/></svg>';
|
9149
|
-
html +=
|
9150
|
-
// }
|
9262
|
+
html += "<button class=\"month-next" + (next ? '' : ' is-disabled') + "\" type=\"button\">" + rightArrow + "</button>";
|
9151
9263
|
|
9152
9264
|
return html += '</div>';
|
9153
9265
|
}
|
@@ -9183,7 +9295,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9183
9295
|
}
|
9184
9296
|
}
|
9185
9297
|
|
9186
|
-
randId = '
|
9298
|
+
randId = 'datepicker-title-' + Math.random().toString(36).replace(/[^a-z]+/g, '').substr(0, 2);
|
9187
9299
|
|
9188
9300
|
for (var c = 0; c < 1; c++) {
|
9189
9301
|
this._renderDateDisplay();
|
@@ -9195,10 +9307,16 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9195
9307
|
this.calendarEl.innerHTML = html;
|
9196
9308
|
|
9197
9309
|
// Init Materialize Select
|
9198
|
-
var yearSelect = this.calendarEl.querySelector('.
|
9199
|
-
var monthSelect = this.calendarEl.querySelector('.
|
9200
|
-
M.FormSelect.init(yearSelect, {
|
9201
|
-
|
9310
|
+
var yearSelect = this.calendarEl.querySelector('.orig-select-year');
|
9311
|
+
var monthSelect = this.calendarEl.querySelector('.orig-select-month');
|
9312
|
+
M.FormSelect.init(yearSelect, {
|
9313
|
+
classes: 'select-year',
|
9314
|
+
dropdownOptions: { container: document.body, constrainWidth: false }
|
9315
|
+
});
|
9316
|
+
M.FormSelect.init(monthSelect, {
|
9317
|
+
classes: 'select-month',
|
9318
|
+
dropdownOptions: { container: document.body, constrainWidth: false }
|
9319
|
+
});
|
9202
9320
|
|
9203
9321
|
// Add change handlers for select
|
9204
9322
|
yearSelect.addEventListener('change', this._handleYearChange.bind(this));
|
@@ -9239,12 +9357,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9239
9357
|
}, {
|
9240
9358
|
key: "_setupVariables",
|
9241
9359
|
value: function _setupVariables() {
|
9242
|
-
var
|
9360
|
+
var _this56 = this;
|
9243
9361
|
|
9244
9362
|
this.$modalEl = $(Datepicker._template);
|
9245
9363
|
this.modalEl = this.$modalEl[0];
|
9246
9364
|
|
9247
|
-
this.calendarEl = this.modalEl.querySelector('.
|
9365
|
+
this.calendarEl = this.modalEl.querySelector('.datepicker-calendar');
|
9248
9366
|
|
9249
9367
|
this.yearTextEl = this.modalEl.querySelector('.year-text');
|
9250
9368
|
this.dateTextEl = this.modalEl.querySelector('.date-text');
|
@@ -9255,38 +9373,37 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9255
9373
|
this.cancelBtn = this.modalEl.querySelector('.datepicker-cancel');
|
9256
9374
|
|
9257
9375
|
this.formats = {
|
9258
|
-
|
9259
9376
|
d: function () {
|
9260
|
-
return
|
9377
|
+
return _this56.date.getDate();
|
9261
9378
|
},
|
9262
9379
|
dd: function () {
|
9263
|
-
var d =
|
9380
|
+
var d = _this56.date.getDate();
|
9264
9381
|
return (d < 10 ? '0' : '') + d;
|
9265
9382
|
},
|
9266
9383
|
ddd: function () {
|
9267
|
-
return
|
9384
|
+
return _this56.options.i18n.weekdaysShort[_this56.date.getDay()];
|
9268
9385
|
},
|
9269
9386
|
dddd: function () {
|
9270
|
-
return
|
9387
|
+
return _this56.options.i18n.weekdays[_this56.date.getDay()];
|
9271
9388
|
},
|
9272
9389
|
m: function () {
|
9273
|
-
return
|
9390
|
+
return _this56.date.getMonth() + 1;
|
9274
9391
|
},
|
9275
9392
|
mm: function () {
|
9276
|
-
var m =
|
9393
|
+
var m = _this56.date.getMonth() + 1;
|
9277
9394
|
return (m < 10 ? '0' : '') + m;
|
9278
9395
|
},
|
9279
9396
|
mmm: function () {
|
9280
|
-
return
|
9397
|
+
return _this56.options.i18n.monthsShort[_this56.date.getMonth()];
|
9281
9398
|
},
|
9282
9399
|
mmmm: function () {
|
9283
|
-
return
|
9400
|
+
return _this56.options.i18n.months[_this56.date.getMonth()];
|
9284
9401
|
},
|
9285
9402
|
yy: function () {
|
9286
|
-
return ('' +
|
9403
|
+
return ('' + _this56.date.getFullYear()).slice(2);
|
9287
9404
|
},
|
9288
9405
|
yyyy: function () {
|
9289
|
-
return
|
9406
|
+
return _this56.date.getFullYear();
|
9290
9407
|
}
|
9291
9408
|
};
|
9292
9409
|
}
|
@@ -9326,24 +9443,16 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9326
9443
|
var $target = $(e.target);
|
9327
9444
|
if (!$target.hasClass('is-disabled')) {
|
9328
9445
|
if ($target.hasClass('datepicker-day-button') && !$target.hasClass('is-empty') && !$target.parent().hasClass('is-disabled')) {
|
9329
|
-
this.setDate(new Date(e.target.getAttribute('data-
|
9446
|
+
this.setDate(new Date(e.target.getAttribute('data-year'), e.target.getAttribute('data-month'), e.target.getAttribute('data-day')));
|
9447
|
+
if (this.options.autoClose) {
|
9448
|
+
this._finishSelection();
|
9449
|
+
}
|
9330
9450
|
} else if ($target.closest('.month-prev').length) {
|
9331
9451
|
this.prevMonth();
|
9332
9452
|
} else if ($target.closest('.month-next').length) {
|
9333
9453
|
this.nextMonth();
|
9334
9454
|
}
|
9335
9455
|
}
|
9336
|
-
// if (!$target.hasClass('pika-select')) {
|
9337
|
-
// // if this is touch event prevent mouse events emulation
|
9338
|
-
// // if (e.preventDefault) {
|
9339
|
-
// // e.preventDefault();
|
9340
|
-
// // } else {
|
9341
|
-
// // e.returnValue = false;
|
9342
|
-
// // return false;
|
9343
|
-
// // }
|
9344
|
-
// } else {
|
9345
|
-
// this._c = true;
|
9346
|
-
// }
|
9347
9456
|
}
|
9348
9457
|
}, {
|
9349
9458
|
key: "_handleClearClick",
|
@@ -9406,9 +9515,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9406
9515
|
if (Datepicker._isDate(date)) {
|
9407
9516
|
this.setDate(date);
|
9408
9517
|
}
|
9409
|
-
// if (!self._v) {
|
9410
|
-
// self.show();
|
9411
|
-
// }
|
9412
9518
|
}
|
9413
9519
|
}, {
|
9414
9520
|
key: "renderDayName",
|
@@ -9534,7 +9640,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9534
9640
|
return Datepicker;
|
9535
9641
|
}(Component);
|
9536
9642
|
|
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="
|
9643
|
+
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="datepicker-calendar"></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('');
|
9538
9644
|
|
9539
9645
|
M.Datepicker = Datepicker;
|
9540
9646
|
|
@@ -9565,7 +9671,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9565
9671
|
|
9566
9672
|
autoClose: false, // auto close when minute is selected
|
9567
9673
|
twelveHour: true, // change to 12 hour AM/PM clock from 24 hour
|
9568
|
-
vibrate: true // vibrate the device when dragging clock hand
|
9674
|
+
vibrate: true, // vibrate the device when dragging clock hand
|
9675
|
+
|
9676
|
+
// Callbacks
|
9677
|
+
onOpenStart: null,
|
9678
|
+
onOpenEnd: null,
|
9679
|
+
onCloseStart: null,
|
9680
|
+
onCloseEnd: null,
|
9681
|
+
onSelect: null
|
9569
9682
|
};
|
9570
9683
|
|
9571
9684
|
/**
|
@@ -9579,21 +9692,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9579
9692
|
function Timepicker(el, options) {
|
9580
9693
|
_classCallCheck(this, Timepicker);
|
9581
9694
|
|
9582
|
-
var
|
9695
|
+
var _this57 = _possibleConstructorReturn(this, (Timepicker.__proto__ || Object.getPrototypeOf(Timepicker)).call(this, Timepicker, el, options));
|
9583
9696
|
|
9584
|
-
|
9697
|
+
_this57.el.M_Timepicker = _this57;
|
9585
9698
|
|
9586
|
-
|
9699
|
+
_this57.options = $.extend({}, Timepicker.defaults, options);
|
9587
9700
|
|
9588
|
-
|
9589
|
-
|
9590
|
-
|
9591
|
-
|
9592
|
-
|
9701
|
+
_this57.id = M.guid();
|
9702
|
+
_this57._insertHTMLIntoDOM();
|
9703
|
+
_this57._setupModal();
|
9704
|
+
_this57._setupVariables();
|
9705
|
+
_this57._setupEventHandlers();
|
9593
9706
|
|
9594
|
-
|
9595
|
-
|
9596
|
-
return
|
9707
|
+
_this57._clockSetup();
|
9708
|
+
_this57._pickerSetup();
|
9709
|
+
return _this57;
|
9597
9710
|
}
|
9598
9711
|
|
9599
9712
|
_createClass(Timepicker, [{
|
@@ -9688,7 +9801,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9688
9801
|
}, {
|
9689
9802
|
key: "_handleDocumentClickEnd",
|
9690
9803
|
value: function _handleDocumentClickEnd(e) {
|
9691
|
-
var
|
9804
|
+
var _this58 = this;
|
9692
9805
|
|
9693
9806
|
e.preventDefault();
|
9694
9807
|
document.removeEventListener('mouseup', this._handleDocumentClickEndBound);
|
@@ -9705,10 +9818,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9705
9818
|
} else if (this.options.autoClose) {
|
9706
9819
|
$(this.minutesView).addClass('timepicker-dial-out');
|
9707
9820
|
setTimeout(function () {
|
9708
|
-
|
9821
|
+
_this58.done();
|
9709
9822
|
}, this.options.duration / 2);
|
9710
9823
|
}
|
9711
9824
|
|
9825
|
+
if (typeof this.options.onSelect === 'function') {
|
9826
|
+
this.options.onSelect.call(this, this.hours, this.minutes);
|
9827
|
+
}
|
9828
|
+
|
9712
9829
|
// Unbind mousemove event
|
9713
9830
|
document.removeEventListener('mousemove', this._handleDocumentClickMoveBound);
|
9714
9831
|
document.removeEventListener('touchmove', this._handleDocumentClickMoveBound);
|
@@ -9731,11 +9848,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9731
9848
|
}, {
|
9732
9849
|
key: "_setupModal",
|
9733
9850
|
value: function _setupModal() {
|
9734
|
-
var
|
9851
|
+
var _this59 = this;
|
9735
9852
|
|
9736
9853
|
this.modal = M.Modal.init(this.modalEl, {
|
9854
|
+
onOpenStart: this.options.onOpenStart,
|
9855
|
+
onOpenEnd: this.options.onOpenEnd,
|
9856
|
+
onCloseStart: this.options.onCloseStart,
|
9737
9857
|
onCloseEnd: function () {
|
9738
|
-
|
9858
|
+
if (typeof _this59.options.onCloseEnd === 'function') {
|
9859
|
+
_this59.options.onCloseEnd.call(_this59);
|
9860
|
+
}
|
9861
|
+
_this59.isOpen = false;
|
9739
9862
|
}
|
9740
9863
|
});
|
9741
9864
|
}
|
@@ -9759,8 +9882,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9759
9882
|
}, {
|
9760
9883
|
key: "_pickerSetup",
|
9761
9884
|
value: function _pickerSetup() {
|
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));
|
9885
|
+
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
9886
|
if (this.options.showClearBtn) {
|
9765
9887
|
$clearBtn.css({ visibility: '' });
|
9766
9888
|
}
|
@@ -9891,12 +10013,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9891
10013
|
// Get the time
|
9892
10014
|
var value = ((this.el.value || this.options.defaultTime || '') + '').split(':');
|
9893
10015
|
if (this.options.twelveHour && !(typeof value[1] === 'undefined')) {
|
9894
|
-
if (value[1].toUpperCase().indexOf(
|
10016
|
+
if (value[1].toUpperCase().indexOf('AM') > 0) {
|
9895
10017
|
this.amOrPm = 'AM';
|
9896
10018
|
} else {
|
9897
10019
|
this.amOrPm = 'PM';
|
9898
10020
|
}
|
9899
|
-
value[1] = value[1].replace(
|
10021
|
+
value[1] = value[1].replace('AM', '').replace('PM', '');
|
9900
10022
|
}
|
9901
10023
|
if (value[0] === 'now') {
|
9902
10024
|
var now = new Date(+new Date() + this.options.fromNow);
|
@@ -9915,7 +10037,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9915
10037
|
}, {
|
9916
10038
|
key: "showView",
|
9917
10039
|
value: function showView(view, delay) {
|
9918
|
-
if (view === 'minutes' && $(this.hoursView).css(
|
10040
|
+
if (view === 'minutes' && $(this.hoursView).css('visibility') === 'visible') {
|
9919
10041
|
// raiseCallback(this.options.beforeHourSelect);
|
9920
10042
|
}
|
9921
10043
|
var isHours = view === 'hours',
|
@@ -9965,7 +10087,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
9965
10087
|
}, {
|
9966
10088
|
key: "setHand",
|
9967
10089
|
value: function setHand(x, y, roundBy5) {
|
9968
|
-
var
|
10090
|
+
var _this60 = this;
|
9969
10091
|
|
9970
10092
|
var radian = Math.atan2(x, -y),
|
9971
10093
|
isHours = this.currentView === 'hours',
|
@@ -10020,7 +10142,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10020
10142
|
if (!this.vibrateTimer) {
|
10021
10143
|
navigator[this.vibrate](10);
|
10022
10144
|
this.vibrateTimer = setTimeout(function () {
|
10023
|
-
|
10145
|
+
_this60.vibrateTimer = null;
|
10024
10146
|
}, 100);
|
10025
10147
|
}
|
10026
10148
|
}
|
@@ -10053,6 +10175,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10053
10175
|
this.isOpen = true;
|
10054
10176
|
this._updateTimeFromInput();
|
10055
10177
|
this.showView('hours');
|
10178
|
+
|
10056
10179
|
this.modal.open();
|
10057
10180
|
}
|
10058
10181
|
}, {
|
@@ -10184,20 +10307,20 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10184
10307
|
function CharacterCounter(el, options) {
|
10185
10308
|
_classCallCheck(this, CharacterCounter);
|
10186
10309
|
|
10187
|
-
var
|
10310
|
+
var _this61 = _possibleConstructorReturn(this, (CharacterCounter.__proto__ || Object.getPrototypeOf(CharacterCounter)).call(this, CharacterCounter, el, options));
|
10188
10311
|
|
10189
|
-
|
10312
|
+
_this61.el.M_CharacterCounter = _this61;
|
10190
10313
|
|
10191
10314
|
/**
|
10192
10315
|
* Options for the character counter
|
10193
10316
|
*/
|
10194
|
-
|
10317
|
+
_this61.options = $.extend({}, CharacterCounter.defaults, options);
|
10195
10318
|
|
10196
|
-
|
10197
|
-
|
10198
|
-
|
10199
|
-
|
10200
|
-
return
|
10319
|
+
_this61.isInvalid = false;
|
10320
|
+
_this61.isValidLength = false;
|
10321
|
+
_this61._setupCounter();
|
10322
|
+
_this61._setupEventHandlers();
|
10323
|
+
return _this61;
|
10201
10324
|
}
|
10202
10325
|
|
10203
10326
|
_createClass(CharacterCounter, [{
|
@@ -10364,9 +10487,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10364
10487
|
function Carousel(el, options) {
|
10365
10488
|
_classCallCheck(this, Carousel);
|
10366
10489
|
|
10367
|
-
var
|
10490
|
+
var _this62 = _possibleConstructorReturn(this, (Carousel.__proto__ || Object.getPrototypeOf(Carousel)).call(this, Carousel, el, options));
|
10368
10491
|
|
10369
|
-
|
10492
|
+
_this62.el.M_Carousel = _this62;
|
10370
10493
|
|
10371
10494
|
/**
|
10372
10495
|
* Options for the carousel
|
@@ -10381,38 +10504,38 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10381
10504
|
* @prop {Boolean} noWrap
|
10382
10505
|
* @prop {Function} onCycleTo
|
10383
10506
|
*/
|
10384
|
-
|
10507
|
+
_this62.options = $.extend({}, Carousel.defaults, options);
|
10385
10508
|
|
10386
10509
|
// Setup
|
10387
|
-
|
10388
|
-
|
10389
|
-
|
10390
|
-
|
10391
|
-
|
10392
|
-
|
10393
|
-
|
10394
|
-
|
10395
|
-
|
10396
|
-
|
10397
|
-
|
10398
|
-
|
10510
|
+
_this62.hasMultipleSlides = _this62.$el.find('.carousel-item').length > 1;
|
10511
|
+
_this62.showIndicators = _this62.options.indicators && _this62.hasMultipleSlides;
|
10512
|
+
_this62.noWrap = _this62.options.noWrap || !_this62.hasMultipleSlides;
|
10513
|
+
_this62.pressed = false;
|
10514
|
+
_this62.dragged = false;
|
10515
|
+
_this62.offset = _this62.target = 0;
|
10516
|
+
_this62.images = [];
|
10517
|
+
_this62.itemWidth = _this62.$el.find('.carousel-item').first().innerWidth();
|
10518
|
+
_this62.itemHeight = _this62.$el.find('.carousel-item').first().innerHeight();
|
10519
|
+
_this62.dim = _this62.itemWidth * 2 + _this62.options.padding || 1; // Make sure dim is non zero for divisions.
|
10520
|
+
_this62._autoScrollBound = _this62._autoScroll.bind(_this62);
|
10521
|
+
_this62._trackBound = _this62._track.bind(_this62);
|
10399
10522
|
|
10400
10523
|
// Full Width carousel setup
|
10401
|
-
if (
|
10402
|
-
|
10403
|
-
|
10524
|
+
if (_this62.options.fullWidth) {
|
10525
|
+
_this62.options.dist = 0;
|
10526
|
+
_this62._setCarouselHeight();
|
10404
10527
|
|
10405
10528
|
// Offset fixed items when indicators.
|
10406
|
-
if (
|
10407
|
-
|
10529
|
+
if (_this62.showIndicators) {
|
10530
|
+
_this62.$el.find('.carousel-fixed-item').addClass('with-indicators');
|
10408
10531
|
}
|
10409
10532
|
}
|
10410
10533
|
|
10411
10534
|
// Iterate through slides
|
10412
|
-
|
10413
|
-
|
10414
|
-
|
10415
|
-
if (
|
10535
|
+
_this62.$indicators = $('<ul class="indicators"></ul>');
|
10536
|
+
_this62.$el.find('.carousel-item').each(function (el, i) {
|
10537
|
+
_this62.images.push(el);
|
10538
|
+
if (_this62.showIndicators) {
|
10416
10539
|
var $indicator = $('<li class="indicator-item"></li>');
|
10417
10540
|
|
10418
10541
|
// Add active to first by default.
|
@@ -10420,31 +10543,31 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10420
10543
|
$indicator[0].classList.add('active');
|
10421
10544
|
}
|
10422
10545
|
|
10423
|
-
|
10546
|
+
_this62.$indicators.append($indicator);
|
10424
10547
|
}
|
10425
10548
|
});
|
10426
|
-
if (
|
10427
|
-
|
10549
|
+
if (_this62.showIndicators) {
|
10550
|
+
_this62.$el.append(_this62.$indicators);
|
10428
10551
|
}
|
10429
|
-
|
10552
|
+
_this62.count = _this62.images.length;
|
10430
10553
|
|
10431
10554
|
// Cap numVisible at count
|
10432
|
-
|
10555
|
+
_this62.options.numVisible = Math.min(_this62.count, _this62.options.numVisible);
|
10433
10556
|
|
10434
10557
|
// Setup cross browser string
|
10435
|
-
|
10558
|
+
_this62.xform = 'transform';
|
10436
10559
|
['webkit', 'Moz', 'O', 'ms'].every(function (prefix) {
|
10437
10560
|
var e = prefix + 'Transform';
|
10438
10561
|
if (typeof document.body.style[e] !== 'undefined') {
|
10439
|
-
|
10562
|
+
_this62.xform = e;
|
10440
10563
|
return false;
|
10441
10564
|
}
|
10442
10565
|
return true;
|
10443
10566
|
});
|
10444
10567
|
|
10445
|
-
|
10446
|
-
|
10447
|
-
return
|
10568
|
+
_this62._setupEventHandlers();
|
10569
|
+
_this62._scroll(_this62.offset);
|
10570
|
+
return _this62;
|
10448
10571
|
}
|
10449
10572
|
|
10450
10573
|
_createClass(Carousel, [{
|
@@ -10466,7 +10589,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10466
10589
|
}, {
|
10467
10590
|
key: "_setupEventHandlers",
|
10468
10591
|
value: function _setupEventHandlers() {
|
10469
|
-
var
|
10592
|
+
var _this63 = this;
|
10470
10593
|
|
10471
10594
|
this._handleCarouselTapBound = this._handleCarouselTap.bind(this);
|
10472
10595
|
this._handleCarouselDragBound = this._handleCarouselDrag.bind(this);
|
@@ -10488,7 +10611,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10488
10611
|
if (this.showIndicators && this.$indicators) {
|
10489
10612
|
this._handleIndicatorClickBound = this._handleIndicatorClick.bind(this);
|
10490
10613
|
this.$indicators.find('.indicator-item').each(function (el, i) {
|
10491
|
-
el.addEventListener('click',
|
10614
|
+
el.addEventListener('click', _this63._handleIndicatorClickBound);
|
10492
10615
|
});
|
10493
10616
|
}
|
10494
10617
|
|
@@ -10506,7 +10629,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10506
10629
|
}, {
|
10507
10630
|
key: "_removeEventHandlers",
|
10508
10631
|
value: function _removeEventHandlers() {
|
10509
|
-
var
|
10632
|
+
var _this64 = this;
|
10510
10633
|
|
10511
10634
|
if (typeof window.ontouchstart !== 'undefined') {
|
10512
10635
|
this.el.removeEventListener('touchstart', this._handleCarouselTapBound);
|
@@ -10521,7 +10644,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10521
10644
|
|
10522
10645
|
if (this.showIndicators && this.$indicators) {
|
10523
10646
|
this.$indicators.find('.indicator-item').each(function (el, i) {
|
10524
|
-
el.removeEventListener('click',
|
10647
|
+
el.removeEventListener('click', _this64._handleIndicatorClickBound);
|
10525
10648
|
});
|
10526
10649
|
}
|
10527
10650
|
|
@@ -10707,7 +10830,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10707
10830
|
}, {
|
10708
10831
|
key: "_setCarouselHeight",
|
10709
10832
|
value: function _setCarouselHeight(imageOnly) {
|
10710
|
-
var
|
10833
|
+
var _this65 = this;
|
10711
10834
|
|
10712
10835
|
var firstSlide = this.$el.find('.carousel-item.active').length ? this.$el.find('.carousel-item.active').first() : this.$el.find('.carousel-item').first();
|
10713
10836
|
var firstImage = firstSlide.find('img').first();
|
@@ -10727,7 +10850,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10727
10850
|
} else {
|
10728
10851
|
// Get height when image is loaded normally
|
10729
10852
|
firstImage.one('load', function (el, i) {
|
10730
|
-
|
10853
|
+
_this65.$el.css('height', el.offsetHeight + 'px');
|
10731
10854
|
});
|
10732
10855
|
}
|
10733
10856
|
} else if (!imageOnly) {
|
@@ -10833,7 +10956,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10833
10956
|
}, {
|
10834
10957
|
key: "_scroll",
|
10835
10958
|
value: function _scroll(x) {
|
10836
|
-
var
|
10959
|
+
var _this66 = this;
|
10837
10960
|
|
10838
10961
|
// Track scrolling state
|
10839
10962
|
if (!this.$el.hasClass('scrolling')) {
|
@@ -10843,7 +10966,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10843
10966
|
window.clearTimeout(this.scrollingTimeout);
|
10844
10967
|
}
|
10845
10968
|
this.scrollingTimeout = window.setTimeout(function () {
|
10846
|
-
|
10969
|
+
_this66.$el.removeClass('scrolling');
|
10847
10970
|
}, this.options.duration);
|
10848
10971
|
|
10849
10972
|
// Start actual scroll
|
@@ -10896,7 +11019,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10896
11019
|
this.$el.find('.carousel-item').removeClass('active');
|
10897
11020
|
el.classList.add('active');
|
10898
11021
|
}
|
10899
|
-
var transformString = alignment +
|
11022
|
+
var transformString = alignment + " translateX(" + -delta / 2 + "px) translateX(" + dir * this.options.shift * tween * i + "px) translateZ(" + this.options.dist * tween + "px)";
|
10900
11023
|
this._updateItemStyle(el, centerTweenedOpacity, 0, transformString);
|
10901
11024
|
}
|
10902
11025
|
|
@@ -10912,7 +11035,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10912
11035
|
// Don't show wrapped items.
|
10913
11036
|
if (!this.noWrap || this.center + i < this.count) {
|
10914
11037
|
el = this.images[this._wrap(this.center + i)];
|
10915
|
-
var _transformString = alignment +
|
11038
|
+
var _transformString = alignment + " translateX(" + (this.options.shift + (this.dim * i - delta) / 2) + "px) translateZ(" + zTranslation + "px)";
|
10916
11039
|
this._updateItemStyle(el, tweenedOpacity, -i, _transformString);
|
10917
11040
|
}
|
10918
11041
|
|
@@ -10927,7 +11050,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10927
11050
|
// Don't show wrapped items.
|
10928
11051
|
if (!this.noWrap || this.center - i >= 0) {
|
10929
11052
|
el = this.images[this._wrap(this.center - i)];
|
10930
|
-
var _transformString2 = alignment +
|
11053
|
+
var _transformString2 = alignment + " translateX(" + (-this.options.shift + (-this.dim * i - delta) / 2) + "px) translateZ(" + zTranslation + "px)";
|
10931
11054
|
this._updateItemStyle(el, tweenedOpacity, -i, _transformString2);
|
10932
11055
|
}
|
10933
11056
|
}
|
@@ -10936,18 +11059,18 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
10936
11059
|
// Don't show wrapped items.
|
10937
11060
|
if (!this.noWrap || this.center >= 0 && this.center < this.count) {
|
10938
11061
|
el = this.images[this._wrap(this.center)];
|
10939
|
-
var _transformString3 = alignment +
|
11062
|
+
var _transformString3 = alignment + " translateX(" + -delta / 2 + "px) translateX(" + dir * this.options.shift * tween + "px) translateZ(" + this.options.dist * tween + "px)";
|
10940
11063
|
this._updateItemStyle(el, centerTweenedOpacity, 0, _transformString3);
|
10941
11064
|
}
|
10942
11065
|
|
10943
11066
|
// onCycleTo callback
|
10944
11067
|
var $currItem = this.$el.find('.carousel-item').eq(this._wrap(this.center));
|
10945
|
-
if (lastCenter !== this.center && typeof this.options.onCycleTo ===
|
11068
|
+
if (lastCenter !== this.center && typeof this.options.onCycleTo === 'function') {
|
10946
11069
|
this.options.onCycleTo.call(this, $currItem[0], this.dragged);
|
10947
11070
|
}
|
10948
11071
|
|
10949
11072
|
// One time callback
|
10950
|
-
if (typeof this.oneTimeCallback ===
|
11073
|
+
if (typeof this.oneTimeCallback === 'function') {
|
10951
11074
|
this.oneTimeCallback.call(this, $currItem[0], this.dragged);
|
10952
11075
|
this.oneTimeCallback = null;
|
10953
11076
|
}
|
@@ -11005,7 +11128,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11005
11128
|
}
|
11006
11129
|
|
11007
11130
|
// Set one time callback
|
11008
|
-
if (typeof callback ===
|
11131
|
+
if (typeof callback === 'function') {
|
11009
11132
|
this.oneTimeCallback = callback;
|
11010
11133
|
}
|
11011
11134
|
|
@@ -11030,7 +11153,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11030
11153
|
}
|
11031
11154
|
|
11032
11155
|
var index = this.center + n;
|
11033
|
-
if (index
|
11156
|
+
if (index >= this.count || index < 0) {
|
11034
11157
|
if (this.noWrap) {
|
11035
11158
|
return;
|
11036
11159
|
}
|
@@ -11053,7 +11176,7 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11053
11176
|
}
|
11054
11177
|
|
11055
11178
|
var index = this.center - n;
|
11056
|
-
if (index
|
11179
|
+
if (index >= this.count || index < 0) {
|
11057
11180
|
if (this.noWrap) {
|
11058
11181
|
return;
|
11059
11182
|
}
|
@@ -11144,9 +11267,9 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11144
11267
|
function TapTarget(el, options) {
|
11145
11268
|
_classCallCheck(this, TapTarget);
|
11146
11269
|
|
11147
|
-
var
|
11270
|
+
var _this67 = _possibleConstructorReturn(this, (TapTarget.__proto__ || Object.getPrototypeOf(TapTarget)).call(this, TapTarget, el, options));
|
11148
11271
|
|
11149
|
-
|
11272
|
+
_this67.el.M_TapTarget = _this67;
|
11150
11273
|
|
11151
11274
|
/**
|
11152
11275
|
* Options for the select
|
@@ -11154,17 +11277,17 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11154
11277
|
* @prop {Function} onOpen - Callback function called when feature discovery is opened
|
11155
11278
|
* @prop {Function} onClose - Callback function called when feature discovery is closed
|
11156
11279
|
*/
|
11157
|
-
|
11280
|
+
_this67.options = $.extend({}, TapTarget.defaults, options);
|
11158
11281
|
|
11159
|
-
|
11282
|
+
_this67.isOpen = false;
|
11160
11283
|
|
11161
11284
|
// setup
|
11162
|
-
|
11163
|
-
|
11285
|
+
_this67.$origin = $('#' + _this67.$el.attr('data-target'));
|
11286
|
+
_this67._setup();
|
11164
11287
|
|
11165
|
-
|
11166
|
-
|
11167
|
-
return
|
11288
|
+
_this67._calculatePositioning();
|
11289
|
+
_this67._setupEventHandlers();
|
11290
|
+
return _this67;
|
11168
11291
|
}
|
11169
11292
|
|
11170
11293
|
_createClass(TapTarget, [{
|
@@ -11499,30 +11622,30 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11499
11622
|
_classCallCheck(this, FormSelect);
|
11500
11623
|
|
11501
11624
|
// Don't init if browser default version
|
11502
|
-
var
|
11625
|
+
var _this68 = _possibleConstructorReturn(this, (FormSelect.__proto__ || Object.getPrototypeOf(FormSelect)).call(this, FormSelect, el, options));
|
11503
11626
|
|
11504
|
-
if (
|
11505
|
-
return _possibleConstructorReturn(
|
11627
|
+
if (_this68.$el.hasClass('browser-default')) {
|
11628
|
+
return _possibleConstructorReturn(_this68);
|
11506
11629
|
}
|
11507
11630
|
|
11508
|
-
|
11631
|
+
_this68.el.M_FormSelect = _this68;
|
11509
11632
|
|
11510
11633
|
/**
|
11511
11634
|
* Options for the select
|
11512
11635
|
* @member FormSelect#options
|
11513
11636
|
*/
|
11514
|
-
|
11637
|
+
_this68.options = $.extend({}, FormSelect.defaults, options);
|
11515
11638
|
|
11516
|
-
|
11639
|
+
_this68.isMultiple = _this68.$el.prop('multiple');
|
11517
11640
|
|
11518
11641
|
// Setup
|
11519
|
-
|
11520
|
-
|
11521
|
-
|
11522
|
-
|
11642
|
+
_this68.el.tabIndex = -1;
|
11643
|
+
_this68._keysSelected = {};
|
11644
|
+
_this68._valueDict = {}; // Maps key to original and generated option element.
|
11645
|
+
_this68._setupDropdown();
|
11523
11646
|
|
11524
|
-
|
11525
|
-
return
|
11647
|
+
_this68._setupEventHandlers();
|
11648
|
+
return _this68;
|
11526
11649
|
}
|
11527
11650
|
|
11528
11651
|
_createClass(FormSelect, [{
|
@@ -11545,14 +11668,14 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11545
11668
|
}, {
|
11546
11669
|
key: "_setupEventHandlers",
|
11547
11670
|
value: function _setupEventHandlers() {
|
11548
|
-
var
|
11671
|
+
var _this69 = this;
|
11549
11672
|
|
11550
11673
|
this._handleSelectChangeBound = this._handleSelectChange.bind(this);
|
11551
11674
|
this._handleOptionClickBound = this._handleOptionClick.bind(this);
|
11552
11675
|
this._handleInputClickBound = this._handleInputClick.bind(this);
|
11553
11676
|
|
11554
11677
|
$(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
|
11555
|
-
el.addEventListener('click',
|
11678
|
+
el.addEventListener('click', _this69._handleOptionClickBound);
|
11556
11679
|
});
|
11557
11680
|
this.el.addEventListener('change', this._handleSelectChangeBound);
|
11558
11681
|
this.input.addEventListener('click', this._handleInputClickBound);
|
@@ -11565,10 +11688,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11565
11688
|
}, {
|
11566
11689
|
key: "_removeEventHandlers",
|
11567
11690
|
value: function _removeEventHandlers() {
|
11568
|
-
var
|
11691
|
+
var _this70 = this;
|
11569
11692
|
|
11570
11693
|
$(this.dropdownOptions).find('li:not(.optgroup)').each(function (el) {
|
11571
|
-
el.removeEventListener('click',
|
11694
|
+
el.removeEventListener('click', _this70._handleOptionClickBound);
|
11572
11695
|
});
|
11573
11696
|
this.el.removeEventListener('change', this._handleSelectChangeBound);
|
11574
11697
|
this.input.removeEventListener('click', this._handleInputClickBound);
|
@@ -11607,19 +11730,19 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11607
11730
|
placeholderOption.find('input[type="checkbox"]').prop('checked', false);
|
11608
11731
|
this._toggleEntryFromArray(placeholderOption[0].id);
|
11609
11732
|
}
|
11610
|
-
|
11611
|
-
var checkbox = $(option).find('input[type="checkbox"]');
|
11612
|
-
checkbox.prop('checked', !checkbox.prop('checked'));
|
11613
11733
|
selected = this._toggleEntryFromArray(key);
|
11614
11734
|
} else {
|
11615
|
-
$(this.dropdownOptions).find('li').removeClass('
|
11616
|
-
$(option).toggleClass('
|
11617
|
-
this.input.value = option.textContent;
|
11735
|
+
$(this.dropdownOptions).find('li').removeClass('selected');
|
11736
|
+
$(option).toggleClass('selected', selected);
|
11618
11737
|
}
|
11619
11738
|
|
11620
|
-
|
11621
|
-
|
11622
|
-
this
|
11739
|
+
// Set selected on original select option
|
11740
|
+
// Only trigger if selected state changed
|
11741
|
+
var prevSelected = $(this._valueDict[key].el).prop('selected');
|
11742
|
+
if (prevSelected !== selected) {
|
11743
|
+
$(this._valueDict[key].el).prop('selected', selected);
|
11744
|
+
this.$el.trigger('change');
|
11745
|
+
}
|
11623
11746
|
}
|
11624
11747
|
|
11625
11748
|
e.stopPropagation();
|
@@ -11645,10 +11768,10 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11645
11768
|
}, {
|
11646
11769
|
key: "_setupDropdown",
|
11647
11770
|
value: function _setupDropdown() {
|
11648
|
-
var
|
11771
|
+
var _this71 = this;
|
11649
11772
|
|
11650
11773
|
this.wrapper = document.createElement('div');
|
11651
|
-
$(this.wrapper).addClass('select-wrapper
|
11774
|
+
$(this.wrapper).addClass('select-wrapper ' + this.options.classes);
|
11652
11775
|
this.$el.before($(this.wrapper));
|
11653
11776
|
this.wrapper.appendChild(this.el);
|
11654
11777
|
|
@@ -11668,21 +11791,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11668
11791
|
if ($(el).is('option')) {
|
11669
11792
|
// Direct descendant option.
|
11670
11793
|
var optionEl = void 0;
|
11671
|
-
if (
|
11672
|
-
optionEl =
|
11794
|
+
if (_this71.isMultiple) {
|
11795
|
+
optionEl = _this71._appendOptionWithIcon(_this71.$el, el, 'multiple');
|
11673
11796
|
} else {
|
11674
|
-
optionEl =
|
11797
|
+
optionEl = _this71._appendOptionWithIcon(_this71.$el, el);
|
11675
11798
|
}
|
11676
11799
|
|
11677
|
-
|
11800
|
+
_this71._addOptionToValueDict(el, optionEl);
|
11678
11801
|
} else if ($(el).is('optgroup')) {
|
11679
11802
|
// Optgroup.
|
11680
11803
|
var selectOptions = $(el).children('option');
|
11681
|
-
$(
|
11804
|
+
$(_this71.dropdownOptions).append($('<li class="optgroup"><span>' + el.getAttribute('label') + '</span></li>')[0]);
|
11682
11805
|
|
11683
11806
|
selectOptions.each(function (el) {
|
11684
|
-
var optionEl =
|
11685
|
-
|
11807
|
+
var optionEl = _this71._appendOptionWithIcon(_this71.$el, el, 'optgroup-option');
|
11808
|
+
_this71._addOptionToValueDict(el, optionEl);
|
11686
11809
|
});
|
11687
11810
|
}
|
11688
11811
|
});
|
@@ -11713,11 +11836,21 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11713
11836
|
|
11714
11837
|
// Add callback for centering selected option when dropdown content is scrollable
|
11715
11838
|
dropdownOptions.onOpenEnd = function (el) {
|
11716
|
-
var selectedOption = $(
|
11717
|
-
|
11718
|
-
|
11719
|
-
|
11720
|
-
|
11839
|
+
var selectedOption = $(_this71.dropdownOptions).find('.selected').first();
|
11840
|
+
|
11841
|
+
if (selectedOption.length) {
|
11842
|
+
// Focus selected option in dropdown
|
11843
|
+
M.keyDown = true;
|
11844
|
+
_this71.dropdown.focusedIndex = selectedOption.index();
|
11845
|
+
_this71.dropdown._focusFocusedItem();
|
11846
|
+
M.keyDown = false;
|
11847
|
+
|
11848
|
+
// Handle scrolling to selected option
|
11849
|
+
if (_this71.dropdown.isScrollable) {
|
11850
|
+
var scrollOffset = selectedOption[0].getBoundingClientRect().top - _this71.dropdownOptions.getBoundingClientRect().top; // scroll to selected option
|
11851
|
+
scrollOffset -= _this71.dropdownOptions.clientHeight / 2; // center in dropdown
|
11852
|
+
_this71.dropdownOptions.scrollTop = scrollOffset;
|
11853
|
+
}
|
11721
11854
|
}
|
11722
11855
|
};
|
11723
11856
|
|
@@ -11787,9 +11920,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11787
11920
|
|
11788
11921
|
// add icons
|
11789
11922
|
var iconUrl = option.getAttribute('data-icon');
|
11790
|
-
var classes = option.getAttribute('class');
|
11791
11923
|
if (!!iconUrl) {
|
11792
|
-
var imgEl = $(
|
11924
|
+
var imgEl = $("<img alt=\"\" src=\"" + iconUrl + "\">");
|
11793
11925
|
liEl.prepend(imgEl);
|
11794
11926
|
}
|
11795
11927
|
|
@@ -11808,49 +11940,54 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11808
11940
|
key: "_toggleEntryFromArray",
|
11809
11941
|
value: function _toggleEntryFromArray(key) {
|
11810
11942
|
var notAdded = !this._keysSelected.hasOwnProperty(key);
|
11943
|
+
var $optionLi = $(this._valueDict[key].optionEl);
|
11944
|
+
|
11811
11945
|
if (notAdded) {
|
11812
11946
|
this._keysSelected[key] = true;
|
11813
11947
|
} else {
|
11814
11948
|
delete this._keysSelected[key];
|
11815
11949
|
}
|
11816
11950
|
|
11817
|
-
$
|
11951
|
+
$optionLi.toggleClass('selected', notAdded);
|
11952
|
+
|
11953
|
+
// Set checkbox checked value
|
11954
|
+
$optionLi.find('input[type="checkbox"]').prop('checked', notAdded);
|
11818
11955
|
|
11819
11956
|
// use notAdded instead of true (to detect if the option is selected or not)
|
11820
|
-
$
|
11957
|
+
$optionLi.prop('selected', notAdded);
|
11821
11958
|
|
11822
11959
|
return notAdded;
|
11823
11960
|
}
|
11824
11961
|
|
11825
11962
|
/**
|
11826
|
-
* Set value to input
|
11963
|
+
* Set text value to input
|
11827
11964
|
*/
|
11828
11965
|
|
11829
11966
|
}, {
|
11830
11967
|
key: "_setValueToInput",
|
11831
11968
|
value: function _setValueToInput() {
|
11832
|
-
var
|
11969
|
+
var values = [];
|
11833
11970
|
var options = this.$el.find('option');
|
11834
11971
|
|
11835
11972
|
options.each(function (el) {
|
11836
11973
|
if ($(el).prop('selected')) {
|
11837
11974
|
var text = $(el).text();
|
11838
|
-
|
11975
|
+
values.push(text);
|
11839
11976
|
}
|
11840
11977
|
});
|
11841
11978
|
|
11842
|
-
if (
|
11979
|
+
if (!values.length) {
|
11843
11980
|
var firstDisabled = this.$el.find('option:disabled').eq(0);
|
11844
|
-
if (firstDisabled.length) {
|
11845
|
-
|
11981
|
+
if (firstDisabled.length && firstDisabled[0].value === '') {
|
11982
|
+
values.push(firstDisabled.text());
|
11846
11983
|
}
|
11847
11984
|
}
|
11848
11985
|
|
11849
|
-
this.input.value =
|
11986
|
+
this.input.value = values.join(', ');
|
11850
11987
|
}
|
11851
11988
|
|
11852
11989
|
/**
|
11853
|
-
* Set selected state of dropdown
|
11990
|
+
* Set selected state of dropdown to match actual select element
|
11854
11991
|
*/
|
11855
11992
|
|
11856
11993
|
}, {
|
@@ -11860,12 +11997,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11860
11997
|
|
11861
11998
|
for (var key in this._valueDict) {
|
11862
11999
|
var option = this._valueDict[key];
|
11863
|
-
|
11864
|
-
|
12000
|
+
var optionIsSelected = $(option.el).prop('selected');
|
12001
|
+
$(option.optionEl).find('input[type="checkbox"]').prop('checked', optionIsSelected);
|
12002
|
+
if (optionIsSelected) {
|
11865
12003
|
this._activateOption($(this.dropdownOptions), $(option.optionEl));
|
11866
12004
|
this._keysSelected[key] = true;
|
11867
12005
|
} else {
|
11868
|
-
$(option.optionEl).find('input[type="checkbox"]').prop("checked", false);
|
11869
12006
|
$(option.optionEl).removeClass('selected');
|
11870
12007
|
}
|
11871
12008
|
}
|
@@ -11884,7 +12021,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11884
12021
|
if (!this.isMultiple) {
|
11885
12022
|
collection.find('li.selected').removeClass('selected');
|
11886
12023
|
}
|
11887
|
-
|
11888
12024
|
var option = $(newOption);
|
11889
12025
|
option.addClass('selected');
|
11890
12026
|
}
|
@@ -11958,23 +12094,23 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11958
12094
|
function Range(el, options) {
|
11959
12095
|
_classCallCheck(this, Range);
|
11960
12096
|
|
11961
|
-
var
|
12097
|
+
var _this72 = _possibleConstructorReturn(this, (Range.__proto__ || Object.getPrototypeOf(Range)).call(this, Range, el, options));
|
11962
12098
|
|
11963
|
-
|
12099
|
+
_this72.el.M_Range = _this72;
|
11964
12100
|
|
11965
12101
|
/**
|
11966
12102
|
* Options for the range
|
11967
12103
|
* @member Range#options
|
11968
12104
|
*/
|
11969
|
-
|
12105
|
+
_this72.options = $.extend({}, Range.defaults, options);
|
11970
12106
|
|
11971
|
-
|
12107
|
+
_this72._mousedown = false;
|
11972
12108
|
|
11973
12109
|
// Setup
|
11974
|
-
|
12110
|
+
_this72._setupThumb();
|
11975
12111
|
|
11976
|
-
|
11977
|
-
return
|
12112
|
+
_this72._setupEventHandlers();
|
12113
|
+
return _this72;
|
11978
12114
|
}
|
11979
12115
|
|
11980
12116
|
_createClass(Range, [{
|
@@ -11998,14 +12134,12 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
11998
12134
|
key: "_setupEventHandlers",
|
11999
12135
|
value: function _setupEventHandlers() {
|
12000
12136
|
this._handleRangeChangeBound = this._handleRangeChange.bind(this);
|
12001
|
-
this._handleRangeFocusBound = this._handleRangeFocus.bind(this);
|
12002
12137
|
this._handleRangeMousedownTouchstartBound = this._handleRangeMousedownTouchstart.bind(this);
|
12003
12138
|
this._handleRangeInputMousemoveTouchmoveBound = this._handleRangeInputMousemoveTouchmove.bind(this);
|
12004
12139
|
this._handleRangeMouseupTouchendBound = this._handleRangeMouseupTouchend.bind(this);
|
12005
12140
|
this._handleRangeBlurMouseoutTouchleaveBound = this._handleRangeBlurMouseoutTouchleave.bind(this);
|
12006
12141
|
|
12007
12142
|
this.el.addEventListener('change', this._handleRangeChangeBound);
|
12008
|
-
this.el.addEventListener('focus', this._handleRangeFocusBound);
|
12009
12143
|
|
12010
12144
|
this.el.addEventListener('mousedown', this._handleRangeMousedownTouchstartBound);
|
12011
12145
|
this.el.addEventListener('touchstart', this._handleRangeMousedownTouchstartBound);
|
@@ -12030,7 +12164,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
12030
12164
|
key: "_removeEventHandlers",
|
12031
12165
|
value: function _removeEventHandlers() {
|
12032
12166
|
this.el.removeEventListener('change', this._handleRangeChangeBound);
|
12033
|
-
this.el.removeEventListener('focus', this._handleRangeFocusBound);
|
12034
12167
|
|
12035
12168
|
this.el.removeEventListener('mousedown', this._handleRangeMousedownTouchstartBound);
|
12036
12169
|
this.el.removeEventListener('touchstart', this._handleRangeMousedownTouchstartBound);
|
@@ -12065,19 +12198,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
12065
12198
|
$(this.thumb).addClass('active').css('left', offsetLeft + 'px');
|
12066
12199
|
}
|
12067
12200
|
|
12068
|
-
/**
|
12069
|
-
* Handle Range Focus
|
12070
|
-
* @param {Event} e
|
12071
|
-
*/
|
12072
|
-
|
12073
|
-
}, {
|
12074
|
-
key: "_handleRangeFocus",
|
12075
|
-
value: function _handleRangeFocus() {
|
12076
|
-
if (M.tabPressed) {
|
12077
|
-
this.$el.addClass('focused');
|
12078
|
-
}
|
12079
|
-
}
|
12080
|
-
|
12081
12201
|
/**
|
12082
12202
|
* Handle Range Mousedown and Touchstart
|
12083
12203
|
* @param {Event} e
|
@@ -12139,7 +12259,6 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
12139
12259
|
key: "_handleRangeBlurMouseoutTouchleave",
|
12140
12260
|
value: function _handleRangeBlurMouseoutTouchleave() {
|
12141
12261
|
if (!this._mousedown) {
|
12142
|
-
this.$el.removeClass('focused');
|
12143
12262
|
var paddingLeft = parseInt(this.$el.css('padding-left'));
|
12144
12263
|
var marginLeft = 7 + paddingLeft + 'px';
|
12145
12264
|
|
@@ -12214,8 +12333,8 @@ $jscomp.polyfill = function (e, r, p, m) {
|
|
12214
12333
|
key: "_calcRangeOffset",
|
12215
12334
|
value: function _calcRangeOffset() {
|
12216
12335
|
var width = this.$el.width() - 15;
|
12217
|
-
var max = parseFloat(this.$el.attr('max'));
|
12218
|
-
var min = parseFloat(this.$el.attr('min'));
|
12336
|
+
var max = parseFloat(this.$el.attr('max')) || 100; // Range default max
|
12337
|
+
var min = parseFloat(this.$el.attr('min')) || 0; // Range default min
|
12219
12338
|
var percent = (parseFloat(this.$el.val()) - min) / (max - min);
|
12220
12339
|
return percent * width;
|
12221
12340
|
}
|