@materializecss/materialize 1.1.0-alpha → 1.1.0

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.
Files changed (85) hide show
  1. package/Gruntfile.js +115 -132
  2. package/LICENSE +21 -21
  3. package/README.md +97 -97
  4. package/dist/css/materialize.css +8462 -8987
  5. package/dist/css/materialize.min.css +7 -7
  6. package/dist/js/materialize.js +12669 -12791
  7. package/dist/js/materialize.min.js +6 -6
  8. package/extras/noUiSlider/nouislider.css +406 -406
  9. package/extras/noUiSlider/nouislider.js +2147 -2147
  10. package/extras/noUiSlider/nouislider.min.js +0 -0
  11. package/js/anime.min.js +34 -34
  12. package/js/autocomplete.js +479 -479
  13. package/js/buttons.js +354 -354
  14. package/js/cards.js +40 -40
  15. package/js/carousel.js +732 -717
  16. package/js/cash.js +960 -960
  17. package/js/characterCounter.js +136 -136
  18. package/js/chips.js +486 -486
  19. package/js/collapsible.js +275 -275
  20. package/js/component.js +44 -44
  21. package/js/datepicker.js +983 -976
  22. package/js/dropdown.js +669 -668
  23. package/js/forms.js +275 -275
  24. package/js/global.js +424 -424
  25. package/js/materialbox.js +453 -453
  26. package/js/modal.js +382 -382
  27. package/js/parallax.js +138 -138
  28. package/js/pushpin.js +148 -148
  29. package/js/range.js +263 -263
  30. package/js/scrollspy.js +295 -295
  31. package/js/select.js +310 -451
  32. package/js/sidenav.js +583 -583
  33. package/js/slider.js +359 -359
  34. package/js/tabs.js +402 -402
  35. package/js/tapTarget.js +315 -315
  36. package/js/timepicker.js +648 -647
  37. package/js/toasts.js +322 -322
  38. package/js/tooltip.js +320 -320
  39. package/js/waves.js +614 -614
  40. package/package.json +82 -74
  41. package/sass/_style.scss +929 -0
  42. package/sass/components/_badges.scss +55 -55
  43. package/sass/components/_buttons.scss +322 -322
  44. package/sass/components/_cards.scss +195 -195
  45. package/sass/components/_carousel.scss +90 -90
  46. package/sass/components/_chips.scss +96 -96
  47. package/sass/components/_collapsible.scss +91 -91
  48. package/sass/components/_collection.scss +107 -0
  49. package/sass/components/_color-classes.scss +32 -32
  50. package/sass/components/_color-variables.scss +370 -370
  51. package/sass/components/_datepicker.scss +191 -191
  52. package/sass/components/_dropdown.scss +84 -84
  53. package/sass/components/_global.scss +642 -771
  54. package/sass/components/_grid.scss +158 -156
  55. package/sass/components/_icons-material-design.scss +5 -5
  56. package/sass/components/_materialbox.scss +42 -42
  57. package/sass/components/_modal.scss +97 -97
  58. package/sass/components/_navbar.scss +208 -208
  59. package/sass/components/_normalize.scss +447 -447
  60. package/sass/components/_preloader.scss +334 -334
  61. package/sass/components/_pulse.scss +34 -34
  62. package/sass/components/_sidenav.scss +214 -214
  63. package/sass/components/_slider.scss +91 -91
  64. package/sass/components/_table_of_contents.scss +33 -33
  65. package/sass/components/_tabs.scss +99 -99
  66. package/sass/components/_tapTarget.scss +103 -103
  67. package/sass/components/_timepicker.scss +183 -183
  68. package/sass/components/_toast.scss +58 -58
  69. package/sass/components/_tooltip.scss +32 -32
  70. package/sass/components/_transitions.scss +12 -12
  71. package/sass/components/_typography.scss +62 -60
  72. package/sass/components/_variables.scss +352 -349
  73. package/sass/components/_waves.scss +187 -187
  74. package/sass/components/forms/_checkboxes.scss +200 -200
  75. package/sass/components/forms/_file-input.scss +44 -44
  76. package/sass/components/forms/_forms.scss +22 -22
  77. package/sass/components/forms/_input-fields.scss +379 -379
  78. package/sass/components/forms/_radio-buttons.scss +115 -115
  79. package/sass/components/forms/_range.scss +161 -161
  80. package/sass/components/forms/_select.scss +199 -199
  81. package/sass/components/forms/_switches.scss +91 -91
  82. package/sass/ghpages-materialize.scss +7 -0
  83. package/sass/materialize.scss +42 -41
  84. package/CHANGELOG.md +0 -76
  85. package/HISTORY.md +0 -527
package/js/forms.js CHANGED
@@ -1,275 +1,275 @@
1
- (function($) {
2
- // Function to update labels of text fields
3
- M.updateTextFields = function() {
4
- let input_selector =
5
- 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
6
- $(input_selector).each(function(element, index) {
7
- let $this = $(this);
8
- if (
9
- element.value.length > 0 ||
10
- $(element).is(':focus') ||
11
- element.autofocus ||
12
- $this.attr('placeholder') !== null
13
- ) {
14
- $this.siblings('label').addClass('active');
15
- } else if (element.validity) {
16
- $this.siblings('label').toggleClass('active', element.validity.badInput === true);
17
- } else {
18
- $this.siblings('label').removeClass('active');
19
- }
20
- });
21
- };
22
-
23
- M.validate_field = function(object) {
24
- let hasLength = object.attr('data-length') !== null;
25
- let lenAttr = parseInt(object.attr('data-length'));
26
- let len = object[0].value.length;
27
-
28
- if (len === 0 && object[0].validity.badInput === false && !object.is(':required')) {
29
- if (object.hasClass('validate')) {
30
- object.removeClass('valid');
31
- object.removeClass('invalid');
32
- }
33
- } else {
34
- if (object.hasClass('validate')) {
35
- // Check for character counter attributes
36
- if (
37
- (object.is(':valid') && hasLength && len <= lenAttr) ||
38
- (object.is(':valid') && !hasLength)
39
- ) {
40
- object.removeClass('invalid');
41
- object.addClass('valid');
42
- } else {
43
- object.removeClass('valid');
44
- object.addClass('invalid');
45
- }
46
- }
47
- }
48
- };
49
-
50
- M.textareaAutoResize = function($textarea) {
51
- // Wrap if native element
52
- if ($textarea instanceof Element) {
53
- $textarea = $($textarea);
54
- }
55
-
56
- if (!$textarea.length) {
57
- console.error('No textarea element found');
58
- return;
59
- }
60
-
61
- // Textarea Auto Resize
62
- let hiddenDiv = $('.hiddendiv').first();
63
- if (!hiddenDiv.length) {
64
- hiddenDiv = $('<div class="hiddendiv common"></div>');
65
- $('body').append(hiddenDiv);
66
- }
67
-
68
- // Set font properties of hiddenDiv
69
- let fontFamily = $textarea.css('font-family');
70
- let fontSize = $textarea.css('font-size');
71
- let lineHeight = $textarea.css('line-height');
72
-
73
- // Firefox can't handle padding shorthand.
74
- let paddingTop = $textarea.css('padding-top');
75
- let paddingRight = $textarea.css('padding-right');
76
- let paddingBottom = $textarea.css('padding-bottom');
77
- let paddingLeft = $textarea.css('padding-left');
78
-
79
- if (fontSize) {
80
- hiddenDiv.css('font-size', fontSize);
81
- }
82
- if (fontFamily) {
83
- hiddenDiv.css('font-family', fontFamily);
84
- }
85
- if (lineHeight) {
86
- hiddenDiv.css('line-height', lineHeight);
87
- }
88
- if (paddingTop) {
89
- hiddenDiv.css('padding-top', paddingTop);
90
- }
91
- if (paddingRight) {
92
- hiddenDiv.css('padding-right', paddingRight);
93
- }
94
- if (paddingBottom) {
95
- hiddenDiv.css('padding-bottom', paddingBottom);
96
- }
97
- if (paddingLeft) {
98
- hiddenDiv.css('padding-left', paddingLeft);
99
- }
100
-
101
- // Set original-height, if none
102
- if (!$textarea.data('original-height')) {
103
- $textarea.data('original-height', $textarea.height());
104
- }
105
-
106
- if ($textarea.attr('wrap') === 'off') {
107
- hiddenDiv.css('overflow-wrap', 'normal').css('white-space', 'pre');
108
- }
109
-
110
- hiddenDiv.text($textarea[0].value + '\n');
111
- let content = hiddenDiv.html().replace(/\n/g, '<br>');
112
- hiddenDiv.html(content);
113
-
114
- // When textarea is hidden, width goes crazy.
115
- // Approximate with half of window size
116
-
117
- if ($textarea[0].offsetWidth > 0 && $textarea[0].offsetHeight > 0) {
118
- hiddenDiv.css('width', $textarea.width() + 'px');
119
- } else {
120
- hiddenDiv.css('width', window.innerWidth / 2 + 'px');
121
- }
122
-
123
- /**
124
- * Resize if the new height is greater than the
125
- * original height of the textarea
126
- */
127
- if ($textarea.data('original-height') <= hiddenDiv.innerHeight()) {
128
- $textarea.css('height', hiddenDiv.innerHeight() + 'px');
129
- } else if ($textarea[0].value.length < $textarea.data('previous-length')) {
130
- /**
131
- * In case the new height is less than original height, it
132
- * means the textarea has less text than before
133
- * So we set the height to the original one
134
- */
135
- $textarea.css('height', $textarea.data('original-height') + 'px');
136
- }
137
- $textarea.data('previous-length', $textarea[0].value.length);
138
- };
139
-
140
- $(document).ready(function() {
141
- // Text based inputs
142
- let input_selector =
143
- 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
144
-
145
- // Add active if form auto complete
146
- $(document).on('change', input_selector, function() {
147
- if (this.value.length !== 0 || $(this).attr('placeholder') !== null) {
148
- $(this)
149
- .siblings('label')
150
- .addClass('active');
151
- }
152
- M.validate_field($(this));
153
- });
154
-
155
- // Add active if input element has been pre-populated on document ready
156
- $(document).ready(function() {
157
- M.updateTextFields();
158
- });
159
-
160
- // HTML DOM FORM RESET handling
161
- $(document).on('reset', function(e) {
162
- let formReset = $(e.target);
163
- if (formReset.is('form')) {
164
- formReset
165
- .find(input_selector)
166
- .removeClass('valid')
167
- .removeClass('invalid');
168
- formReset.find(input_selector).each(function(e) {
169
- if (this.value.length) {
170
- $(this)
171
- .siblings('label')
172
- .removeClass('active');
173
- }
174
- });
175
-
176
- // Reset select (after native reset)
177
- setTimeout(function() {
178
- formReset.find('select').each(function() {
179
- // check if initialized
180
- if (this.M_FormSelect) {
181
- $(this).trigger('change');
182
- }
183
- });
184
- }, 0);
185
- }
186
- });
187
-
188
- /**
189
- * Add active when element has focus
190
- * @param {Event} e
191
- */
192
- document.addEventListener(
193
- 'focus',
194
- function(e) {
195
- if ($(e.target).is(input_selector)) {
196
- $(e.target)
197
- .siblings('label, .prefix')
198
- .addClass('active');
199
- }
200
- },
201
- true
202
- );
203
-
204
- /**
205
- * Remove active when element is blurred
206
- * @param {Event} e
207
- */
208
- document.addEventListener(
209
- 'blur',
210
- function(e) {
211
- let $inputElement = $(e.target);
212
- if ($inputElement.is(input_selector)) {
213
- let selector = '.prefix';
214
-
215
- if (
216
- $inputElement[0].value.length === 0 &&
217
- $inputElement[0].validity.badInput !== true &&
218
- $inputElement.attr('placeholder') === null
219
- ) {
220
- selector += ', label';
221
- }
222
- $inputElement.siblings(selector).removeClass('active');
223
- M.validate_field($inputElement);
224
- }
225
- },
226
- true
227
- );
228
-
229
- // Radio and Checkbox focus class
230
- let radio_checkbox = 'input[type=radio], input[type=checkbox]';
231
- $(document).on('keyup', radio_checkbox, function(e) {
232
- // TAB, check if tabbing to radio or checkbox.
233
- if (e.which === M.keys.TAB) {
234
- $(this).addClass('tabbed');
235
- let $this = $(this);
236
- $this.one('blur', function(e) {
237
- $(this).removeClass('tabbed');
238
- });
239
- return;
240
- }
241
- });
242
-
243
- let text_area_selector = '.materialize-textarea';
244
- $(text_area_selector).each(function() {
245
- let $textarea = $(this);
246
- /**
247
- * Resize textarea on document load after storing
248
- * the original height and the original length
249
- */
250
- $textarea.data('original-height', $textarea.height());
251
- $textarea.data('previous-length', this.value.length);
252
- M.textareaAutoResize($textarea);
253
- });
254
-
255
- $(document).on('keyup', text_area_selector, function() {
256
- M.textareaAutoResize($(this));
257
- });
258
- $(document).on('keydown', text_area_selector, function() {
259
- M.textareaAutoResize($(this));
260
- });
261
-
262
- // File Input Path
263
- $(document).on('change', '.file-field input[type="file"]', function() {
264
- let file_field = $(this).closest('.file-field');
265
- let path_input = file_field.find('input.file-path');
266
- let files = $(this)[0].files;
267
- let file_names = [];
268
- for (let i = 0; i < files.length; i++) {
269
- file_names.push(files[i].name);
270
- }
271
- path_input[0].value = file_names.join(', ');
272
- path_input.trigger('change');
273
- });
274
- }); // End of $(document).ready
275
- })(cash);
1
+ (function($) {
2
+ // Function to update labels of text fields
3
+ M.updateTextFields = function() {
4
+ let input_selector =
5
+ 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
6
+ $(input_selector).each(function(element, index) {
7
+ let $this = $(this);
8
+ if (
9
+ element.value.length > 0 ||
10
+ $(element).is(':focus') ||
11
+ element.autofocus ||
12
+ $this.attr('placeholder') !== null
13
+ ) {
14
+ $this.siblings('label').addClass('active');
15
+ } else if (element.validity) {
16
+ $this.siblings('label').toggleClass('active', element.validity.badInput === true);
17
+ } else {
18
+ $this.siblings('label').removeClass('active');
19
+ }
20
+ });
21
+ };
22
+
23
+ M.validate_field = function(object) {
24
+ let hasLength = object.attr('data-length') !== null;
25
+ let lenAttr = parseInt(object.attr('data-length'));
26
+ let len = object[0].value.length;
27
+
28
+ if (len === 0 && object[0].validity.badInput === false && !object.is(':required')) {
29
+ if (object.hasClass('validate')) {
30
+ object.removeClass('valid');
31
+ object.removeClass('invalid');
32
+ }
33
+ } else {
34
+ if (object.hasClass('validate')) {
35
+ // Check for character counter attributes
36
+ if (
37
+ (object.is(':valid') && hasLength && len <= lenAttr) ||
38
+ (object.is(':valid') && !hasLength)
39
+ ) {
40
+ object.removeClass('invalid');
41
+ object.addClass('valid');
42
+ } else {
43
+ object.removeClass('valid');
44
+ object.addClass('invalid');
45
+ }
46
+ }
47
+ }
48
+ };
49
+
50
+ M.textareaAutoResize = function($textarea) {
51
+ // Wrap if native element
52
+ if ($textarea instanceof Element) {
53
+ $textarea = $($textarea);
54
+ }
55
+
56
+ if (!$textarea.length) {
57
+ console.error('No textarea element found');
58
+ return;
59
+ }
60
+
61
+ // Textarea Auto Resize
62
+ let hiddenDiv = $('.hiddendiv').first();
63
+ if (!hiddenDiv.length) {
64
+ hiddenDiv = $('<div class="hiddendiv common"></div>');
65
+ $('body').append(hiddenDiv);
66
+ }
67
+
68
+ // Set font properties of hiddenDiv
69
+ let fontFamily = $textarea.css('font-family');
70
+ let fontSize = $textarea.css('font-size');
71
+ let lineHeight = $textarea.css('line-height');
72
+
73
+ // Firefox can't handle padding shorthand.
74
+ let paddingTop = $textarea.css('padding-top');
75
+ let paddingRight = $textarea.css('padding-right');
76
+ let paddingBottom = $textarea.css('padding-bottom');
77
+ let paddingLeft = $textarea.css('padding-left');
78
+
79
+ if (fontSize) {
80
+ hiddenDiv.css('font-size', fontSize);
81
+ }
82
+ if (fontFamily) {
83
+ hiddenDiv.css('font-family', fontFamily);
84
+ }
85
+ if (lineHeight) {
86
+ hiddenDiv.css('line-height', lineHeight);
87
+ }
88
+ if (paddingTop) {
89
+ hiddenDiv.css('padding-top', paddingTop);
90
+ }
91
+ if (paddingRight) {
92
+ hiddenDiv.css('padding-right', paddingRight);
93
+ }
94
+ if (paddingBottom) {
95
+ hiddenDiv.css('padding-bottom', paddingBottom);
96
+ }
97
+ if (paddingLeft) {
98
+ hiddenDiv.css('padding-left', paddingLeft);
99
+ }
100
+
101
+ // Set original-height, if none
102
+ if (!$textarea.data('original-height')) {
103
+ $textarea.data('original-height', $textarea.height());
104
+ }
105
+
106
+ if ($textarea.attr('wrap') === 'off') {
107
+ hiddenDiv.css('overflow-wrap', 'normal').css('white-space', 'pre');
108
+ }
109
+
110
+ hiddenDiv.text($textarea[0].value + '\n');
111
+ let content = hiddenDiv.html().replace(/\n/g, '<br>');
112
+ hiddenDiv.html(content);
113
+
114
+ // When textarea is hidden, width goes crazy.
115
+ // Approximate with half of window size
116
+
117
+ if ($textarea[0].offsetWidth > 0 && $textarea[0].offsetHeight > 0) {
118
+ hiddenDiv.css('width', $textarea.width() + 'px');
119
+ } else {
120
+ hiddenDiv.css('width', window.innerWidth / 2 + 'px');
121
+ }
122
+
123
+ /**
124
+ * Resize if the new height is greater than the
125
+ * original height of the textarea
126
+ */
127
+ if ($textarea.data('original-height') <= hiddenDiv.innerHeight()) {
128
+ $textarea.css('height', hiddenDiv.innerHeight() + 'px');
129
+ } else if ($textarea[0].value.length < $textarea.data('previous-length')) {
130
+ /**
131
+ * In case the new height is less than original height, it
132
+ * means the textarea has less text than before
133
+ * So we set the height to the original one
134
+ */
135
+ $textarea.css('height', $textarea.data('original-height') + 'px');
136
+ }
137
+ $textarea.data('previous-length', $textarea[0].value.length);
138
+ };
139
+
140
+ $(document).ready(function() {
141
+ // Text based inputs
142
+ let input_selector =
143
+ 'input[type=text], input[type=password], input[type=email], input[type=url], input[type=tel], input[type=number], input[type=search], input[type=date], input[type=time], textarea';
144
+
145
+ // Add active if form auto complete
146
+ $(document).on('change', input_selector, function() {
147
+ if (this.value.length !== 0 || $(this).attr('placeholder') !== null) {
148
+ $(this)
149
+ .siblings('label')
150
+ .addClass('active');
151
+ }
152
+ M.validate_field($(this));
153
+ });
154
+
155
+ // Add active if input element has been pre-populated on document ready
156
+ $(document).ready(function() {
157
+ M.updateTextFields();
158
+ });
159
+
160
+ // HTML DOM FORM RESET handling
161
+ $(document).on('reset', function(e) {
162
+ let formReset = $(e.target);
163
+ if (formReset.is('form')) {
164
+ formReset
165
+ .find(input_selector)
166
+ .removeClass('valid')
167
+ .removeClass('invalid');
168
+ formReset.find(input_selector).each(function(e) {
169
+ if (this.value.length) {
170
+ $(this)
171
+ .siblings('label')
172
+ .removeClass('active');
173
+ }
174
+ });
175
+
176
+ // Reset select (after native reset)
177
+ setTimeout(function() {
178
+ formReset.find('select').each(function() {
179
+ // check if initialized
180
+ if (this.M_FormSelect) {
181
+ $(this).trigger('change');
182
+ }
183
+ });
184
+ }, 0);
185
+ }
186
+ });
187
+
188
+ /**
189
+ * Add active when element has focus
190
+ * @param {Event} e
191
+ */
192
+ document.addEventListener(
193
+ 'focus',
194
+ function(e) {
195
+ if ($(e.target).is(input_selector)) {
196
+ $(e.target)
197
+ .siblings('label, .prefix')
198
+ .addClass('active');
199
+ }
200
+ },
201
+ true
202
+ );
203
+
204
+ /**
205
+ * Remove active when element is blurred
206
+ * @param {Event} e
207
+ */
208
+ document.addEventListener(
209
+ 'blur',
210
+ function(e) {
211
+ let $inputElement = $(e.target);
212
+ if ($inputElement.is(input_selector)) {
213
+ let selector = '.prefix';
214
+
215
+ if (
216
+ $inputElement[0].value.length === 0 &&
217
+ $inputElement[0].validity.badInput !== true &&
218
+ $inputElement.attr('placeholder') === null
219
+ ) {
220
+ selector += ', label';
221
+ }
222
+ $inputElement.siblings(selector).removeClass('active');
223
+ M.validate_field($inputElement);
224
+ }
225
+ },
226
+ true
227
+ );
228
+
229
+ // Radio and Checkbox focus class
230
+ let radio_checkbox = 'input[type=radio], input[type=checkbox]';
231
+ $(document).on('keyup', radio_checkbox, function(e) {
232
+ // TAB, check if tabbing to radio or checkbox.
233
+ if (e.which === M.keys.TAB) {
234
+ $(this).addClass('tabbed');
235
+ let $this = $(this);
236
+ $this.one('blur', function(e) {
237
+ $(this).removeClass('tabbed');
238
+ });
239
+ return;
240
+ }
241
+ });
242
+
243
+ let text_area_selector = '.materialize-textarea';
244
+ $(text_area_selector).each(function() {
245
+ let $textarea = $(this);
246
+ /**
247
+ * Resize textarea on document load after storing
248
+ * the original height and the original length
249
+ */
250
+ $textarea.data('original-height', $textarea.height());
251
+ $textarea.data('previous-length', this.value.length);
252
+ M.textareaAutoResize($textarea);
253
+ });
254
+
255
+ $(document).on('keyup', text_area_selector, function() {
256
+ M.textareaAutoResize($(this));
257
+ });
258
+ $(document).on('keydown', text_area_selector, function() {
259
+ M.textareaAutoResize($(this));
260
+ });
261
+
262
+ // File Input Path
263
+ $(document).on('change', '.file-field input[type="file"]', function() {
264
+ let file_field = $(this).closest('.file-field');
265
+ let path_input = file_field.find('input.file-path');
266
+ let files = $(this)[0].files;
267
+ let file_names = [];
268
+ for (let i = 0; i < files.length; i++) {
269
+ file_names.push(files[i].name);
270
+ }
271
+ path_input[0].value = file_names.join(', ');
272
+ path_input.trigger('change');
273
+ });
274
+ }); // End of $(document).ready
275
+ })(cash);