uikit 3.14.1-dev.eeb4cd6ae → 3.14.2-dev.35b3deec9

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 (99) hide show
  1. package/CHANGELOG.md +45 -3
  2. package/build/util.js +8 -2
  3. package/dist/css/uikit-core-rtl.css +93 -21
  4. package/dist/css/uikit-core-rtl.min.css +1 -1
  5. package/dist/css/uikit-core.css +93 -21
  6. package/dist/css/uikit-core.min.css +1 -1
  7. package/dist/css/uikit-rtl.css +99 -33
  8. package/dist/css/uikit-rtl.min.css +1 -1
  9. package/dist/css/uikit.css +99 -33
  10. package/dist/css/uikit.min.css +1 -1
  11. package/dist/js/components/countdown.js +1 -1
  12. package/dist/js/components/countdown.min.js +1 -1
  13. package/dist/js/components/filter.js +2 -2
  14. package/dist/js/components/filter.min.js +1 -1
  15. package/dist/js/components/lightbox-panel.js +111 -15
  16. package/dist/js/components/lightbox-panel.min.js +1 -1
  17. package/dist/js/components/lightbox.js +111 -15
  18. package/dist/js/components/lightbox.min.js +1 -1
  19. package/dist/js/components/notification.js +1 -1
  20. package/dist/js/components/notification.min.js +1 -1
  21. package/dist/js/components/parallax.js +18 -3
  22. package/dist/js/components/parallax.min.js +1 -1
  23. package/dist/js/components/slider-parallax.js +2 -2
  24. package/dist/js/components/slider-parallax.min.js +1 -1
  25. package/dist/js/components/slider.js +1 -1
  26. package/dist/js/components/slider.min.js +1 -1
  27. package/dist/js/components/slideshow-parallax.js +2 -2
  28. package/dist/js/components/slideshow-parallax.min.js +1 -1
  29. package/dist/js/components/slideshow.js +1 -1
  30. package/dist/js/components/slideshow.min.js +1 -1
  31. package/dist/js/components/sortable.js +1 -1
  32. package/dist/js/components/sortable.min.js +1 -1
  33. package/dist/js/components/tooltip.js +147 -34
  34. package/dist/js/components/tooltip.min.js +1 -1
  35. package/dist/js/components/upload.js +1 -1
  36. package/dist/js/components/upload.min.js +1 -1
  37. package/dist/js/uikit-core.js +280 -132
  38. package/dist/js/uikit-core.min.js +1 -1
  39. package/dist/js/uikit-icons.js +1 -1
  40. package/dist/js/uikit-icons.min.js +1 -1
  41. package/dist/js/uikit.js +298 -135
  42. package/dist/js/uikit.min.js +1 -1
  43. package/package.json +11 -11
  44. package/src/js/api/hooks.js +1 -1
  45. package/src/js/components/filter.js +1 -1
  46. package/src/js/components/parallax.js +16 -1
  47. package/src/js/core/accordion.js +3 -3
  48. package/src/js/core/alert.js +1 -1
  49. package/src/js/core/drop.js +47 -18
  50. package/src/js/core/height-viewport.js +15 -11
  51. package/src/js/core/margin.js +1 -1
  52. package/src/js/core/navbar.js +19 -18
  53. package/src/js/core/scrollspy.js +6 -1
  54. package/src/js/core/toggle.js +9 -8
  55. package/src/js/mixin/parallax.js +1 -1
  56. package/src/js/mixin/position.js +36 -20
  57. package/src/js/mixin/togglable.js +116 -18
  58. package/src/js/util/animation.js +1 -0
  59. package/src/js/util/position.js +24 -22
  60. package/src/js/util/viewport.js +7 -14
  61. package/src/less/components/drop.less +19 -4
  62. package/src/less/components/dropdown.less +21 -4
  63. package/src/less/components/margin.less +13 -14
  64. package/src/less/components/modal.less +19 -4
  65. package/src/less/components/nav.less +1 -1
  66. package/src/less/components/navbar.less +60 -19
  67. package/src/less/components/offcanvas.less +21 -21
  68. package/src/less/components/position.less +1 -1
  69. package/src/less/components/sticky.less +7 -0
  70. package/src/less/components/tooltip.less +1 -0
  71. package/src/less/components/utility.less +1 -2
  72. package/src/less/theme/dropdown.less +11 -0
  73. package/src/less/theme/navbar.less +10 -10
  74. package/src/scss/components/drop.scss +19 -4
  75. package/src/scss/components/dropdown.scss +21 -4
  76. package/src/scss/components/margin.scss +13 -14
  77. package/src/scss/components/modal.scss +19 -4
  78. package/src/scss/components/nav.scss +1 -1
  79. package/src/scss/components/navbar.scss +49 -8
  80. package/src/scss/components/offcanvas.scss +21 -21
  81. package/src/scss/components/position.scss +1 -1
  82. package/src/scss/components/sticky.scss +7 -0
  83. package/src/scss/components/tooltip.scss +1 -0
  84. package/src/scss/components/utility.scss +1 -2
  85. package/src/scss/mixins-theme.scss +8 -10
  86. package/src/scss/mixins.scss +2 -0
  87. package/src/scss/theme/dropdown.scss +8 -0
  88. package/src/scss/theme/navbar.scss +7 -0
  89. package/src/scss/variables-theme.scss +26 -11
  90. package/src/scss/variables.scss +24 -11
  91. package/tests/drop.html +165 -4
  92. package/tests/dropdown.html +234 -13
  93. package/tests/height-viewport.html +62 -0
  94. package/tests/navbar.html +333 -64
  95. package/tests/notification.html +1 -1
  96. package/tests/offcanvas.html +8 -8
  97. package/tests/sticky-navbar.html +132 -0
  98. package/tests/sticky-parallax.html +2 -1
  99. package/tests/sticky.html +5 -4
@@ -40,6 +40,7 @@
40
40
  @navbar-color-mode: none;
41
41
 
42
42
  @navbar-nav-item-height: 80px;
43
+ @navbar-nav-item-gap: 0;
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,14 @@
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 {
179
+ right: 100%; // Fallback if gap is 0
180
+ right: ~'calc(100% + var(--uk-navbar-nav-item-gap))';
181
+ }
182
+ .uk-navbar-center-right {
183
+ left: 100%; // Fallback if gap is 0
184
+ left: ~'calc(100% + var(--uk-navbar-nav-item-gap))';
185
+ }
173
186
 
174
187
  [class*='uk-navbar-center-'] {
175
188
  width: max-content;
@@ -186,6 +199,7 @@
186
199
 
187
200
  .uk-navbar-nav {
188
201
  display: flex;
202
+ gap: var(--uk-navbar-nav-item-gap);
189
203
  /* 1 */
190
204
  margin: 0;
191
205
  padding: 0;
@@ -267,6 +281,7 @@
267
281
  ========================================================================== */
268
282
 
269
283
  .uk-navbar-item {
284
+ padding: 0 @navbar-item-padding-horizontal;
270
285
  color: @navbar-item-color;
271
286
  .hook-navbar-item();
272
287
  }
@@ -362,6 +377,8 @@
362
377
  position: absolute;
363
378
  z-index: @navbar-dropdown-z-index;
364
379
  --uk-position-offset: @navbar-dropdown-margin;
380
+ --uk-position-shift-offset: @navbar-dropdown-shift-margin;
381
+ --uk-position-viewport-offset: @navbar-dropdown-viewport-margin;
365
382
  /* 3 */
366
383
  box-sizing: border-box;
367
384
  width: @navbar-dropdown-width;
@@ -376,6 +393,10 @@
376
393
  /* Show */
377
394
  .uk-navbar-dropdown.uk-open { display: block; }
378
395
 
396
+
397
+ .uk-navbar-dropdown:extend(.uk-light all) when (@navbar-dropdown-color-mode = light) {}
398
+ .uk-navbar-dropdown:extend(.uk-dark all) when (@navbar-dropdown-color-mode = dark) {}
399
+
379
400
  /*
380
401
  * Grid
381
402
  * Adopts `uk-grid`
@@ -400,21 +421,40 @@
400
421
  .uk-navbar-dropdown-width-4:not(.uk-navbar-dropdown-stack) { width: (@navbar-dropdown-width * 4); }
401
422
  .uk-navbar-dropdown-width-5:not(.uk-navbar-dropdown-stack) { width: (@navbar-dropdown-width * 5); }
402
423
 
424
+ /*
425
+ * Stretch modifier
426
+ * 1. Allow scrolling
427
+ */
428
+
429
+ .uk-navbar-dropdown-stretch {
430
+ --uk-position-offset: 0;
431
+ --uk-position-shift-offset: 0;
432
+ --uk-position-viewport-offset: 0;
433
+ /* 1 */
434
+ overflow-y: auto;
435
+ -webkit-overflow-scrolling: touch;
436
+ .hook-navbar-dropdown-stretch();
437
+ }
438
+
403
439
  /*
404
440
  * Dropbar modifier
405
- * 1. Set position
406
- * 2. Bottom padding for dropbar
407
- * 3. Horizontal padding
441
+ * 1. Reset dropdown width to prevent to early shifting
442
+ * 2. Set position
443
+ * 3. Bottom padding for dropbar
444
+ * 4. Horizontal padding
408
445
  */
409
446
 
410
447
  .uk-navbar-dropdown-dropbar {
411
448
  /* 1 */
412
- --uk-position-offset: @navbar-dropdown-dropbar-margin-top;
449
+ width: auto;
413
450
  /* 2 */
414
- margin-bottom: @navbar-dropdown-dropbar-margin-bottom;
451
+ --uk-position-offset: @navbar-dropdown-dropbar-margin-top;
415
452
  /* 3 */
453
+ margin-bottom: @navbar-dropdown-dropbar-margin-bottom;
454
+ /* 4 */
416
455
  padding-left: @navbar-dropdown-dropbar-padding-horizontal;
417
456
  padding-right: @navbar-dropdown-dropbar-padding-horizontal;
457
+ --uk-position-shift-offset: 0;
418
458
  .hook-navbar-dropdown-dropbar();
419
459
  }
420
460
 
@@ -511,24 +551,25 @@
511
551
  .hook-navbar-nav-item-onclick() {}
512
552
  .hook-navbar-nav-item-active() {}
513
553
  .hook-navbar-item() {}
514
- .hook-navbar-toggle(){}
515
- .hook-navbar-toggle-hover(){}
516
- .hook-navbar-toggle-icon(){}
517
- .hook-navbar-toggle-icon-hover(){}
554
+ .hook-navbar-toggle() {}
555
+ .hook-navbar-toggle-hover() {}
556
+ .hook-navbar-toggle-icon() {}
557
+ .hook-navbar-toggle-icon-hover() {}
518
558
  .hook-navbar-subtitle() {}
519
- .hook-navbar-primary(){}
520
- .hook-navbar-transparent(){}
521
- .hook-navbar-sticky(){}
522
- .hook-navbar-dropdown(){}
523
- .hook-navbar-dropdown-dropbar(){}
524
- .hook-navbar-dropdown-nav(){}
559
+ .hook-navbar-primary() {}
560
+ .hook-navbar-transparent() {}
561
+ .hook-navbar-sticky() {}
562
+ .hook-navbar-dropdown() {}
563
+ .hook-navbar-dropdown-stretch() {}
564
+ .hook-navbar-dropdown-dropbar() {}
565
+ .hook-navbar-dropdown-nav() {}
525
566
  .hook-navbar-dropdown-nav-item() {}
526
567
  .hook-navbar-dropdown-nav-item-hover() {}
527
568
  .hook-navbar-dropdown-nav-item-active() {}
528
569
  .hook-navbar-dropdown-nav-subtitle() {}
529
570
  .hook-navbar-dropdown-nav-header() {}
530
571
  .hook-navbar-dropdown-nav-divider() {}
531
- .hook-navbar-dropbar(){}
572
+ .hook-navbar-dropbar() {}
532
573
  .hook-navbar-misc() {}
533
574
 
534
575
 
@@ -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
 
@@ -55,6 +55,13 @@
55
55
 
56
56
  .uk-sticky.uk-animation-reverse { animation-duration: @sticky-reverse-animation-duration; }
57
57
 
58
+ /*
59
+ * Placeholder
60
+ * Make content clickable for sticky cover and reveal effects
61
+ */
62
+
63
+ .uk-sticky-placeholder { pointer-events: none; }
64
+
58
65
 
59
66
  // Hooks
60
67
  // ========================================================================
@@ -51,6 +51,7 @@
51
51
  position: absolute;
52
52
  z-index: @tooltip-z-index;
53
53
  --uk-position-offset: @tooltip-margin;
54
+ --uk-position-viewport-offset: 10;
54
55
  /* 3 */
55
56
  top: 0;
56
57
  /* 4 */
@@ -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 {
@@ -405,7 +404,7 @@
405
404
  .hook-logo-hover();
406
405
  }
407
406
 
408
- .uk-logo > :where(img, svg, video) { display: block; }
407
+ .uk-logo > :where(img, svg, video) { display: inline-block; }
409
408
 
410
409
  .uk-logo-inverse { display: none; }
411
410
 
@@ -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,16 +139,6 @@
129
139
 
130
140
  .hook-navbar-misc() {
131
141
 
132
- /*
133
- * Navbar
134
- */
135
-
136
- .uk-navbar-container > .uk-container .uk-navbar-left {
137
- margin-left: -@navbar-nav-item-padding-horizontal;
138
- margin-right: -@navbar-nav-item-padding-horizontal;
139
- }
140
- .uk-navbar-container > .uk-container .uk-navbar-right { margin-right: -@navbar-nav-item-padding-horizontal; }
141
-
142
142
  /*
143
143
  * Grid Divider
144
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,6 +40,7 @@ $drop-width: 300px !default;
42
40
  position: absolute;
43
41
  z-index: $drop-z-index;
44
42
  --uk-position-offset: #{$drop-margin};
43
+ --uk-position-viewport-offset: #{$drop-viewport-margin};
45
44
  /* 3 */
46
45
  box-sizing: border-box;
47
46
  width: $drop-width;
@@ -51,6 +50,22 @@ $drop-width: 300px !default;
51
50
  .uk-drop.uk-open { display: block; }
52
51
 
53
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
+
54
69
  /* Grid modifiers
55
70
  ========================================================================== */
56
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,6 +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};
56
+ --uk-position-viewport-offset: #{$dropdown-viewport-margin};
58
57
  /* 3 */
59
58
  box-sizing: border-box;
60
59
  min-width: $dropdown-min-width;
@@ -70,6 +69,23 @@ $dropdown-nav-sublist-item-hover-color: $global-color !default;
70
69
  .uk-dropdown.uk-open { display: block; }
71
70
 
72
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
+
73
89
  /* Nav
74
90
  * Adopts `uk-nav`
75
91
  ========================================================================== */
@@ -144,6 +160,7 @@ $dropdown-nav-sublist-item-hover-color: $global-color !default;
144
160
  @if(mixin-exists(hook-dropdown-misc)) {@include hook-dropdown-misc();}
145
161
 
146
162
  // @mixin hook-dropdown(){}
163
+ // @mixin hook-dropdown-stretch(){}
147
164
  // @mixin hook-dropdown-nav(){}
148
165
  // @mixin hook-dropdown-nav-item(){}
149
166
  // @mixin hook-dropdown-nav-item-hover(){}
@@ -193,20 +193,20 @@ $margin-xlarge-margin-l: $global-xlarge-margin !d
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 @@ $margin-xlarge-margin-l: $global-xlarge-margin !d
241
241
  }
242
242
 
243
243
 
244
-
245
244
  // Hooks
246
245
  // ========================================================================
247
246
 
@@ -40,15 +40,21 @@ $modal-dialog-background: $global-background !default;
40
40
 
41
41
  $modal-container-width: 1200px !default;
42
42
 
43
- $modal-body-padding-horizontal: $global-gutter !default;
44
- $modal-body-padding-vertical: $global-gutter !default;
43
+ $modal-body-padding-horizontal: 20px !default;
44
+ $modal-body-padding-vertical: 20px !default;
45
+ $modal-body-padding-horizontal-s: $global-gutter !default;
46
+ $modal-body-padding-vertical-s: $global-gutter !default;
45
47
 
46
- $modal-header-padding-horizontal: $global-gutter !default;
48
+ $modal-header-padding-horizontal: 20px !default;
47
49
  $modal-header-padding-vertical: ($modal-header-padding-horizontal * 0.5) !default;
50
+ $modal-header-padding-horizontal-s: $global-gutter !default;
51
+ $modal-header-padding-vertical-s: ($modal-header-padding-horizontal-s * 0.5) !default;
48
52
  $modal-header-background: $global-muted-background !default;
49
53
 
50
- $modal-footer-padding-horizontal: $global-gutter !default;
54
+ $modal-footer-padding-horizontal: 20px !default;
51
55
  $modal-footer-padding-vertical: ($modal-footer-padding-horizontal * 0.5) !default;
56
+ $modal-footer-padding-horizontal-s: $global-gutter !default;
57
+ $modal-footer-padding-vertical-s: ($modal-footer-padding-horizontal-s * 0.5) !default;
52
58
  $modal-footer-background: $global-muted-background !default;
53
59
 
54
60
  $modal-title-font-size: $global-xlarge-font-size !default;
@@ -228,6 +234,15 @@ $modal-close-outside-hover-color: $global-inverse-color !default;
228
234
  @if(mixin-exists(hook-modal-footer)) {@include 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
  @if(mixin-exists(hook-nav-primary-subtitle)) {@include hook-nav-primary-subtitle();}
288
288
  }