uikit 3.19.5-dev.c6a7fbca6 → 3.19.5-dev.c70b3862f
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 +6 -1
- package/dist/css/uikit-core-rtl.css +2 -2
- package/dist/css/uikit-core-rtl.min.css +1 -1
- package/dist/css/uikit-core.css +2 -2
- package/dist/css/uikit-core.min.css +1 -1
- package/dist/css/uikit-rtl.css +2 -2
- package/dist/css/uikit-rtl.min.css +1 -1
- package/dist/css/uikit.css +2 -2
- 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 +87 -87
- package/dist/js/components/filter.min.js +1 -1
- package/dist/js/components/lightbox-panel.js +55 -55
- package/dist/js/components/lightbox-panel.min.js +1 -1
- package/dist/js/components/lightbox.js +55 -55
- 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 +43 -32
- package/dist/js/components/parallax.min.js +1 -1
- package/dist/js/components/slider-parallax.js +44 -33
- package/dist/js/components/slider-parallax.min.js +1 -1
- package/dist/js/components/slider.js +44 -34
- package/dist/js/components/slider.min.js +1 -1
- package/dist/js/components/slideshow-parallax.js +44 -33
- package/dist/js/components/slideshow-parallax.min.js +1 -1
- package/dist/js/components/slideshow.js +44 -33
- package/dist/js/components/slideshow.min.js +1 -1
- package/dist/js/components/sortable.js +87 -87
- package/dist/js/components/sortable.min.js +1 -1
- package/dist/js/components/tooltip.js +1 -1
- 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 +132 -114
- package/dist/js/uikit-core.min.js +1 -1
- package/dist/js/uikit-icons.js +1 -1
- package/dist/js/uikit-icons.min.js +1 -1
- package/dist/js/uikit.js +221 -206
- package/dist/js/uikit.min.js +1 -1
- package/package.json +1 -1
- package/src/js/api/boot.js +6 -7
- package/src/js/api/component.js +4 -4
- package/src/js/api/computed.js +20 -26
- package/src/js/api/observer.js +17 -5
- package/src/js/components/slider-parallax.js +2 -2
- package/src/js/components/slider.js +1 -1
- package/src/js/core/drop.js +1 -2
- package/src/js/core/height-placeholder.js +4 -1
- package/src/js/core/height-viewport.js +1 -1
- package/src/js/core/icon.js +2 -3
- package/src/js/core/img.js +1 -1
- package/src/js/core/inverse.js +13 -6
- package/src/js/core/margin.js +5 -0
- package/src/js/core/modal.js +5 -6
- package/src/js/core/scrollspy.js +0 -3
- package/src/js/core/sticky.js +1 -1
- package/src/js/core/switcher.js +4 -1
- package/src/js/core/toggle.js +6 -3
- package/src/js/mixin/internal/animate-fade.js +2 -7
- package/src/js/mixin/internal/animate-slide.js +2 -7
- package/src/js/mixin/parallax.js +7 -3
- package/src/js/mixin/slider.js +0 -3
- package/src/js/mixin/slideshow.js +3 -0
- package/src/js/util/class.js +1 -1
- package/src/js/util/fastdom.js +6 -13
- package/src/js/util/filter.js +7 -14
- package/src/js/util/lang.js +1 -1
- package/src/js/util/selector.js +33 -24
- package/src/js/util/style.js +2 -4
- package/src/js/util/svg.js +4 -1
- package/src/less/components/utility.less +1 -1
- package/src/scss/components/utility.scss +1 -1
- package/tests/base.html +1 -1
- package/tests/js/index.js +12 -10
- package/tests/switcher.html +86 -86
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.19.5-dev.
|
|
5
|
+
"version": "3.19.5-dev.c70b3862f",
|
|
6
6
|
"main": "dist/js/uikit.js",
|
|
7
7
|
"style": "dist/css/uikit.css",
|
|
8
8
|
"sideEffects": [
|
package/src/js/api/boot.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { apply, hasAttr, inBrowser,
|
|
1
|
+
import { apply, hasAttr, inBrowser, startsWith, trigger } from 'uikit-util';
|
|
2
2
|
import { components, createComponent, getComponent, getComponents } from './component';
|
|
3
3
|
import { callConnected, callDisconnected } from './hooks';
|
|
4
4
|
|
|
@@ -53,16 +53,15 @@ function applyAttributeMutation({ target, attributeName }) {
|
|
|
53
53
|
if (name) {
|
|
54
54
|
if (hasAttr(target, attributeName)) {
|
|
55
55
|
createComponent(name, target);
|
|
56
|
-
|
|
56
|
+
} else {
|
|
57
|
+
getComponent(target, name)?.$destroy();
|
|
57
58
|
}
|
|
58
|
-
|
|
59
|
-
getComponent(target, name)?.$destroy();
|
|
60
59
|
}
|
|
61
60
|
}
|
|
62
61
|
|
|
63
62
|
function connect(node) {
|
|
64
63
|
const components = getComponents(node);
|
|
65
|
-
for (const name in
|
|
64
|
+
for (const name in components) {
|
|
66
65
|
callConnected(components[name]);
|
|
67
66
|
}
|
|
68
67
|
|
|
@@ -74,7 +73,7 @@ function connect(node) {
|
|
|
74
73
|
|
|
75
74
|
function disconnect(node) {
|
|
76
75
|
const components = getComponents(node);
|
|
77
|
-
for (const name in
|
|
76
|
+
for (const name in components) {
|
|
78
77
|
callDisconnected(components[name]);
|
|
79
78
|
}
|
|
80
79
|
}
|
|
@@ -85,5 +84,5 @@ function getComponentName(attribute) {
|
|
|
85
84
|
}
|
|
86
85
|
|
|
87
86
|
const cmp = components[attribute];
|
|
88
|
-
return cmp && (
|
|
87
|
+
return cmp && (cmp.options || cmp).name;
|
|
89
88
|
}
|
package/src/js/api/component.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { camelize, findAll, hyphenate, isEmpty, isPlainObject } from 'uikit-util';
|
|
2
2
|
import App from './app';
|
|
3
3
|
|
|
4
4
|
const PREFIX = 'uk-';
|
|
@@ -10,7 +10,7 @@ export function component(name, options) {
|
|
|
10
10
|
const id = PREFIX + hyphenate(name);
|
|
11
11
|
|
|
12
12
|
if (!options) {
|
|
13
|
-
if (
|
|
13
|
+
if (!components[id].options) {
|
|
14
14
|
components[id] = App.extend(components[id]);
|
|
15
15
|
}
|
|
16
16
|
|
|
@@ -21,7 +21,7 @@ export function component(name, options) {
|
|
|
21
21
|
|
|
22
22
|
App[name] = (element, data) => createComponent(name, element, data);
|
|
23
23
|
|
|
24
|
-
const opt =
|
|
24
|
+
const opt = options.options ?? { ...options };
|
|
25
25
|
|
|
26
26
|
opt.id = id;
|
|
27
27
|
opt.name = name;
|
|
@@ -41,7 +41,7 @@ export function createComponent(name, element, data, ...args) {
|
|
|
41
41
|
return Component.options.functional
|
|
42
42
|
? new Component({ data: isPlainObject(element) ? element : [element, data, ...args] })
|
|
43
43
|
: element
|
|
44
|
-
?
|
|
44
|
+
? findAll(element).map(init)[0]
|
|
45
45
|
: init();
|
|
46
46
|
|
|
47
47
|
function init(element) {
|
package/src/js/api/computed.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { hasOwn, isUndefined } from 'uikit-util';
|
|
2
|
-
import { callUpdate, prependUpdate } from './update';
|
|
3
|
-
import { runWatches } from './watch';
|
|
1
|
+
import { hasOwn, isUndefined, observeMutation } from 'uikit-util';
|
|
2
|
+
import { callUpdate, prependUpdate } from './update.js';
|
|
3
|
+
import { runWatches } from './watch.js';
|
|
4
4
|
|
|
5
5
|
export function initComputed(instance) {
|
|
6
6
|
const { computed } = instance.$options;
|
|
@@ -13,7 +13,7 @@ export function initComputed(instance) {
|
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
|
-
|
|
16
|
+
const mutationOptions = { subtree: true, childList: true };
|
|
17
17
|
export function registerComputed(instance, key, cb) {
|
|
18
18
|
instance._hasComputed = true;
|
|
19
19
|
Object.defineProperty(instance, key, {
|
|
@@ -24,6 +24,15 @@ export function registerComputed(instance, key, cb) {
|
|
|
24
24
|
|
|
25
25
|
if (!hasOwn(_computed, key)) {
|
|
26
26
|
_computed[key] = (cb.get || cb).call(instance, $props, $el);
|
|
27
|
+
if (cb.observe && instance._computedObserver) {
|
|
28
|
+
const selector = cb.observe.call(instance, $props);
|
|
29
|
+
instance._computedObserver.observe(
|
|
30
|
+
['~', '+', '-'].includes(selector[0])
|
|
31
|
+
? $el.parentElement
|
|
32
|
+
: $el.getRootNode(),
|
|
33
|
+
mutationOptions,
|
|
34
|
+
);
|
|
35
|
+
}
|
|
27
36
|
}
|
|
28
37
|
|
|
29
38
|
return _computed[key];
|
|
@@ -51,12 +60,16 @@ export function initComputedUpdates(instance) {
|
|
|
51
60
|
events: ['resize', 'computed'],
|
|
52
61
|
});
|
|
53
62
|
|
|
54
|
-
|
|
55
|
-
|
|
63
|
+
instance._computedObserver = observeMutation(
|
|
64
|
+
instance.$el,
|
|
65
|
+
() => callUpdate(instance, 'computed'),
|
|
66
|
+
mutationOptions,
|
|
67
|
+
);
|
|
56
68
|
}
|
|
57
69
|
|
|
58
70
|
export function disconnectComputedUpdates(instance) {
|
|
59
|
-
|
|
71
|
+
instance._computedObserver?.disconnect();
|
|
72
|
+
delete instance._computedObserver;
|
|
60
73
|
resetComputed(instance);
|
|
61
74
|
}
|
|
62
75
|
|
|
@@ -65,22 +78,3 @@ function resetComputed(instance) {
|
|
|
65
78
|
instance._computed = {};
|
|
66
79
|
return values;
|
|
67
80
|
}
|
|
68
|
-
|
|
69
|
-
let observer;
|
|
70
|
-
let instances;
|
|
71
|
-
function registerComputedObserver() {
|
|
72
|
-
if (observer) {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
instances = new Set();
|
|
77
|
-
observer = new MutationObserver(() => {
|
|
78
|
-
for (const instance of instances) {
|
|
79
|
-
callUpdate(instance, 'computed');
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
observer.observe(document, {
|
|
83
|
-
subtree: true,
|
|
84
|
-
childList: true,
|
|
85
|
-
});
|
|
86
|
-
}
|
package/src/js/api/observer.js
CHANGED
|
@@ -46,21 +46,33 @@ function registerObservable(instance, observable) {
|
|
|
46
46
|
const targets = hasOwn(instance, key) ? instance[key] : target;
|
|
47
47
|
const observer = observe(targets, handler, options, args);
|
|
48
48
|
|
|
49
|
-
if (isFunction(target) && isArray(instance[key])
|
|
50
|
-
registerWatch(
|
|
49
|
+
if (isFunction(target) && isArray(instance[key])) {
|
|
50
|
+
registerWatch(
|
|
51
|
+
instance,
|
|
52
|
+
{ handler: updateTargets(observer, options), immediate: false },
|
|
53
|
+
key,
|
|
54
|
+
);
|
|
51
55
|
}
|
|
52
56
|
|
|
53
57
|
registerObserver(instance, observer);
|
|
54
58
|
}
|
|
55
59
|
|
|
56
|
-
function updateTargets(observer) {
|
|
60
|
+
function updateTargets(observer, options) {
|
|
57
61
|
return (targets, prev) => {
|
|
58
62
|
for (const target of prev) {
|
|
59
|
-
!includes(targets, target)
|
|
63
|
+
if (!includes(targets, target)) {
|
|
64
|
+
if (observer.unobserve) {
|
|
65
|
+
observer.unobserve(target);
|
|
66
|
+
} else if (observer.observe) {
|
|
67
|
+
observer.disconnect();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
60
70
|
}
|
|
61
71
|
|
|
62
72
|
for (const target of targets) {
|
|
63
|
-
!includes(prev, target)
|
|
73
|
+
if (!includes(prev, target) || !observer.unobserve) {
|
|
74
|
+
observer.observe(target, options);
|
|
75
|
+
}
|
|
64
76
|
}
|
|
65
77
|
};
|
|
66
78
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { css, endsWith, fastdom, noop, Transition } from 'uikit-util';
|
|
2
2
|
import Parallax from '../mixin/parallax';
|
|
3
3
|
|
|
4
4
|
export default {
|
|
5
5
|
mixins: [Parallax],
|
|
6
6
|
|
|
7
7
|
beforeConnect() {
|
|
8
|
-
this.item =
|
|
8
|
+
this.item = this.$el.closest(`.${this.$options.id.replace('parallax', 'items')} > *`);
|
|
9
9
|
},
|
|
10
10
|
|
|
11
11
|
disconnected() {
|
package/src/js/core/drop.js
CHANGED
|
@@ -27,7 +27,6 @@ import {
|
|
|
27
27
|
pointerUp,
|
|
28
28
|
query,
|
|
29
29
|
removeClass,
|
|
30
|
-
within,
|
|
31
30
|
} from 'uikit-util';
|
|
32
31
|
import Container from '../mixin/container';
|
|
33
32
|
import Position from '../mixin/position';
|
|
@@ -513,7 +512,7 @@ function listenForBackgroundClose(drop) {
|
|
|
513
512
|
!defaultPrevented &&
|
|
514
513
|
type === pointerUp &&
|
|
515
514
|
target === newTarget &&
|
|
516
|
-
!
|
|
515
|
+
!drop.targetEl?.contains(target)
|
|
517
516
|
) {
|
|
518
517
|
drop.hide(false);
|
|
519
518
|
}
|
|
@@ -13,7 +13,10 @@ export default {
|
|
|
13
13
|
},
|
|
14
14
|
|
|
15
15
|
computed: {
|
|
16
|
-
target:
|
|
16
|
+
target: {
|
|
17
|
+
get: ({ target }, $el) => query(target, $el),
|
|
18
|
+
observe: ({ target }) => target,
|
|
19
|
+
},
|
|
17
20
|
},
|
|
18
21
|
|
|
19
22
|
observe: resize({ target: ({ target }) => target }),
|
|
@@ -68,7 +68,7 @@ export default {
|
|
|
68
68
|
offsetPosition(offsetTopEl)[0] - offsetPosition(scrollElement)[0];
|
|
69
69
|
minHeight += top > 0 && top < viewportHeight / 2 ? ` - ${top}px` : '';
|
|
70
70
|
} else {
|
|
71
|
-
minHeight += ` - ${css(scrollElement, '
|
|
71
|
+
minHeight += ` - ${boxModelAdjust(scrollElement, 'height', css(scrollElement, 'boxSizing'))}px`;
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
74
|
|
package/src/js/core/icon.js
CHANGED
|
@@ -3,7 +3,6 @@ import {
|
|
|
3
3
|
addClass,
|
|
4
4
|
apply,
|
|
5
5
|
attr,
|
|
6
|
-
closest,
|
|
7
6
|
css,
|
|
8
7
|
each,
|
|
9
8
|
hasAttr,
|
|
@@ -126,9 +125,9 @@ export const Search = {
|
|
|
126
125
|
hasClass(this.$el, 'uk-search-toggle') || hasClass(this.$el, 'uk-navbar-toggle');
|
|
127
126
|
this.icon = isToggle
|
|
128
127
|
? 'search-toggle-icon'
|
|
129
|
-
: hasClass(this.$el, 'uk-search-icon') &&
|
|
128
|
+
: hasClass(this.$el, 'uk-search-icon') && this.$el.closest('.uk-search-large')
|
|
130
129
|
? 'search-large'
|
|
131
|
-
:
|
|
130
|
+
: this.$el.closest('.uk-search-navbar')
|
|
132
131
|
? 'search-navbar'
|
|
133
132
|
: this.$props.icon;
|
|
134
133
|
|
package/src/js/core/img.js
CHANGED
|
@@ -56,13 +56,13 @@ export default {
|
|
|
56
56
|
},
|
|
57
57
|
|
|
58
58
|
observe: intersection({
|
|
59
|
-
target: ({ $el, $props }) => [$el, ...queryAll($props.target, $el)],
|
|
60
59
|
handler(entries, observer) {
|
|
61
60
|
this.load();
|
|
62
61
|
observer.disconnect();
|
|
63
62
|
},
|
|
64
63
|
options: ({ margin }) => ({ rootMargin: margin }),
|
|
65
64
|
filter: ({ loading }) => loading === 'lazy',
|
|
65
|
+
target: ({ $el, $props }) => ($props.target ? [$el, ...queryAll($props.target, $el)] : $el),
|
|
66
66
|
}),
|
|
67
67
|
|
|
68
68
|
methods: {
|
package/src/js/core/inverse.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { $$, css, dimensions, matches, observeResize, on, replaceClass } from 'uikit-util';
|
|
1
|
+
import { $$, css, dimensions, matches, observeResize, on, replaceClass, toNodes } from 'uikit-util';
|
|
2
2
|
import { intersection, mutation } from '../api/observables';
|
|
3
3
|
|
|
4
4
|
export default {
|
|
@@ -13,14 +13,16 @@ export default {
|
|
|
13
13
|
},
|
|
14
14
|
|
|
15
15
|
computed: {
|
|
16
|
-
target: ({ target }, $el) => (target ? $$(target, $el) :
|
|
16
|
+
target: ({ target }, $el) => (target ? $$(target, $el) : $el),
|
|
17
17
|
},
|
|
18
18
|
|
|
19
19
|
observe: [
|
|
20
20
|
intersection({
|
|
21
|
-
handler(
|
|
22
|
-
this.isIntersecting = isIntersecting;
|
|
21
|
+
handler(entries) {
|
|
22
|
+
this.isIntersecting = entries.some(({ isIntersecting }) => isIntersecting);
|
|
23
|
+
this.$emit();
|
|
23
24
|
},
|
|
25
|
+
target: ({ target }) => target,
|
|
24
26
|
args: { intersecting: false },
|
|
25
27
|
}),
|
|
26
28
|
mutation({
|
|
@@ -30,7 +32,10 @@ export default {
|
|
|
30
32
|
{
|
|
31
33
|
target: ({ target }) => target,
|
|
32
34
|
observe: (target, handler) => {
|
|
33
|
-
const observer = observeResize(
|
|
35
|
+
const observer = observeResize(
|
|
36
|
+
[...toNodes(target), document.documentElement],
|
|
37
|
+
handler,
|
|
38
|
+
);
|
|
34
39
|
const listener = [
|
|
35
40
|
on(document, 'scroll itemshown itemhidden', handler, {
|
|
36
41
|
passive: true,
|
|
@@ -47,6 +52,8 @@ export default {
|
|
|
47
52
|
];
|
|
48
53
|
|
|
49
54
|
return {
|
|
55
|
+
observe: observer.observe.bind(observer),
|
|
56
|
+
unobserve: observer.unobserve.bind(observer),
|
|
50
57
|
disconnect() {
|
|
51
58
|
observer.disconnect();
|
|
52
59
|
listener.map((off) => off());
|
|
@@ -65,7 +72,7 @@ export default {
|
|
|
65
72
|
return false;
|
|
66
73
|
}
|
|
67
74
|
|
|
68
|
-
for (const target of this.target) {
|
|
75
|
+
for (const target of toNodes(this.target)) {
|
|
69
76
|
replaceClass(
|
|
70
77
|
target,
|
|
71
78
|
'uk-light,uk-dark',
|
package/src/js/core/margin.js
CHANGED
package/src/js/core/modal.js
CHANGED
|
@@ -70,12 +70,11 @@ export default {
|
|
|
70
70
|
|
|
71
71
|
function install({ modal }) {
|
|
72
72
|
modal.dialog = function (content, options) {
|
|
73
|
-
const dialog = modal(
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
);
|
|
73
|
+
const dialog = modal($(`<div><div class="uk-modal-dialog">${content}</div></div>`), {
|
|
74
|
+
stack: true,
|
|
75
|
+
role: 'alertdialog',
|
|
76
|
+
...options,
|
|
77
|
+
});
|
|
79
78
|
|
|
80
79
|
dialog.show();
|
|
81
80
|
|
package/src/js/core/scrollspy.js
CHANGED
package/src/js/core/sticky.js
CHANGED
package/src/js/core/switcher.js
CHANGED
|
@@ -50,7 +50,10 @@ export default {
|
|
|
50
50
|
},
|
|
51
51
|
|
|
52
52
|
computed: {
|
|
53
|
-
connects:
|
|
53
|
+
connects: {
|
|
54
|
+
get: ({ connect }, $el) => queryAll(connect, $el),
|
|
55
|
+
observe: ({ connect }) => connect,
|
|
56
|
+
},
|
|
54
57
|
|
|
55
58
|
connectChildren() {
|
|
56
59
|
return this.connects.map((el) => children(el)).flat();
|
package/src/js/core/toggle.js
CHANGED
|
@@ -41,9 +41,12 @@ export default {
|
|
|
41
41
|
},
|
|
42
42
|
|
|
43
43
|
computed: {
|
|
44
|
-
target
|
|
45
|
-
|
|
46
|
-
|
|
44
|
+
target: {
|
|
45
|
+
get: ({ target }, $el) => {
|
|
46
|
+
target = queryAll(target || $el.hash, $el);
|
|
47
|
+
return target.length ? target : [$el];
|
|
48
|
+
},
|
|
49
|
+
observe: ({ target }) => target,
|
|
47
50
|
},
|
|
48
51
|
},
|
|
49
52
|
|
|
@@ -11,6 +11,7 @@ import {
|
|
|
11
11
|
Transition,
|
|
12
12
|
} from 'uikit-util';
|
|
13
13
|
import { getRows } from '../../core/margin';
|
|
14
|
+
import { awaitFrame } from './animate-slide.js';
|
|
14
15
|
|
|
15
16
|
const clsLeave = 'uk-transition-leave';
|
|
16
17
|
const clsEnter = 'uk-transition-enter';
|
|
@@ -117,13 +118,7 @@ function waitTransitionend(target) {
|
|
|
117
118
|
}
|
|
118
119
|
|
|
119
120
|
function getTransitionNodes(target) {
|
|
120
|
-
return getRows(children(target))
|
|
121
|
-
.flat()
|
|
122
|
-
.filter((node) => isVisible(node));
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
function awaitFrame() {
|
|
126
|
-
return new Promise((resolve) => requestAnimationFrame(resolve));
|
|
121
|
+
return getRows(children(target)).flat().filter(isVisible);
|
|
127
122
|
}
|
|
128
123
|
|
|
129
124
|
function awaitTimeout(timeout) {
|
|
@@ -2,7 +2,6 @@ import {
|
|
|
2
2
|
attr,
|
|
3
3
|
children,
|
|
4
4
|
css,
|
|
5
|
-
fastdom,
|
|
6
5
|
includes,
|
|
7
6
|
index,
|
|
8
7
|
isVisible,
|
|
@@ -26,7 +25,7 @@ export default async function (action, target, duration) {
|
|
|
26
25
|
await Promise.all(nodes.concat(target).map(Transition.cancel));
|
|
27
26
|
|
|
28
27
|
// Adding, sorting, removing nodes
|
|
29
|
-
action();
|
|
28
|
+
await action();
|
|
30
29
|
|
|
31
30
|
// Find new nodes
|
|
32
31
|
nodes = nodes.concat(children(target).filter((el) => !includes(nodes, el)));
|
|
@@ -34,9 +33,6 @@ export default async function (action, target, duration) {
|
|
|
34
33
|
// Wait for update to propagate
|
|
35
34
|
await Promise.resolve();
|
|
36
35
|
|
|
37
|
-
// Force update
|
|
38
|
-
fastdom.flush();
|
|
39
|
-
|
|
40
36
|
// Get new state
|
|
41
37
|
const targetStyle = attr(target, 'style');
|
|
42
38
|
const targetPropsTo = css(target, ['height', 'padding']);
|
|
@@ -49,7 +45,6 @@ export default async function (action, target, duration) {
|
|
|
49
45
|
|
|
50
46
|
// Trigger update in e.g. parallax component
|
|
51
47
|
trigger(target, 'scroll');
|
|
52
|
-
fastdom.flush();
|
|
53
48
|
|
|
54
49
|
// Start transitions on next frame
|
|
55
50
|
await awaitFrame();
|
|
@@ -142,6 +137,6 @@ function getPositionWithMargin(el) {
|
|
|
142
137
|
};
|
|
143
138
|
}
|
|
144
139
|
|
|
145
|
-
function awaitFrame() {
|
|
140
|
+
export function awaitFrame() {
|
|
146
141
|
return new Promise((resolve) => requestAnimationFrame(resolve));
|
|
147
142
|
}
|
package/src/js/mixin/parallax.js
CHANGED
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
isString,
|
|
8
8
|
isUndefined,
|
|
9
9
|
noop,
|
|
10
|
+
once,
|
|
10
11
|
propName,
|
|
11
12
|
toFloat,
|
|
12
13
|
toPx,
|
|
@@ -271,6 +272,7 @@ function setBackgroundPosFn(bgProps, positions, props) {
|
|
|
271
272
|
};
|
|
272
273
|
}
|
|
273
274
|
|
|
275
|
+
const loading = {};
|
|
274
276
|
const dimensions = {};
|
|
275
277
|
function getBackgroundImageDimensions(el) {
|
|
276
278
|
const src = css(el, 'backgroundImage').replace(/^none|url\(["']?(.+?)["']?\)$/, '$1');
|
|
@@ -283,11 +285,13 @@ function getBackgroundImageDimensions(el) {
|
|
|
283
285
|
if (src) {
|
|
284
286
|
image.src = src;
|
|
285
287
|
|
|
286
|
-
if (!image.naturalWidth) {
|
|
287
|
-
image
|
|
288
|
+
if (!image.naturalWidth && !loading[src]) {
|
|
289
|
+
once(image, 'error load', () => {
|
|
288
290
|
dimensions[src] = toDimensions(image);
|
|
289
291
|
trigger(el, createEvent('load', false));
|
|
290
|
-
};
|
|
292
|
+
});
|
|
293
|
+
loading[src] = true;
|
|
294
|
+
|
|
291
295
|
return toDimensions(image);
|
|
292
296
|
}
|
|
293
297
|
}
|
package/src/js/mixin/slider.js
CHANGED
|
@@ -10,7 +10,6 @@ import {
|
|
|
10
10
|
removeClass,
|
|
11
11
|
trigger,
|
|
12
12
|
} from 'uikit-util';
|
|
13
|
-
import { resize } from '../api/observables';
|
|
14
13
|
import I18n from './i18n';
|
|
15
14
|
import SliderAutoplay from './slider-autoplay';
|
|
16
15
|
import SliderDrag from './slider-drag';
|
|
@@ -80,8 +79,6 @@ export default {
|
|
|
80
79
|
},
|
|
81
80
|
},
|
|
82
81
|
|
|
83
|
-
observe: resize(),
|
|
84
|
-
|
|
85
82
|
events: {
|
|
86
83
|
itemshow({ target }) {
|
|
87
84
|
addClass(target, this.clsEnter, this.clsSlideActive);
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { addClass, removeClass } from 'uikit-util';
|
|
2
|
+
import { resize } from '../api/observables.js';
|
|
2
3
|
import Animations from './internal/slideshow-animations';
|
|
3
4
|
import Transitioner from './internal/slideshow-transitioner';
|
|
4
5
|
import Slider from './slider.js';
|
|
@@ -27,6 +28,8 @@ export default {
|
|
|
27
28
|
},
|
|
28
29
|
},
|
|
29
30
|
|
|
31
|
+
observe: resize(),
|
|
32
|
+
|
|
30
33
|
events: {
|
|
31
34
|
beforeitemshow({ target }) {
|
|
32
35
|
addClass(target, this.clsActive);
|
package/src/js/util/class.js
CHANGED
package/src/js/util/fastdom.js
CHANGED
|
@@ -28,28 +28,21 @@ export const fastdom = {
|
|
|
28
28
|
flush,
|
|
29
29
|
};
|
|
30
30
|
|
|
31
|
-
function flush(
|
|
31
|
+
function flush() {
|
|
32
32
|
runTasks(fastdom.reads);
|
|
33
33
|
runTasks(fastdom.writes.splice(0));
|
|
34
34
|
|
|
35
35
|
fastdom.scheduled = false;
|
|
36
36
|
|
|
37
37
|
if (fastdom.reads.length || fastdom.writes.length) {
|
|
38
|
-
scheduleFlush(
|
|
38
|
+
scheduleFlush();
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
fastdom.scheduled = true;
|
|
49
|
-
if (recursion && recursion < RECURSION_LIMIT) {
|
|
50
|
-
Promise.resolve().then(() => flush(recursion));
|
|
51
|
-
} else {
|
|
52
|
-
requestAnimationFrame(() => flush(1));
|
|
42
|
+
function scheduleFlush() {
|
|
43
|
+
if (!fastdom.scheduled) {
|
|
44
|
+
fastdom.scheduled = true;
|
|
45
|
+
queueMicrotask(flush);
|
|
53
46
|
}
|
|
54
47
|
}
|
|
55
48
|
|
package/src/js/util/filter.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { toArray, toNode, toNodes } from './lang';
|
|
2
2
|
|
|
3
3
|
const voidElements = {
|
|
4
4
|
area: true,
|
|
@@ -21,10 +21,13 @@ export function isVoidElement(element) {
|
|
|
21
21
|
return toNodes(element).some((element) => voidElements[element.tagName.toLowerCase()]);
|
|
22
22
|
}
|
|
23
23
|
|
|
24
|
+
const isVisibleFn =
|
|
25
|
+
Element.prototype.checkVisibility ||
|
|
26
|
+
function () {
|
|
27
|
+
return this.offsetWidth || this.offsetHeight || this.getClientRects().length;
|
|
28
|
+
};
|
|
24
29
|
export function isVisible(element) {
|
|
25
|
-
return toNodes(element).some(
|
|
26
|
-
(element) => element.offsetWidth || element.offsetHeight || element.getClientRects().length,
|
|
27
|
-
);
|
|
30
|
+
return toNodes(element).some((element) => isVisibleFn.call(element));
|
|
28
31
|
}
|
|
29
32
|
|
|
30
33
|
export const selInput = 'input,select,textarea,button';
|
|
@@ -49,16 +52,6 @@ export function matches(element, selector) {
|
|
|
49
52
|
return toNodes(element).some((element) => element.matches(selector));
|
|
50
53
|
}
|
|
51
54
|
|
|
52
|
-
export function closest(element, selector) {
|
|
53
|
-
return toNode(element)?.closest(startsWith(selector, '>') ? selector.slice(1) : selector);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export function within(element, selector) {
|
|
57
|
-
return isString(selector)
|
|
58
|
-
? !!closest(element, selector)
|
|
59
|
-
: toNode(selector).contains(toNode(element));
|
|
60
|
-
}
|
|
61
|
-
|
|
62
55
|
export function parents(element, selector) {
|
|
63
56
|
const elements = [];
|
|
64
57
|
|