uikit 3.14.4-dev.871ba3c05 → 3.14.4-dev.a014fa609

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 (139) hide show
  1. package/CHANGELOG.md +47 -12
  2. package/build/util.js +1 -0
  3. package/dist/css/uikit-core-rtl.css +385 -110
  4. package/dist/css/uikit-core-rtl.min.css +1 -1
  5. package/dist/css/uikit-core.css +385 -110
  6. package/dist/css/uikit-core.min.css +1 -1
  7. package/dist/css/uikit-rtl.css +402 -115
  8. package/dist/css/uikit-rtl.min.css +1 -1
  9. package/dist/css/uikit.css +402 -115
  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 +7 -5
  14. package/dist/js/components/filter.min.js +1 -1
  15. package/dist/js/components/lightbox-panel.js +196 -140
  16. package/dist/js/components/lightbox-panel.min.js +1 -1
  17. package/dist/js/components/lightbox.js +196 -140
  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 +4 -5
  22. package/dist/js/components/parallax.min.js +1 -1
  23. package/dist/js/components/slider-parallax.js +4 -5
  24. package/dist/js/components/slider-parallax.min.js +1 -1
  25. package/dist/js/components/slider.js +22 -7
  26. package/dist/js/components/slider.min.js +1 -1
  27. package/dist/js/components/slideshow-parallax.js +4 -5
  28. package/dist/js/components/slideshow-parallax.min.js +1 -1
  29. package/dist/js/components/slideshow.js +22 -7
  30. package/dist/js/components/slideshow.min.js +1 -1
  31. package/dist/js/components/sortable.js +3 -3
  32. package/dist/js/components/sortable.min.js +1 -1
  33. package/dist/js/components/tooltip.js +107 -137
  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 +1819 -1714
  38. package/dist/js/uikit-core.min.js +14 -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 +1081 -959
  42. package/dist/js/uikit.min.js +14 -1
  43. package/package.json +1 -1
  44. package/src/images/{backgrounds/nav-parent-open.svg → components/nav-parent-icon-large.svg} +0 -0
  45. package/src/images/components/nav-parent-icon.svg +3 -0
  46. package/src/images/components/navbar-parent-icon.svg +3 -0
  47. package/src/images/components/navbar-toggle-icon.svg +22 -3
  48. package/src/js/api/state.js +2 -2
  49. package/src/js/components/filter.js +5 -3
  50. package/src/js/components/sortable.js +2 -3
  51. package/src/js/core/accordion.js +9 -17
  52. package/src/js/core/alert.js +35 -14
  53. package/src/js/core/drop.js +115 -80
  54. package/src/js/core/height-viewport.js +14 -6
  55. package/src/js/core/icon.js +16 -0
  56. package/src/js/core/index.js +2 -0
  57. package/src/js/core/leader.js +2 -2
  58. package/src/js/core/navbar.js +44 -30
  59. package/src/js/core/offcanvas.js +1 -47
  60. package/src/js/core/scroll.js +37 -10
  61. package/src/js/core/sticky.js +8 -9
  62. package/src/js/core/toggle.js +3 -5
  63. package/src/js/mixin/media.js +4 -5
  64. package/src/js/mixin/modal.js +97 -8
  65. package/src/js/mixin/position.js +26 -11
  66. package/src/js/mixin/slider-drag.js +20 -8
  67. package/src/js/mixin/style.js +11 -0
  68. package/src/js/mixin/togglable.js +88 -133
  69. package/src/js/util/animation.js +4 -3
  70. package/src/js/util/class.js +3 -1
  71. package/src/js/util/dimensions.js +6 -6
  72. package/src/js/util/filter.js +3 -7
  73. package/src/js/util/position.js +108 -107
  74. package/src/js/util/style.js +4 -13
  75. package/src/js/util/viewport.js +5 -32
  76. package/src/less/components/_import.less +1 -0
  77. package/src/less/components/drop.less +1 -18
  78. package/src/less/components/dropbar.less +115 -0
  79. package/src/less/components/dropdown.less +16 -16
  80. package/src/less/components/leader.less +1 -1
  81. package/src/less/components/nav.less +240 -63
  82. package/src/less/components/navbar.less +81 -38
  83. package/src/less/components/utility.less +21 -4
  84. package/src/less/theme/_import.less +1 -0
  85. package/src/less/theme/dropbar.less +44 -0
  86. package/src/less/theme/dropdown.less +0 -11
  87. package/src/less/theme/nav.less +43 -9
  88. package/src/less/theme/navbar.less +7 -11
  89. package/src/scss/components/_import.scss +1 -0
  90. package/src/scss/components/drop.scss +1 -18
  91. package/src/scss/components/dropbar.scss +115 -0
  92. package/src/scss/components/dropdown.scss +16 -16
  93. package/src/scss/components/leader.scss +1 -1
  94. package/src/scss/components/nav.scss +189 -51
  95. package/src/scss/components/navbar.scss +69 -38
  96. package/src/scss/components/utility.scss +19 -3
  97. package/src/scss/mixins-theme.scss +93 -25
  98. package/src/scss/mixins.scss +89 -17
  99. package/src/scss/theme/_import.scss +1 -0
  100. package/src/scss/theme/dropbar.scss +44 -0
  101. package/src/scss/theme/dropdown.scss +0 -8
  102. package/src/scss/theme/nav.scss +41 -9
  103. package/src/scss/theme/navbar.scss +7 -8
  104. package/src/scss/variables-theme.scss +71 -18
  105. package/src/scss/variables.scss +60 -14
  106. package/tests/accordion.html +2 -2
  107. package/tests/alert.html +2 -2
  108. package/tests/countdown.html +1 -1
  109. package/tests/drop.html +461 -375
  110. package/tests/dropbar.html +458 -0
  111. package/tests/dropdown.html +26 -401
  112. package/tests/filter.html +9 -12
  113. package/tests/form.html +1 -1
  114. package/tests/index.html +126 -107
  115. package/tests/js/index.js +1 -4
  116. package/tests/lightbox.html +5 -5
  117. package/tests/list.html +8 -8
  118. package/tests/modal.html +13 -13
  119. package/tests/nav.html +117 -75
  120. package/tests/navbar.html +2002 -1131
  121. package/tests/offcanvas.html +17 -21
  122. package/tests/parallax.html +1 -1
  123. package/tests/position.html +18 -16
  124. package/tests/progress.html +9 -9
  125. package/tests/scroll.html +7 -10
  126. package/tests/search.html +6 -6
  127. package/tests/slider.html +6 -5
  128. package/tests/slideshow.html +8 -8
  129. package/tests/sortable.html +6 -8
  130. package/tests/sticky-navbar.html +9 -9
  131. package/tests/sticky.html +8 -8
  132. package/tests/switcher.html +1 -1
  133. package/tests/tab.html +1 -1
  134. package/tests/table.html +7 -7
  135. package/tests/toggle.html +2 -2
  136. package/tests/tooltip.html +1 -1
  137. package/tests/upload.html +11 -11
  138. package/tests/utility.html +19 -0
  139. package/src/images/backgrounds/nav-parent-close.svg +0 -3
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "uikit",
3
3
  "title": "UIkit",
4
4
  "description": "UIkit is a lightweight and modular front-end framework for developing fast and powerful web interfaces.",
5
- "version": "3.14.4-dev.871ba3c05",
5
+ "version": "3.14.4-dev.a014fa609",
6
6
  "main": "dist/js/uikit.js",
7
7
  "style": "dist/css/uikit.css",
8
8
  "sideEffects": [
@@ -0,0 +1,3 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12">
2
+ <polyline fill="none" stroke="#000" stroke-width="1.1" points="1 3.5 6 8.5 11 3.5"/>
3
+ </svg>
@@ -0,0 +1,3 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12">
2
+ <polyline fill="none" stroke="#000" stroke-width="1.1" points="1 3.5 6 8.5 11 3.5"/>
3
+ </svg>
@@ -1,5 +1,24 @@
1
1
  <svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
2
- <rect y="9" width="20" height="2" />
3
- <rect y="3" width="20" height="2" />
4
- <rect y="15" width="20" height="2" />
2
+ <style>
3
+
4
+ .uk-navbar-toggle svg > [class*='line-'] {
5
+ transition: 0.2s ease-in-out;
6
+ transition-property: transform, opacity,;
7
+ transform-origin: center;
8
+ opacity: 1;
9
+ }
10
+
11
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-2 { transform: rotate(45deg); }
12
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-3 { transform: rotate(-45deg); }
13
+
14
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-1,
15
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-4 { opacity: 0; }
16
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-1 { transform: translateY(6px) scaleX(0); }
17
+ .uk-navbar-toggle[aria-expanded="true"] svg > .line-4 { transform: translateY(-6px) scaleX(0); }
18
+
19
+ </style>
20
+ <rect class="line-1" y="3" width="20" height="2" />
21
+ <rect class="line-2" y="9" width="20" height="2" />
22
+ <rect class="line-3" y="9" width="20" height="2" />
23
+ <rect class="line-4" y="15" width="20" height="2" />
5
24
  </svg>
@@ -142,7 +142,7 @@ function getProps(opts, name) {
142
142
 
143
143
  value = props[key] === Boolean && value === '' ? true : coerce(props[key], value);
144
144
 
145
- if (prop === 'target' && (!value || startsWith(value, '_'))) {
145
+ if (prop === 'target' && startsWith(value, '_')) {
146
146
  continue;
147
147
  }
148
148
 
@@ -153,7 +153,7 @@ function getProps(opts, name) {
153
153
 
154
154
  for (const key in options) {
155
155
  const prop = camelize(key);
156
- if (props[prop] !== undefined) {
156
+ if (!isUndefined(props[prop])) {
157
157
  data[prop] = coerce(props[prop], options[key]);
158
158
  }
159
159
  }
@@ -103,7 +103,7 @@ export default {
103
103
  });
104
104
  },
105
105
 
106
- setState(state, animate = true) {
106
+ async setState(state, animate = true) {
107
107
  state = { filter: { '': '' }, sort: [], ...state };
108
108
 
109
109
  trigger(this.$el, 'beforeFilter', [this, state]);
@@ -112,7 +112,7 @@ export default {
112
112
  toggleClass(el, this.cls, !!matchFilter(el, this.attrItem, state))
113
113
  );
114
114
 
115
- Promise.all(
115
+ await Promise.all(
116
116
  $$(this.target, this.$el).map((target) => {
117
117
  const filterFn = () => {
118
118
  applyState(state, target, getChildren(target));
@@ -120,7 +120,9 @@ export default {
120
120
  };
121
121
  return animate ? this.animate(filterFn, target) : filterFn();
122
122
  })
123
- ).then(() => trigger(this.$el, 'afterFilter', [this]));
123
+ );
124
+
125
+ trigger(this.$el, 'afterFilter', [this]);
124
126
  },
125
127
 
126
128
  updateState() {
@@ -26,7 +26,6 @@ import {
26
26
  remove,
27
27
  removeClass,
28
28
  scrollParents,
29
- scrollTop,
30
29
  toggleClass,
31
30
  Transition,
32
31
  trigger,
@@ -313,7 +312,7 @@ function trackScroll(pos) {
313
312
  let last = Date.now();
314
313
  trackTimer = setInterval(() => {
315
314
  let { x, y } = pos;
316
- y += scrollTop(window);
315
+ y += document.scrollingElement.scrollTop;
317
316
 
318
317
  const dist = (Date.now() - last) * 0.3;
319
318
  last = Date.now();
@@ -334,7 +333,7 @@ function trackScroll(pos) {
334
333
  }
335
334
 
336
335
  if (scroll > 0 && scroll < scrollHeight - height) {
337
- scrollTop(scrollEl, scroll);
336
+ scrollEl.scrollTop = scroll;
338
337
  return true;
339
338
  }
340
339
  });
@@ -1,6 +1,6 @@
1
1
  import Class from '../mixin/class';
2
2
  import Lazyload from '../mixin/lazyload';
3
- import { slide, default as Togglable } from '../mixin/togglable';
3
+ import { default as Togglable, toggleTransition } from '../mixin/togglable';
4
4
  import {
5
5
  $,
6
6
  $$,
@@ -14,14 +14,14 @@ import {
14
14
  isInView,
15
15
  scrollIntoView,
16
16
  toggleClass,
17
- unwrap,
18
- wrapAll,
17
+ within,
19
18
  } from 'uikit-util';
20
19
 
21
20
  export default {
22
21
  mixins: [Class, Lazyload, Togglable],
23
22
 
24
23
  props: {
24
+ animation: Boolean,
25
25
  targets: String,
26
26
  active: null,
27
27
  collapsible: Boolean,
@@ -34,7 +34,7 @@ export default {
34
34
  data: {
35
35
  targets: '> *',
36
36
  active: false,
37
- animation: ['slide'],
37
+ animation: true,
38
38
  collapsible: true,
39
39
  multiple: false,
40
40
  clsOpen: 'uk-open',
@@ -80,7 +80,7 @@ export default {
80
80
  hide(
81
81
  el,
82
82
  !hasClass(
83
- this.items.find((item) => item.contains(el)),
83
+ this.items.find((item) => within(el, item)),
84
84
  this.clsOpen
85
85
  )
86
86
  );
@@ -132,23 +132,15 @@ export default {
132
132
  toggleClass(el, this.clsOpen, show);
133
133
  attr($(this.$props.toggle, el), 'aria-expanded', show);
134
134
 
135
- const content = $(`${el._wrapper ? '> * ' : ''}${this.content}`, el);
135
+ const content = $(this.content, el);
136
136
 
137
- if (animate === false || !this.hasTransition) {
137
+ if (animate === false || !this.animation) {
138
+ content.hidden = !show;
138
139
  hide(content, !show);
139
140
  return;
140
141
  }
141
142
 
142
- if (!el._wrapper) {
143
- el._wrapper = wrapAll(content, `<div${show ? ' hidden' : ''}>`);
144
- }
145
-
146
- hide(content, false);
147
- await slide(this)(el._wrapper, show);
148
- hide(content, !show);
149
-
150
- delete el._wrapper;
151
- unwrap(content);
143
+ await toggleTransition(this)(content, show);
152
144
 
153
145
  if (show) {
154
146
  const toggle = $(this.$props.toggle, el);
@@ -1,5 +1,6 @@
1
1
  import Class from '../mixin/class';
2
2
  import Togglable from '../mixin/togglable';
3
+ import { css, toFloat, Transition } from 'uikit-util';
3
4
 
4
5
  export default {
5
6
  mixins: [Class, Togglable],
@@ -7,35 +8,55 @@ export default {
7
8
  args: 'animation',
8
9
 
9
10
  props: {
11
+ animation: Boolean,
10
12
  close: String,
11
13
  },
12
14
 
13
15
  data: {
14
- animation: ['slide'],
16
+ animation: true,
15
17
  selClose: '.uk-alert-close',
16
18
  duration: 150,
17
- hideProps: { opacity: 0, ...Togglable.data.hideProps },
18
19
  },
19
20
 
20
- events: [
21
- {
22
- name: 'click',
21
+ events: {
22
+ name: 'click',
23
23
 
24
- delegate() {
25
- return this.selClose;
26
- },
24
+ delegate() {
25
+ return this.selClose;
26
+ },
27
27
 
28
- handler(e) {
29
- e.preventDefault();
30
- this.close();
31
- },
28
+ handler(e) {
29
+ e.preventDefault();
30
+ this.close();
32
31
  },
33
- ],
32
+ },
34
33
 
35
34
  methods: {
36
35
  async close() {
37
- await this.toggleElement(this.$el);
36
+ await this.toggleElement(this.$el, false, animate(this));
38
37
  this.$destroy(true);
39
38
  },
40
39
  },
41
40
  };
41
+
42
+ function animate({ duration, transition, velocity }) {
43
+ return (el) => {
44
+ const height = toFloat(css(el, 'height'));
45
+ css(el, 'height', height);
46
+ return Transition.start(
47
+ el,
48
+ {
49
+ height: 0,
50
+ marginTop: 0,
51
+ marginBottom: 0,
52
+ paddingTop: 0,
53
+ paddingBottom: 0,
54
+ borderTop: 0,
55
+ borderBottom: 0,
56
+ opacity: 0,
57
+ },
58
+ velocity * height + duration,
59
+ transition
60
+ );
61
+ };
62
+ }
@@ -1,6 +1,7 @@
1
1
  import Container from '../mixin/container';
2
2
  import Lazyload from '../mixin/lazyload';
3
3
  import Position from '../mixin/position';
4
+ import Style from '../mixin/style';
4
5
  import Togglable from '../mixin/togglable';
5
6
  import {
6
7
  addClass,
@@ -27,14 +28,14 @@ import {
27
28
  query,
28
29
  removeClass,
29
30
  scrollParents,
30
- toggleClass,
31
31
  within,
32
32
  } from 'uikit-util';
33
+ import { preventBackgroundScroll, preventOverscroll } from '../mixin/modal';
33
34
 
34
35
  export let active;
35
36
 
36
37
  export default {
37
- mixins: [Container, Lazyload, Position, Togglable],
38
+ mixins: [Container, Lazyload, Position, Style, Togglable],
38
39
 
39
40
  args: 'pos',
40
41
 
@@ -42,27 +43,47 @@ export default {
42
43
  mode: 'list',
43
44
  toggle: Boolean,
44
45
  boundary: Boolean,
45
- boundaryAlign: Boolean,
46
+ target: Boolean,
47
+ targetX: Boolean,
48
+ targetY: Boolean,
49
+ stretch: Boolean,
46
50
  delayShow: Number,
47
51
  delayHide: Number,
48
- display: String,
52
+ autoUpdate: Boolean,
49
53
  clsDrop: String,
50
54
  animateOut: Boolean,
55
+ bgScroll: Boolean,
51
56
  },
52
57
 
53
58
  data: {
54
59
  mode: ['click', 'hover'],
55
60
  toggle: '- *',
56
- boundary: true,
57
- boundaryAlign: false,
61
+ boundary: false,
62
+ target: false,
63
+ targetX: false,
64
+ targetY: false,
65
+ stretch: false,
58
66
  delayShow: 0,
59
67
  delayHide: 800,
60
- display: null,
68
+ autoUpdate: true,
61
69
  clsDrop: false,
70
+ animateOut: false,
71
+ bgScroll: true,
62
72
  animation: ['uk-animation-fade'],
63
73
  cls: 'uk-open',
64
74
  container: false,
65
- animateOut: false,
75
+ },
76
+
77
+ computed: {
78
+ target({ target, targetX, targetY }, $el) {
79
+ targetX = targetX || target || this.targetEl;
80
+ targetY = targetY || target || this.targetEl;
81
+
82
+ return [
83
+ targetX === true ? window : query(targetX, $el),
84
+ targetY === true ? window : query(targetY, $el),
85
+ ];
86
+ },
66
87
  },
67
88
 
68
89
  created() {
@@ -76,18 +97,19 @@ export default {
76
97
  connected() {
77
98
  addClass(this.$el, this.clsDrop);
78
99
 
79
- if (this.toggle && !this.target) {
80
- this.target = this.$create('toggle', query(this.toggle, this.$el), {
100
+ if (this.toggle && !this.targetEl) {
101
+ this.targetEl = this.$create('toggle', query(this.toggle, this.$el), {
81
102
  target: this.$el,
82
103
  mode: this.mode,
83
104
  }).$el;
84
- attr(this.target, 'aria-haspopup', true);
85
- this.lazyload(this.target);
105
+ attr(this.targetEl, 'aria-haspopup', true);
106
+ this.lazyload(this.targetEl);
86
107
  }
87
108
  },
88
109
 
89
110
  disconnected() {
90
111
  if (this.isActive()) {
112
+ this.hide(false);
91
113
  active = null;
92
114
  }
93
115
  },
@@ -221,7 +243,8 @@ export default {
221
243
 
222
244
  this.tracker.init();
223
245
 
224
- for (const handler of [
246
+ const update = () => this.$emit();
247
+ const handlers = [
225
248
  on(
226
249
  document,
227
250
  pointerDown,
@@ -235,7 +258,7 @@ export default {
235
258
  !defaultPrevented &&
236
259
  type === pointerUp &&
237
260
  target === newTarget &&
238
- !(this.target && within(target, this.target))
261
+ !(this.targetEl && within(target, this.targetEl))
239
262
  ) {
240
263
  this.hide(false);
241
264
  }
@@ -250,25 +273,28 @@ export default {
250
273
  }
251
274
  }),
252
275
 
253
- ...(this.display === 'static' && this.align !== 'stretch'
276
+ on(window, 'resize', update),
277
+
278
+ (() => {
279
+ const observer = observeResize(
280
+ scrollParents(this.$el).concat(this.targetEl),
281
+ update
282
+ );
283
+ return () => observer.disconnect();
284
+ })(),
285
+
286
+ ...(this.autoUpdate
287
+ ? [on([document, scrollParents(this.$el)], 'scroll', update)]
288
+ : []),
289
+
290
+ ...(this.bgScroll
254
291
  ? []
255
- : (() => {
256
- const handler = () => this.$emit();
257
- return [
258
- on(window, 'resize', handler),
259
- on(document, 'scroll', handler, true),
260
- (() => {
261
- const observer = observeResize(
262
- scrollParents(this.$el),
263
- handler
264
- );
265
- return () => observer.disconnect();
266
- })(),
267
- ];
268
- })()),
269
- ]) {
270
- once(this.$el, 'hide', handler, { self: true });
271
- }
292
+ : [preventOverscroll(this.$el), preventBackgroundScroll()]),
293
+ ];
294
+
295
+ once(this.$el, 'hide', () => handlers.forEach((handler) => handler()), {
296
+ self: true,
297
+ });
272
298
  },
273
299
  },
274
300
 
@@ -309,12 +335,12 @@ export default {
309
335
  },
310
336
 
311
337
  methods: {
312
- show(target = this.target, delay = true) {
313
- if (this.isToggled() && target && this.target && target !== this.target) {
338
+ show(target = this.targetEl, delay = true) {
339
+ if (this.isToggled() && target && this.targetEl && target !== this.targetEl) {
314
340
  this.hide(false, false);
315
341
  }
316
342
 
317
- this.target = target;
343
+ this.targetEl = target;
318
344
 
319
345
  this.clearTimers();
320
346
 
@@ -377,60 +403,69 @@ export default {
377
403
 
378
404
  position() {
379
405
  removeClass(this.$el, `${this.clsDrop}-stack`);
380
- toggleClass(this.$el, `${this.clsDrop}-boundary`, this.boundaryAlign);
381
- toggleClass(this.$el, `${this.clsDrop}-stretch`, this.align === 'stretch');
406
+ attr(this.$el, 'style', this._style);
407
+
408
+ // Ensure none positioned element does not generate scrollbars
409
+ this.$el.hidden = true;
382
410
 
383
411
  const boundary = query(this.boundary, this.$el);
384
- const target = boundary && this.boundaryAlign ? boundary : this.target;
385
- const [scrollParent] = scrollParents(
386
- boundary && this.boundaryAlign ? boundary : this.$el
387
- );
388
- const scrollParentOffset = offset(scrollParent);
389
- const boundaryOffset = boundary ? offset(boundary) : scrollParentOffset;
412
+ const boundaryOffset = offsetViewport(boundary || window);
413
+ const viewports = this.target.map((target) => offsetViewport(scrollParents(target)[0]));
390
414
  const viewportOffset = this.getViewportOffset(this.$el);
391
415
 
392
- css(this.$el, 'maxWidth', '');
393
- const maxWidth = scrollParentOffset.width - 2 * viewportOffset;
394
-
395
- if (this.align === 'justify') {
396
- const prop = this.axis === 'y' ? 'width' : 'height';
397
- css(
398
- this.$el,
399
- prop,
400
- Math.min(
401
- (boundary ? boundaryOffset : offset(this.target))[prop],
402
- scrollParentOffset[prop] - 2 * viewportOffset
403
- )
404
- );
405
- } else if (this.align === 'stretch') {
406
- this.flip = this.axis === 'y' ? 'x' : 'y';
407
- this.display = 'static';
408
-
409
- const viewport = offsetViewport(scrollParent);
410
- const targetDim = offset(target);
411
- const elOffset = Math.abs(this.getPositionOffset(this.$el)) + viewportOffset;
412
-
413
- css(this.$el, {
414
- width:
415
- this.axis === 'y'
416
- ? viewport.width
417
- : (this.dir === 'left'
418
- ? targetDim.left - viewport.left
419
- : viewport.right - targetDim.right) - elOffset,
420
- height:
421
- this.axis === 'x'
422
- ? viewport.height
423
- : (this.dir === 'top'
424
- ? targetDim.top - viewport.top
425
- : viewport.bottom - targetDim.bottom) - elOffset,
426
- });
427
- } else if (this.$el.offsetWidth > maxWidth) {
416
+ const dirs = [
417
+ [0, ['x', 'width', 'left', 'right']],
418
+ [1, ['y', 'height', 'top', 'bottom']],
419
+ ];
420
+
421
+ for (const [i, [axis, prop]] of dirs) {
422
+ if (this.axis !== axis && includes([axis, true], this.stretch)) {
423
+ css(this.$el, {
424
+ [prop]: Math.min(
425
+ boundaryOffset[prop],
426
+ viewports[i][prop] - 2 * viewportOffset
427
+ ),
428
+ [`overflow-${axis}`]: 'auto',
429
+ });
430
+ }
431
+ }
432
+
433
+ const maxWidth = viewports[0].width - 2 * viewportOffset;
434
+
435
+ if (this.$el.offsetWidth > maxWidth) {
428
436
  addClass(this.$el, `${this.clsDrop}-stack`);
429
437
  }
430
438
 
431
439
  css(this.$el, 'maxWidth', maxWidth);
432
440
 
433
- this.positionAt(this.$el, target, boundary);
441
+ this.$el.hidden = false;
442
+
443
+ this.positionAt(this.$el, this.target, boundary);
444
+
445
+ for (const [i, [axis, prop, start, end]] of dirs) {
446
+ if (this.axis === axis && includes([axis, true], this.stretch)) {
447
+ const positionOffset = Math.abs(this.getPositionOffset(this.$el));
448
+ const targetOffset = offset(this.target[i]);
449
+ const elOffset = offset(this.$el);
450
+
451
+ css(this.$el, {
452
+ [prop]:
453
+ (targetOffset[start] > elOffset[start]
454
+ ? targetOffset[start] -
455
+ Math.max(
456
+ boundaryOffset[start],
457
+ viewports[i][start] + viewportOffset
458
+ )
459
+ : Math.min(
460
+ boundaryOffset[end],
461
+ viewports[i][end] - viewportOffset
462
+ ) - targetOffset[end]) - positionOffset,
463
+ [`overflow-${axis}`]: 'auto',
464
+ });
465
+
466
+ this.positionAt(this.$el, this.target, boundary);
467
+ }
468
+ }
434
469
  },
435
470
  },
436
471
  };
@@ -45,8 +45,11 @@ export default {
45
45
  let minHeight = '';
46
46
  const box = boxModelAdjust(this.$el, 'height', 'content-box');
47
47
 
48
+ const { body, scrollingElement } = document;
48
49
  const [scrollElement] = scrollParents(this.$el, /auto|scroll/);
49
- const { height: viewportHeight } = offsetViewport(scrollElement);
50
+ const { height: viewportHeight } = offsetViewport(
51
+ scrollElement === body ? scrollingElement : scrollElement
52
+ );
50
53
 
51
54
  if (this.expand) {
52
55
  minHeight = Math.max(
@@ -56,14 +59,19 @@ export default {
56
59
  0
57
60
  );
58
61
  } else {
62
+ const isScrollingElement =
63
+ scrollingElement === scrollElement || body === scrollElement;
64
+
59
65
  // on mobile devices (iOS and Android) window.innerHeight !== 100vh
60
- minHeight = `calc(${
61
- document.scrollingElement === scrollElement ? '100vh' : `${viewportHeight}px`
62
- }`;
66
+ minHeight = `calc(${isScrollingElement ? '100vh' : `${viewportHeight}px`}`;
63
67
 
64
68
  if (this.offsetTop) {
65
- const top = offsetPosition(this.$el)[0] - offsetPosition(scrollElement)[0];
66
- minHeight += top > 0 && top < viewportHeight / 2 ? ` - ${top}px` : '';
69
+ if (isScrollingElement) {
70
+ const top = offsetPosition(this.$el)[0] - offsetPosition(scrollElement)[0];
71
+ minHeight += top > 0 && top < viewportHeight / 2 ? ` - ${top}px` : '';
72
+ } else {
73
+ minHeight += ` - ${css(scrollElement, 'paddingTop')}`;
74
+ }
67
75
  }
68
76
 
69
77
  if (this.offsetBottom === true) {
@@ -2,6 +2,9 @@ import SVG from './svg';
2
2
  import closeIcon from '../../images/components/close-icon.svg';
3
3
  import closeLarge from '../../images/components/close-large.svg';
4
4
  import marker from '../../images/components/marker.svg';
5
+ import navParentIcon from '../../images/components/nav-parent-icon.svg';
6
+ import navParentIconLarge from '../../images/components/nav-parent-icon-large.svg';
7
+ import navbarParentIcon from '../../images/components/navbar-parent-icon.svg';
5
8
  import navbarToggleIcon from '../../images/components/navbar-toggle-icon.svg';
6
9
  import overlayIcon from '../../images/components/overlay-icon.svg';
7
10
  import paginationNext from '../../images/components/pagination-next.svg';
@@ -19,6 +22,7 @@ import {
19
22
  $,
20
23
  addClass,
21
24
  apply,
25
+ closest,
22
26
  css,
23
27
  each,
24
28
  hasClass,
@@ -35,6 +39,9 @@ const icons = {
35
39
  marker,
36
40
  'close-icon': closeIcon,
37
41
  'close-large': closeLarge,
42
+ 'nav-parent-icon': navParentIcon,
43
+ 'nav-parent-icon-large': navParentIconLarge,
44
+ 'navbar-parent-icon': navbarParentIcon,
38
45
  'navbar-toggle-icon': navbarToggleIcon,
39
46
  'overlay-icon': overlayIcon,
40
47
  'pagination-next': paginationNext,
@@ -96,6 +103,15 @@ export const IconComponent = {
96
103
  },
97
104
  };
98
105
 
106
+ export const NavParentIcon = {
107
+ extends: IconComponent,
108
+
109
+ beforeConnect() {
110
+ const icon = this.$props.icon;
111
+ this.icon = closest(this.$el, '.uk-nav-primary') ? `${icon}-large` : icon;
112
+ },
113
+ };
114
+
99
115
  export const Slidenav = {
100
116
  extends: IconComponent,
101
117
 
@@ -29,10 +29,12 @@ export { default as Video } from './video';
29
29
  // Icon components
30
30
  export { Close } from './icon';
31
31
  export { Spinner } from './icon';
32
+ export { NavParentIcon } from './icon';
32
33
  export { Slidenav as SlidenavNext } from './icon';
33
34
  export { Slidenav as SlidenavPrevious } from './icon';
34
35
  export { Search as SearchIcon } from './icon';
35
36
  export { IconComponent as Marker } from './icon';
37
+ export { IconComponent as NavbarParentIcon } from './icon';
36
38
  export { IconComponent as NavbarToggleIcon } from './icon';
37
39
  export { IconComponent as OverlayIcon } from './icon';
38
40
  export { IconComponent as PaginationNext } from './icon';