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.
- package/CHANGELOG.md +47 -12
- package/build/util.js +1 -0
- package/dist/css/uikit-core-rtl.css +385 -110
- package/dist/css/uikit-core-rtl.min.css +1 -1
- package/dist/css/uikit-core.css +385 -110
- package/dist/css/uikit-core.min.css +1 -1
- package/dist/css/uikit-rtl.css +402 -115
- package/dist/css/uikit-rtl.min.css +1 -1
- package/dist/css/uikit.css +402 -115
- package/dist/css/uikit.min.css +1 -1
- package/dist/js/components/countdown.js +1 -1
- package/dist/js/components/countdown.min.js +1 -1
- package/dist/js/components/filter.js +7 -5
- package/dist/js/components/filter.min.js +1 -1
- package/dist/js/components/lightbox-panel.js +196 -140
- package/dist/js/components/lightbox-panel.min.js +1 -1
- package/dist/js/components/lightbox.js +196 -140
- package/dist/js/components/lightbox.min.js +1 -1
- package/dist/js/components/notification.js +1 -1
- package/dist/js/components/notification.min.js +1 -1
- package/dist/js/components/parallax.js +4 -5
- package/dist/js/components/parallax.min.js +1 -1
- package/dist/js/components/slider-parallax.js +4 -5
- package/dist/js/components/slider-parallax.min.js +1 -1
- package/dist/js/components/slider.js +22 -7
- package/dist/js/components/slider.min.js +1 -1
- package/dist/js/components/slideshow-parallax.js +4 -5
- package/dist/js/components/slideshow-parallax.min.js +1 -1
- package/dist/js/components/slideshow.js +22 -7
- package/dist/js/components/slideshow.min.js +1 -1
- package/dist/js/components/sortable.js +3 -3
- package/dist/js/components/sortable.min.js +1 -1
- package/dist/js/components/tooltip.js +107 -137
- package/dist/js/components/tooltip.min.js +1 -1
- package/dist/js/components/upload.js +1 -1
- package/dist/js/components/upload.min.js +1 -1
- package/dist/js/uikit-core.js +1819 -1714
- package/dist/js/uikit-core.min.js +14 -1
- package/dist/js/uikit-icons.js +1 -1
- package/dist/js/uikit-icons.min.js +1 -1
- package/dist/js/uikit.js +1081 -959
- package/dist/js/uikit.min.js +14 -1
- package/package.json +1 -1
- package/src/images/{backgrounds/nav-parent-open.svg → components/nav-parent-icon-large.svg} +0 -0
- package/src/images/components/nav-parent-icon.svg +3 -0
- package/src/images/components/navbar-parent-icon.svg +3 -0
- package/src/images/components/navbar-toggle-icon.svg +22 -3
- package/src/js/api/state.js +2 -2
- package/src/js/components/filter.js +5 -3
- package/src/js/components/sortable.js +2 -3
- package/src/js/core/accordion.js +9 -17
- package/src/js/core/alert.js +35 -14
- package/src/js/core/drop.js +115 -80
- package/src/js/core/height-viewport.js +14 -6
- package/src/js/core/icon.js +16 -0
- package/src/js/core/index.js +2 -0
- package/src/js/core/leader.js +2 -2
- package/src/js/core/navbar.js +44 -30
- package/src/js/core/offcanvas.js +1 -47
- package/src/js/core/scroll.js +37 -10
- package/src/js/core/sticky.js +8 -9
- package/src/js/core/toggle.js +3 -5
- package/src/js/mixin/media.js +4 -5
- package/src/js/mixin/modal.js +97 -8
- package/src/js/mixin/position.js +26 -11
- package/src/js/mixin/slider-drag.js +20 -8
- package/src/js/mixin/style.js +11 -0
- package/src/js/mixin/togglable.js +88 -133
- package/src/js/util/animation.js +4 -3
- package/src/js/util/class.js +3 -1
- package/src/js/util/dimensions.js +6 -6
- package/src/js/util/filter.js +3 -7
- package/src/js/util/position.js +108 -107
- package/src/js/util/style.js +4 -13
- package/src/js/util/viewport.js +5 -32
- package/src/less/components/_import.less +1 -0
- package/src/less/components/drop.less +1 -18
- package/src/less/components/dropbar.less +115 -0
- package/src/less/components/dropdown.less +16 -16
- package/src/less/components/leader.less +1 -1
- package/src/less/components/nav.less +240 -63
- package/src/less/components/navbar.less +81 -38
- package/src/less/components/utility.less +21 -4
- package/src/less/theme/_import.less +1 -0
- package/src/less/theme/dropbar.less +44 -0
- package/src/less/theme/dropdown.less +0 -11
- package/src/less/theme/nav.less +43 -9
- package/src/less/theme/navbar.less +7 -11
- package/src/scss/components/_import.scss +1 -0
- package/src/scss/components/drop.scss +1 -18
- package/src/scss/components/dropbar.scss +115 -0
- package/src/scss/components/dropdown.scss +16 -16
- package/src/scss/components/leader.scss +1 -1
- package/src/scss/components/nav.scss +189 -51
- package/src/scss/components/navbar.scss +69 -38
- package/src/scss/components/utility.scss +19 -3
- package/src/scss/mixins-theme.scss +93 -25
- package/src/scss/mixins.scss +89 -17
- package/src/scss/theme/_import.scss +1 -0
- package/src/scss/theme/dropbar.scss +44 -0
- package/src/scss/theme/dropdown.scss +0 -8
- package/src/scss/theme/nav.scss +41 -9
- package/src/scss/theme/navbar.scss +7 -8
- package/src/scss/variables-theme.scss +71 -18
- package/src/scss/variables.scss +60 -14
- package/tests/accordion.html +2 -2
- package/tests/alert.html +2 -2
- package/tests/countdown.html +1 -1
- package/tests/drop.html +461 -375
- package/tests/dropbar.html +458 -0
- package/tests/dropdown.html +26 -401
- package/tests/filter.html +9 -12
- package/tests/form.html +1 -1
- package/tests/index.html +126 -107
- package/tests/js/index.js +1 -4
- package/tests/lightbox.html +5 -5
- package/tests/list.html +8 -8
- package/tests/modal.html +13 -13
- package/tests/nav.html +117 -75
- package/tests/navbar.html +2002 -1131
- package/tests/offcanvas.html +17 -21
- package/tests/parallax.html +1 -1
- package/tests/position.html +18 -16
- package/tests/progress.html +9 -9
- package/tests/scroll.html +7 -10
- package/tests/search.html +6 -6
- package/tests/slider.html +6 -5
- package/tests/slideshow.html +8 -8
- package/tests/sortable.html +6 -8
- package/tests/sticky-navbar.html +9 -9
- package/tests/sticky.html +8 -8
- package/tests/switcher.html +1 -1
- package/tests/tab.html +1 -1
- package/tests/table.html +7 -7
- package/tests/toggle.html +2 -2
- package/tests/tooltip.html +1 -1
- package/tests/upload.html +11 -11
- package/tests/utility.html +19 -0
- 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.
|
|
5
|
+
"version": "3.14.4-dev.a014fa609",
|
|
6
6
|
"main": "dist/js/uikit.js",
|
|
7
7
|
"style": "dist/css/uikit.css",
|
|
8
8
|
"sideEffects": [
|
|
File without changes
|
|
@@ -1,5 +1,24 @@
|
|
|
1
1
|
<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
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>
|
package/src/js/api/state.js
CHANGED
|
@@ -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' &&
|
|
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]
|
|
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
|
-
)
|
|
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
|
|
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
|
|
336
|
+
scrollEl.scrollTop = scroll;
|
|
338
337
|
return true;
|
|
339
338
|
}
|
|
340
339
|
});
|
package/src/js/core/accordion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import Class from '../mixin/class';
|
|
2
2
|
import Lazyload from '../mixin/lazyload';
|
|
3
|
-
import {
|
|
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
|
-
|
|
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:
|
|
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) =>
|
|
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 = $(
|
|
135
|
+
const content = $(this.content, el);
|
|
136
136
|
|
|
137
|
-
if (animate === false || !this.
|
|
137
|
+
if (animate === false || !this.animation) {
|
|
138
|
+
content.hidden = !show;
|
|
138
139
|
hide(content, !show);
|
|
139
140
|
return;
|
|
140
141
|
}
|
|
141
142
|
|
|
142
|
-
|
|
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);
|
package/src/js/core/alert.js
CHANGED
|
@@ -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:
|
|
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
|
-
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
delegate() {
|
|
25
|
+
return this.selClose;
|
|
26
|
+
},
|
|
27
27
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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
|
+
}
|
package/src/js/core/drop.js
CHANGED
|
@@ -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
|
-
|
|
46
|
+
target: Boolean,
|
|
47
|
+
targetX: Boolean,
|
|
48
|
+
targetY: Boolean,
|
|
49
|
+
stretch: Boolean,
|
|
46
50
|
delayShow: Number,
|
|
47
51
|
delayHide: Number,
|
|
48
|
-
|
|
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:
|
|
57
|
-
|
|
61
|
+
boundary: false,
|
|
62
|
+
target: false,
|
|
63
|
+
targetX: false,
|
|
64
|
+
targetY: false,
|
|
65
|
+
stretch: false,
|
|
58
66
|
delayShow: 0,
|
|
59
67
|
delayHide: 800,
|
|
60
|
-
|
|
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
|
-
|
|
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.
|
|
80
|
-
this.
|
|
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.
|
|
85
|
-
this.lazyload(this.
|
|
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
|
-
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
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.
|
|
313
|
-
if (this.isToggled() && target && this.
|
|
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.
|
|
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
|
-
|
|
381
|
-
|
|
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
|
|
385
|
-
const
|
|
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
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
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
|
|
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(
|
|
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
|
-
|
|
66
|
-
|
|
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) {
|
package/src/js/core/icon.js
CHANGED
|
@@ -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
|
|
package/src/js/core/index.js
CHANGED
|
@@ -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';
|