uikit 3.14.3 → 3.14.4-dev.6a00f7fe6

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 (84) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/css/uikit-core-rtl.css +84 -26
  3. package/dist/css/uikit-core-rtl.min.css +1 -1
  4. package/dist/css/uikit-core.css +84 -26
  5. package/dist/css/uikit-core.min.css +1 -1
  6. package/dist/css/uikit-rtl.css +90 -41
  7. package/dist/css/uikit-rtl.min.css +1 -1
  8. package/dist/css/uikit.css +90 -41
  9. package/dist/css/uikit.min.css +1 -1
  10. package/dist/js/components/countdown.js +1 -1
  11. package/dist/js/components/countdown.min.js +1 -1
  12. package/dist/js/components/filter.js +1 -1
  13. package/dist/js/components/filter.min.js +1 -1
  14. package/dist/js/components/lightbox-panel.js +101 -22
  15. package/dist/js/components/lightbox-panel.min.js +1 -1
  16. package/dist/js/components/lightbox.js +101 -22
  17. package/dist/js/components/lightbox.min.js +1 -1
  18. package/dist/js/components/notification.js +1 -1
  19. package/dist/js/components/notification.min.js +1 -1
  20. package/dist/js/components/parallax.js +1 -1
  21. package/dist/js/components/parallax.min.js +1 -1
  22. package/dist/js/components/slider-parallax.js +1 -1
  23. package/dist/js/components/slider-parallax.min.js +1 -1
  24. package/dist/js/components/slider.js +1 -1
  25. package/dist/js/components/slider.min.js +1 -1
  26. package/dist/js/components/slideshow-parallax.js +1 -1
  27. package/dist/js/components/slideshow-parallax.min.js +1 -1
  28. package/dist/js/components/slideshow.js +1 -1
  29. package/dist/js/components/slideshow.min.js +1 -1
  30. package/dist/js/components/sortable.js +1 -1
  31. package/dist/js/components/sortable.min.js +1 -1
  32. package/dist/js/components/tooltip.js +135 -34
  33. package/dist/js/components/tooltip.min.js +1 -1
  34. package/dist/js/components/upload.js +1 -1
  35. package/dist/js/components/upload.min.js +1 -1
  36. package/dist/js/uikit-core.js +206 -77
  37. package/dist/js/uikit-core.min.js +1 -1
  38. package/dist/js/uikit-icons.js +1 -1
  39. package/dist/js/uikit-icons.min.js +1 -1
  40. package/dist/js/uikit.js +206 -77
  41. package/dist/js/uikit.min.js +1 -1
  42. package/package.json +1 -1
  43. package/src/js/core/accordion.js +3 -3
  44. package/src/js/core/alert.js +1 -1
  45. package/src/js/core/drop.js +40 -20
  46. package/src/js/core/height-viewport.js +14 -9
  47. package/src/js/core/navbar.js +11 -9
  48. package/src/js/core/switcher.js +1 -1
  49. package/src/js/mixin/position.js +44 -13
  50. package/src/js/mixin/togglable.js +105 -24
  51. package/src/js/util/animation.js +1 -0
  52. package/src/js/util/viewport.js +1 -1
  53. package/src/less/components/drop.less +19 -5
  54. package/src/less/components/dropdown.less +21 -5
  55. package/src/less/components/margin.less +13 -14
  56. package/src/less/components/modal.less +19 -4
  57. package/src/less/components/nav.less +1 -1
  58. package/src/less/components/navbar.less +54 -21
  59. package/src/less/components/offcanvas.less +21 -21
  60. package/src/less/components/position.less +1 -1
  61. package/src/less/components/utility.less +0 -1
  62. package/src/less/theme/dropdown.less +11 -0
  63. package/src/less/theme/navbar.less +10 -12
  64. package/src/scss/components/drop.scss +19 -5
  65. package/src/scss/components/dropdown.scss +21 -5
  66. package/src/scss/components/margin.scss +13 -14
  67. package/src/scss/components/modal.scss +19 -4
  68. package/src/scss/components/nav.scss +1 -1
  69. package/src/scss/components/navbar.scss +43 -10
  70. package/src/scss/components/offcanvas.scss +21 -21
  71. package/src/scss/components/position.scss +1 -1
  72. package/src/scss/components/utility.scss +0 -1
  73. package/src/scss/mixins-theme.scss +8 -12
  74. package/src/scss/mixins.scss +2 -0
  75. package/src/scss/theme/dropdown.scss +8 -0
  76. package/src/scss/theme/navbar.scss +7 -0
  77. package/src/scss/variables-theme.scss +26 -11
  78. package/src/scss/variables.scss +24 -11
  79. package/tests/drop.html +145 -2
  80. package/tests/dropdown.html +228 -13
  81. package/tests/height-viewport.html +62 -0
  82. package/tests/navbar.html +321 -14
  83. package/tests/offcanvas.html +8 -8
  84. package/tests/sticky-navbar.html +132 -0
@@ -3,10 +3,7 @@
3
3
  //
4
4
  // Component: `uk-drop`
5
5
  //
6
- // Modifiers: `uk-drop-top-*`
7
- // `uk-drop-bottom-*`
8
- // `uk-drop-left-*`
9
- // `uk-drop-right-*`
6
+ // Modifiers: `uk-drop-stretch`
10
7
  // `uk-drop-stack`
11
8
  // `uk-drop-grid`
12
9
  //
@@ -22,6 +19,7 @@
22
19
 
23
20
  @drop-z-index: @global-z-index + 20;
24
21
  @drop-margin: @global-margin;
22
+ @drop-viewport-margin: 15px;
25
23
  @drop-width: 300px;
26
24
 
27
25
 
@@ -42,7 +40,7 @@
42
40
  position: absolute;
43
41
  z-index: @drop-z-index;
44
42
  --uk-position-offset: @drop-margin;
45
- --uk-position-viewport-offset: 10;
43
+ --uk-position-viewport-offset: @drop-viewport-margin;
46
44
  /* 3 */
47
45
  box-sizing: border-box;
48
46
  width: @drop-width;
@@ -52,6 +50,22 @@
52
50
  .uk-drop.uk-open { display: block; }
53
51
 
54
52
 
53
+ /* Stretch modifier
54
+ ========================================================================== */
55
+
56
+ /*
57
+ * 1. Allow scrolling
58
+ */
59
+
60
+ .uk-drop-stretch {
61
+ --uk-position-offset: 0;
62
+ --uk-position-viewport-offset: 0;
63
+ /* 1 */
64
+ overflow-y: auto;
65
+ -webkit-overflow-scrolling: touch;
66
+ }
67
+
68
+
55
69
  /* Grid modifiers
56
70
  ========================================================================== */
57
71
 
@@ -5,10 +5,7 @@
5
5
  //
6
6
  // Adopted: `uk-dropdown-nav`
7
7
  //
8
- // Modifiers: `uk-dropdown-top-*`
9
- // `uk-dropdown-bottom-*`
10
- // `uk-dropdown-left-*`
11
- // `uk-dropdown-right-*`
8
+ // Modifiers: `uk-dropdown-stretch`
12
9
  // `uk-dropdown-stack`
13
10
  // `uk-dropdown-grid`
14
11
  //
@@ -22,6 +19,7 @@
22
19
 
23
20
  @dropdown-z-index: @global-z-index + 20;
24
21
  @dropdown-margin: @global-small-margin;
22
+ @dropdown-viewport-margin: 15px;
25
23
  @dropdown-min-width: 200px;
26
24
  @dropdown-padding: 15px;
27
25
  @dropdown-background: @global-muted-background;
@@ -55,7 +53,7 @@
55
53
  position: absolute;
56
54
  z-index: @dropdown-z-index;
57
55
  --uk-position-offset: @dropdown-margin;
58
- --uk-position-viewport-offset: 10;
56
+ --uk-position-viewport-offset: @dropdown-viewport-margin;
59
57
  /* 3 */
60
58
  box-sizing: border-box;
61
59
  min-width: @dropdown-min-width;
@@ -71,6 +69,23 @@
71
69
  .uk-dropdown.uk-open { display: block; }
72
70
 
73
71
 
72
+ /* Stretch modifier
73
+ ========================================================================== */
74
+
75
+ /*
76
+ * 1. Allow scrolling
77
+ */
78
+
79
+ .uk-dropdown-stretch {
80
+ --uk-position-offset: 0;
81
+ --uk-position-viewport-offset: 0;
82
+ /* 1 */
83
+ overflow-y: auto;
84
+ -webkit-overflow-scrolling: touch;
85
+ .hook-dropdown-stretch();
86
+ }
87
+
88
+
74
89
  /* Nav
75
90
  * Adopts `uk-nav`
76
91
  ========================================================================== */
@@ -145,6 +160,7 @@
145
160
  .hook-dropdown-misc();
146
161
 
147
162
  .hook-dropdown() {}
163
+ .hook-dropdown-stretch() {}
148
164
  .hook-dropdown-nav() {}
149
165
  .hook-dropdown-nav-item() {}
150
166
  .hook-dropdown-nav-item-hover() {}
@@ -193,20 +193,20 @@
193
193
  /* Remove
194
194
  ========================================================================== */
195
195
 
196
- .uk-margin-remove { margin: 0 !important; }
197
- .uk-margin-remove-top { margin-top: 0 !important; }
198
- .uk-margin-remove-bottom { margin-bottom: 0 !important; }
199
- .uk-margin-remove-left { margin-left: 0 !important; }
200
- .uk-margin-remove-right { margin-right: 0 !important; }
201
-
202
- .uk-margin-remove-vertical {
203
- margin-top: 0 !important;
204
- margin-bottom: 0 !important;
205
- }
196
+ .uk-margin-remove { margin: 0 !important; }
197
+ .uk-margin-remove-top { margin-top: 0 !important; }
198
+ .uk-margin-remove-bottom { margin-bottom: 0 !important; }
199
+ .uk-margin-remove-left { margin-left: 0 !important; }
200
+ .uk-margin-remove-right { margin-right: 0 !important; }
201
+
202
+ .uk-margin-remove-vertical {
203
+ margin-top: 0 !important;
204
+ margin-bottom: 0 !important;
205
+ }
206
206
 
207
- .uk-margin-remove-adjacent + *,
208
- .uk-margin-remove-first-child > :first-child { margin-top: 0 !important; }
209
- .uk-margin-remove-last-child > :last-child { margin-bottom: 0 !important; }
207
+ .uk-margin-remove-adjacent + *,
208
+ .uk-margin-remove-first-child > :first-child { margin-top: 0 !important; }
209
+ .uk-margin-remove-last-child > :last-child { margin-bottom: 0 !important; }
210
210
 
211
211
  /* Phone landscape and bigger */
212
212
  @media (min-width: @breakpoint-small) {
@@ -241,7 +241,6 @@
241
241
  }
242
242
 
243
243
 
244
-
245
244
  // Hooks
246
245
  // ========================================================================
247
246
 
@@ -40,15 +40,21 @@
40
40
 
41
41
  @modal-container-width: 1200px;
42
42
 
43
- @modal-body-padding-horizontal: @global-gutter;
44
- @modal-body-padding-vertical: @global-gutter;
43
+ @modal-body-padding-horizontal: 20px;
44
+ @modal-body-padding-vertical: 20px;
45
+ @modal-body-padding-horizontal-s: @global-gutter;
46
+ @modal-body-padding-vertical-s: @global-gutter;
45
47
 
46
- @modal-header-padding-horizontal: @global-gutter;
48
+ @modal-header-padding-horizontal: 20px;
47
49
  @modal-header-padding-vertical: (@modal-header-padding-horizontal / 2);
50
+ @modal-header-padding-horizontal-s: @global-gutter;
51
+ @modal-header-padding-vertical-s: (@modal-header-padding-horizontal-s / 2);
48
52
  @modal-header-background: @global-muted-background;
49
53
 
50
- @modal-footer-padding-horizontal: @global-gutter;
54
+ @modal-footer-padding-horizontal: 20px;
51
55
  @modal-footer-padding-vertical: (@modal-footer-padding-horizontal / 2);
56
+ @modal-footer-padding-horizontal-s: @global-gutter;
57
+ @modal-footer-padding-vertical-s: (@modal-footer-padding-horizontal-s / 2);
52
58
  @modal-footer-background: @global-muted-background;
53
59
 
54
60
  @modal-title-font-size: @global-xlarge-font-size;
@@ -228,6 +234,15 @@
228
234
  .hook-modal-footer();
229
235
  }
230
236
 
237
+ /* Phone landscape and bigger */
238
+ @media (min-width: @breakpoint-small) {
239
+
240
+ .uk-modal-body { padding: @modal-body-padding-vertical-s @modal-body-padding-horizontal-s; }
241
+ .uk-modal-header { padding: @modal-header-padding-vertical-s @modal-header-padding-horizontal-s; }
242
+ .uk-modal-footer { padding: @modal-footer-padding-vertical-s @modal-footer-padding-horizontal-s; }
243
+
244
+ }
245
+
231
246
  /*
232
247
  * Remove margin from the last-child
233
248
  */
@@ -282,7 +282,7 @@ ul.uk-nav-sub {
282
282
  * Subtitle
283
283
  */
284
284
 
285
- .uk-nav-primary .uk-nav-subtitle {
285
+ .uk-nav-primary .uk-nav-subtitle {
286
286
  font-size: @nav-primary-subtitle-font-size;
287
287
  .hook-nav-primary-subtitle();
288
288
  }
@@ -40,6 +40,7 @@
40
40
  @navbar-color-mode: none;
41
41
 
42
42
  @navbar-nav-item-height: 80px;
43
+ @navbar-nav-item-gap: 0px; // Must have a unit because of `calc`
43
44
  @navbar-nav-item-padding-horizontal: 15px;
44
45
  @navbar-nav-item-color: @global-muted-color;
45
46
  @navbar-nav-item-font-size: @global-font-size;
@@ -48,6 +49,7 @@
48
49
  @navbar-nav-item-onclick-color: @global-emphasis-color;
49
50
  @navbar-nav-item-active-color: @global-emphasis-color;
50
51
 
52
+ @navbar-item-padding-horizontal: @navbar-nav-item-padding-horizontal;
51
53
  @navbar-item-color: @global-color;
52
54
 
53
55
  @navbar-toggle-color: @global-muted-color;
@@ -56,11 +58,14 @@
56
58
  @navbar-subtitle-font-size: @global-small-font-size;
57
59
 
58
60
  @navbar-dropdown-z-index: @global-z-index + 20;
59
- @navbar-dropdown-margin: 0px;
61
+ @navbar-dropdown-margin: 0;
62
+ @navbar-dropdown-shift-margin: 0;
63
+ @navbar-dropdown-viewport-margin: 15px;
60
64
  @navbar-dropdown-width: 200px;
61
65
  @navbar-dropdown-padding: 15px;
62
66
  @navbar-dropdown-background: @global-muted-background;
63
67
  @navbar-dropdown-color: @global-color;
68
+ @navbar-dropdown-color-mode: none;
64
69
  @navbar-dropdown-grid-gutter-horizontal: @global-gutter;
65
70
  @navbar-dropdown-grid-gutter-vertical: @navbar-dropdown-grid-gutter-horizontal;
66
71
 
@@ -93,6 +98,7 @@
93
98
 
94
99
  .uk-navbar {
95
100
  display: flex;
101
+ --uk-navbar-nav-item-gap: @navbar-nav-item-gap;
96
102
  /* 1 */
97
103
  position: relative;
98
104
  .hook-navbar();
@@ -127,6 +133,7 @@
127
133
  .uk-navbar-center-left > *,
128
134
  .uk-navbar-center-right > * {
129
135
  display: flex;
136
+ gap: var(--uk-navbar-nav-item-gap);
130
137
  /* 1 */
131
138
  align-items: center;
132
139
  }
@@ -168,8 +175,8 @@
168
175
  top: 0;
169
176
  }
170
177
 
171
- .uk-navbar-center-left { right: 100%; }
172
- .uk-navbar-center-right { left: 100%; }
178
+ .uk-navbar-center-left { right: ~'calc(100% + var(--uk-navbar-nav-item-gap))'; }
179
+ .uk-navbar-center-right { left: ~'calc(100% + var(--uk-navbar-nav-item-gap))'; }
173
180
 
174
181
  [class*='uk-navbar-center-'] {
175
182
  width: max-content;
@@ -186,6 +193,7 @@
186
193
 
187
194
  .uk-navbar-nav {
188
195
  display: flex;
196
+ gap: var(--uk-navbar-nav-item-gap);
189
197
  /* 1 */
190
198
  margin: 0;
191
199
  padding: 0;
@@ -267,6 +275,7 @@
267
275
  ========================================================================== */
268
276
 
269
277
  .uk-navbar-item {
278
+ padding: 0 @navbar-item-padding-horizontal;
270
279
  color: @navbar-item-color;
271
280
  .hook-navbar-item();
272
281
  }
@@ -362,7 +371,8 @@
362
371
  position: absolute;
363
372
  z-index: @navbar-dropdown-z-index;
364
373
  --uk-position-offset: @navbar-dropdown-margin;
365
- --uk-position-viewport-offset: 10;
374
+ --uk-position-shift-offset: @navbar-dropdown-shift-margin;
375
+ --uk-position-viewport-offset: @navbar-dropdown-viewport-margin;
366
376
  /* 3 */
367
377
  box-sizing: border-box;
368
378
  width: @navbar-dropdown-width;
@@ -377,6 +387,10 @@
377
387
  /* Show */
378
388
  .uk-navbar-dropdown.uk-open { display: block; }
379
389
 
390
+
391
+ .uk-navbar-dropdown:extend(.uk-light all) when (@navbar-dropdown-color-mode = light) {}
392
+ .uk-navbar-dropdown:extend(.uk-dark all) when (@navbar-dropdown-color-mode = dark) {}
393
+
380
394
  /*
381
395
  * Grid
382
396
  * Adopts `uk-grid`
@@ -401,22 +415,40 @@
401
415
  .uk-navbar-dropdown-width-4:not(.uk-navbar-dropdown-stack) { width: (@navbar-dropdown-width * 4); }
402
416
  .uk-navbar-dropdown-width-5:not(.uk-navbar-dropdown-stack) { width: (@navbar-dropdown-width * 5); }
403
417
 
418
+ /*
419
+ * Stretch modifier
420
+ * 1. Allow scrolling
421
+ */
422
+
423
+ .uk-navbar-dropdown-stretch {
424
+ --uk-position-offset: 0;
425
+ --uk-position-shift-offset: 0;
426
+ --uk-position-viewport-offset: 0;
427
+ /* 1 */
428
+ overflow-y: auto;
429
+ -webkit-overflow-scrolling: touch;
430
+ .hook-navbar-dropdown-stretch();
431
+ }
432
+
404
433
  /*
405
434
  * Dropbar modifier
406
- * 1. Set position
407
- * 2. Bottom padding for dropbar
408
- * 3. Horizontal padding
435
+ * 1. Reset dropdown width to prevent to early shifting
436
+ * 2. Set position
437
+ * 3. Bottom padding for dropbar
438
+ * 4. Horizontal padding
409
439
  */
410
440
 
411
441
  .uk-navbar-dropdown-dropbar {
412
442
  /* 1 */
413
- --uk-position-offset: @navbar-dropdown-dropbar-margin-top;
414
- --uk-position-viewport-offset: 0;
443
+ width: auto;
415
444
  /* 2 */
416
- margin-bottom: @navbar-dropdown-dropbar-margin-bottom;
445
+ --uk-position-offset: @navbar-dropdown-dropbar-margin-top;
417
446
  /* 3 */
447
+ margin-bottom: @navbar-dropdown-dropbar-margin-bottom;
448
+ /* 4 */
418
449
  padding-left: @navbar-dropdown-dropbar-padding-horizontal;
419
450
  padding-right: @navbar-dropdown-dropbar-padding-horizontal;
451
+ --uk-position-shift-offset: 0;
420
452
  .hook-navbar-dropdown-dropbar();
421
453
  }
422
454
 
@@ -513,24 +545,25 @@
513
545
  .hook-navbar-nav-item-onclick() {}
514
546
  .hook-navbar-nav-item-active() {}
515
547
  .hook-navbar-item() {}
516
- .hook-navbar-toggle(){}
517
- .hook-navbar-toggle-hover(){}
518
- .hook-navbar-toggle-icon(){}
519
- .hook-navbar-toggle-icon-hover(){}
548
+ .hook-navbar-toggle() {}
549
+ .hook-navbar-toggle-hover() {}
550
+ .hook-navbar-toggle-icon() {}
551
+ .hook-navbar-toggle-icon-hover() {}
520
552
  .hook-navbar-subtitle() {}
521
- .hook-navbar-primary(){}
522
- .hook-navbar-transparent(){}
523
- .hook-navbar-sticky(){}
524
- .hook-navbar-dropdown(){}
525
- .hook-navbar-dropdown-dropbar(){}
526
- .hook-navbar-dropdown-nav(){}
553
+ .hook-navbar-primary() {}
554
+ .hook-navbar-transparent() {}
555
+ .hook-navbar-sticky() {}
556
+ .hook-navbar-dropdown() {}
557
+ .hook-navbar-dropdown-stretch() {}
558
+ .hook-navbar-dropdown-dropbar() {}
559
+ .hook-navbar-dropdown-nav() {}
527
560
  .hook-navbar-dropdown-nav-item() {}
528
561
  .hook-navbar-dropdown-nav-item-hover() {}
529
562
  .hook-navbar-dropdown-nav-item-active() {}
530
563
  .hook-navbar-dropdown-nav-subtitle() {}
531
564
  .hook-navbar-dropdown-nav-header() {}
532
565
  .hook-navbar-dropdown-nav-divider() {}
533
- .hook-navbar-dropbar(){}
566
+ .hook-navbar-dropbar() {}
534
567
  .hook-navbar-misc() {}
535
568
 
536
569
 
@@ -26,19 +26,19 @@
26
26
  @offcanvas-z-index: @global-z-index;
27
27
 
28
28
  @offcanvas-bar-width: 270px;
29
- @offcanvas-bar-padding-vertical: @global-margin;
30
- @offcanvas-bar-padding-horizontal: @global-margin;
29
+ @offcanvas-bar-padding-vertical: 20px;
30
+ @offcanvas-bar-padding-horizontal: 20px;
31
31
  @offcanvas-bar-background: @global-secondary-background;
32
32
  @offcanvas-bar-color-mode: light;
33
33
 
34
- @offcanvas-bar-width-m: 350px;
35
- @offcanvas-bar-padding-vertical-m: @global-medium-gutter;
36
- @offcanvas-bar-padding-horizontal-m: @global-medium-gutter;
34
+ @offcanvas-bar-width-s: 350px;
35
+ @offcanvas-bar-padding-vertical-s: @global-gutter;
36
+ @offcanvas-bar-padding-horizontal-s: @global-gutter;
37
37
 
38
38
  @offcanvas-close-position: 5px;
39
39
  @offcanvas-close-padding: 5px;
40
40
 
41
- @offcanvas-close-position-m: 20px;
41
+ @offcanvas-close-position-s: 10px;
42
42
 
43
43
  @offcanvas-overlay-background: rgba(0,0,0,0.1);
44
44
 
@@ -99,13 +99,13 @@
99
99
  .hook-offcanvas-bar();
100
100
  }
101
101
 
102
- /* Tablet landscape and bigger */
103
- @media (min-width: @breakpoint-medium) {
102
+ /* Phone landscape and bigger */
103
+ @media (min-width: @breakpoint-small) {
104
104
 
105
105
  .uk-offcanvas-bar {
106
- left: -@offcanvas-bar-width-m;
107
- width: @offcanvas-bar-width-m;
108
- padding: @offcanvas-bar-padding-vertical-m @offcanvas-bar-padding-horizontal-m;
106
+ left: -@offcanvas-bar-width-s;
107
+ width: @offcanvas-bar-width-s;
108
+ padding: @offcanvas-bar-padding-vertical-s @offcanvas-bar-padding-horizontal-s;
109
109
  }
110
110
 
111
111
  }
@@ -121,9 +121,9 @@
121
121
  }
122
122
 
123
123
  /* Tablet landscape and bigger */
124
- @media (min-width: @breakpoint-medium) {
124
+ @media (min-width: @breakpoint-small) {
125
125
 
126
- .uk-offcanvas-flip .uk-offcanvas-bar { right: -@offcanvas-bar-width-m; }
126
+ .uk-offcanvas-flip .uk-offcanvas-bar { right: -@offcanvas-bar-width-s; }
127
127
 
128
128
  }
129
129
 
@@ -179,9 +179,9 @@
179
179
  .uk-open > .uk-offcanvas-reveal { width: @offcanvas-bar-width; }
180
180
 
181
181
  /* Tablet landscape and bigger */
182
- @media (min-width: @breakpoint-medium) {
182
+ @media (min-width: @breakpoint-small) {
183
183
 
184
- .uk-open > .uk-offcanvas-reveal { width: @offcanvas-bar-width-m; }
184
+ .uk-open > .uk-offcanvas-reveal { width: @offcanvas-bar-width-s; }
185
185
 
186
186
  }
187
187
 
@@ -209,11 +209,11 @@
209
209
  }
210
210
 
211
211
  /* Tablet landscape and bigger */
212
- @media (min-width: @breakpoint-medium) {
212
+ @media (min-width: @breakpoint-small) {
213
213
 
214
214
  .uk-offcanvas-close {
215
- top: @offcanvas-close-position-m;
216
- right: @offcanvas-close-position-m;
215
+ top: @offcanvas-close-position-s;
216
+ right: @offcanvas-close-position-s;
217
217
  }
218
218
 
219
219
  }
@@ -304,11 +304,11 @@
304
304
  .uk-offcanvas-flip.uk-offcanvas-container-animation { left: -@offcanvas-bar-width; }
305
305
 
306
306
  /* Tablet landscape and bigger */
307
- @media (min-width: @breakpoint-medium) {
307
+ @media (min-width: @breakpoint-small) {
308
308
 
309
- :not(.uk-offcanvas-flip).uk-offcanvas-container-animation { left: @offcanvas-bar-width-m; }
309
+ :not(.uk-offcanvas-flip).uk-offcanvas-container-animation { left: @offcanvas-bar-width-s; }
310
310
 
311
- .uk-offcanvas-flip.uk-offcanvas-container-animation { left: -@offcanvas-bar-width-m; }
311
+ .uk-offcanvas-flip.uk-offcanvas-container-animation { left: -@offcanvas-bar-width-s; }
312
312
 
313
313
  }
314
314
 
@@ -218,7 +218,7 @@
218
218
  ========================================================================== */
219
219
 
220
220
  .uk-position-z-index { z-index: 1; }
221
-
221
+ .uk-position-z-index-zero { z-index: 0; }
222
222
  .uk-position-z-index-negative { z-index: -1; }
223
223
 
224
224
 
@@ -137,7 +137,6 @@
137
137
 
138
138
  /*
139
139
  * Enable scrollbars if content is clipped
140
- * Note: Firefox ignores `padding-bottom` for the scrollable overflow https://bugzilla.mozilla.org/show_bug.cgi?id=748518
141
140
  */
142
141
 
143
142
  .uk-overflow-auto {
@@ -20,6 +20,8 @@
20
20
 
21
21
  @dropdown-box-shadow: 0 5px 12px rgba(0,0,0,0.15);
22
22
 
23
+ @dropdown-stretch-background: @global-muted-background;
24
+
23
25
 
24
26
  // Component
25
27
  // ========================================================================
@@ -27,6 +29,15 @@
27
29
  .hook-dropdown() { box-shadow: @dropdown-box-shadow; }
28
30
 
29
31
 
32
+ // Stretch modifier
33
+ // ========================================================================
34
+
35
+ .hook-dropdown-stretch() {
36
+ box-shadow: none;
37
+ background: @dropdown-stretch-background;
38
+ }
39
+
40
+
30
41
  // Nav
31
42
  // ========================================================================
32
43
 
@@ -7,6 +7,9 @@
7
7
  // Variables
8
8
  // ========================================================================
9
9
 
10
+ @navbar-nav-item-gap: 30px;
11
+ @navbar-nav-item-padding-horizontal: 0;
12
+
10
13
  @navbar-nav-item-font-size: @global-small-font-size;
11
14
 
12
15
  @navbar-dropdown-margin: 15px;
@@ -26,6 +29,8 @@
26
29
 
27
30
  @navbar-dropdown-box-shadow: 0 5px 12px rgba(0,0,0,0.15);
28
31
 
32
+ @navbar-dropdown-stretch-background: @global-muted-background;
33
+
29
34
  @navbar-dropbar-box-shadow: 0 5px 7px rgba(0, 0, 0, 0.05);
30
35
 
31
36
  @navbar-dropdown-grid-divider-border-width: @global-border-width;
@@ -99,6 +104,11 @@
99
104
 
100
105
  .hook-navbar-dropdown() { box-shadow: @navbar-dropdown-box-shadow; }
101
106
 
107
+ .hook-navbar-dropdown-stretch() {
108
+ box-shadow: none;
109
+ background: @navbar-dropdown-stretch-background;
110
+ }
111
+
102
112
  .hook-navbar-dropdown-dropbar() { box-shadow: none; }
103
113
 
104
114
 
@@ -129,18 +139,6 @@
129
139
 
130
140
  .hook-navbar-misc() {
131
141
 
132
- /*
133
- * Navbar
134
- */
135
-
136
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-left .uk-navbar-nav:first-child,
137
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-left .uk-navbar-item:first-child,
138
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-left .uk-navbar-toggle:first-child { margin-left: -@navbar-nav-item-padding-horizontal; }
139
-
140
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-right .uk-navbar-nav:last-child,
141
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-right .uk-navbar-item:last-child,
142
- .uk-container > :not(.uk-navbar-justified) > .uk-navbar-right .uk-navbar-toggle:last-child { margin-right: -@navbar-nav-item-padding-horizontal; }
143
-
144
142
  /*
145
143
  * Grid Divider
146
144
  */
@@ -3,10 +3,7 @@
3
3
  //
4
4
  // Component: `uk-drop`
5
5
  //
6
- // Modifiers: `uk-drop-top-*`
7
- // `uk-drop-bottom-*`
8
- // `uk-drop-left-*`
9
- // `uk-drop-right-*`
6
+ // Modifiers: `uk-drop-stretch`
10
7
  // `uk-drop-stack`
11
8
  // `uk-drop-grid`
12
9
  //
@@ -22,6 +19,7 @@
22
19
 
23
20
  $drop-z-index: $global-z-index + 20 !default;
24
21
  $drop-margin: $global-margin !default;
22
+ $drop-viewport-margin: 15px !default;
25
23
  $drop-width: 300px !default;
26
24
 
27
25
 
@@ -42,7 +40,7 @@ $drop-width: 300px !default;
42
40
  position: absolute;
43
41
  z-index: $drop-z-index;
44
42
  --uk-position-offset: #{$drop-margin};
45
- --uk-position-viewport-offset: 10;
43
+ --uk-position-viewport-offset: #{$drop-viewport-margin};
46
44
  /* 3 */
47
45
  box-sizing: border-box;
48
46
  width: $drop-width;
@@ -52,6 +50,22 @@ $drop-width: 300px !default;
52
50
  .uk-drop.uk-open { display: block; }
53
51
 
54
52
 
53
+ /* Stretch modifier
54
+ ========================================================================== */
55
+
56
+ /*
57
+ * 1. Allow scrolling
58
+ */
59
+
60
+ .uk-drop-stretch {
61
+ --uk-position-offset: 0;
62
+ --uk-position-viewport-offset: 0;
63
+ /* 1 */
64
+ overflow-y: auto;
65
+ -webkit-overflow-scrolling: touch;
66
+ }
67
+
68
+
55
69
  /* Grid modifiers
56
70
  ========================================================================== */
57
71
 
@@ -5,10 +5,7 @@
5
5
  //
6
6
  // Adopted: `uk-dropdown-nav`
7
7
  //
8
- // Modifiers: `uk-dropdown-top-*`
9
- // `uk-dropdown-bottom-*`
10
- // `uk-dropdown-left-*`
11
- // `uk-dropdown-right-*`
8
+ // Modifiers: `uk-dropdown-stretch`
12
9
  // `uk-dropdown-stack`
13
10
  // `uk-dropdown-grid`
14
11
  //
@@ -22,6 +19,7 @@
22
19
 
23
20
  $dropdown-z-index: $global-z-index + 20 !default;
24
21
  $dropdown-margin: $global-small-margin !default;
22
+ $dropdown-viewport-margin: 15px !default;
25
23
  $dropdown-min-width: 200px !default;
26
24
  $dropdown-padding: 15px !default;
27
25
  $dropdown-background: $global-muted-background !default;
@@ -55,7 +53,7 @@ $dropdown-nav-sublist-item-hover-color: $global-color !default;
55
53
  position: absolute;
56
54
  z-index: $dropdown-z-index;
57
55
  --uk-position-offset: #{$dropdown-margin};
58
- --uk-position-viewport-offset: 10;
56
+ --uk-position-viewport-offset: #{$dropdown-viewport-margin};
59
57
  /* 3 */
60
58
  box-sizing: border-box;
61
59
  min-width: $dropdown-min-width;
@@ -71,6 +69,23 @@ $dropdown-nav-sublist-item-hover-color: $global-color !default;
71
69
  .uk-dropdown.uk-open { display: block; }
72
70
 
73
71
 
72
+ /* Stretch modifier
73
+ ========================================================================== */
74
+
75
+ /*
76
+ * 1. Allow scrolling
77
+ */
78
+
79
+ .uk-dropdown-stretch {
80
+ --uk-position-offset: 0;
81
+ --uk-position-viewport-offset: 0;
82
+ /* 1 */
83
+ overflow-y: auto;
84
+ -webkit-overflow-scrolling: touch;
85
+ @if(mixin-exists(hook-dropdown-stretch)) {@include hook-dropdown-stretch();}
86
+ }
87
+
88
+
74
89
  /* Nav
75
90
  * Adopts `uk-nav`
76
91
  ========================================================================== */
@@ -145,6 +160,7 @@ $dropdown-nav-sublist-item-hover-color: $global-color !default;
145
160
  @if(mixin-exists(hook-dropdown-misc)) {@include hook-dropdown-misc();}
146
161
 
147
162
  // @mixin hook-dropdown(){}
163
+ // @mixin hook-dropdown-stretch(){}
148
164
  // @mixin hook-dropdown-nav(){}
149
165
  // @mixin hook-dropdown-nav-item(){}
150
166
  // @mixin hook-dropdown-nav-item-hover(){}