uikit 3.19.5-dev.520984f53 → 3.19.5-dev.5db24934f

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 (61) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/dist/css/uikit-core-rtl.css +2 -2
  3. package/dist/css/uikit-core-rtl.min.css +1 -1
  4. package/dist/css/uikit-core.css +2 -2
  5. package/dist/css/uikit-core.min.css +1 -1
  6. package/dist/css/uikit-rtl.css +2 -2
  7. package/dist/css/uikit-rtl.min.css +1 -1
  8. package/dist/css/uikit.css +2 -2
  9. package/dist/css/uikit.min.css +1 -1
  10. package/dist/js/components/countdown.js +1 -1
  11. package/dist/js/components/countdown.min.js +1 -1
  12. package/dist/js/components/filter.js +2 -2
  13. package/dist/js/components/filter.min.js +1 -1
  14. package/dist/js/components/lightbox-panel.js +1 -1
  15. package/dist/js/components/lightbox-panel.min.js +1 -1
  16. package/dist/js/components/lightbox.js +1 -1
  17. package/dist/js/components/lightbox.min.js +1 -1
  18. package/dist/js/components/notification.js +1 -1
  19. package/dist/js/components/notification.min.js +1 -1
  20. package/dist/js/components/parallax.js +20 -14
  21. package/dist/js/components/parallax.min.js +1 -1
  22. package/dist/js/components/slider-parallax.js +21 -15
  23. package/dist/js/components/slider-parallax.min.js +1 -1
  24. package/dist/js/components/slider.js +20 -14
  25. package/dist/js/components/slider.min.js +1 -1
  26. package/dist/js/components/slideshow-parallax.js +21 -15
  27. package/dist/js/components/slideshow-parallax.min.js +1 -1
  28. package/dist/js/components/slideshow.js +20 -14
  29. package/dist/js/components/slideshow.min.js +1 -1
  30. package/dist/js/components/sortable.js +2 -2
  31. package/dist/js/components/sortable.min.js +1 -1
  32. package/dist/js/components/tooltip.js +1 -1
  33. package/dist/js/components/tooltip.min.js +1 -1
  34. package/dist/js/components/upload.js +1 -1
  35. package/dist/js/components/upload.min.js +1 -1
  36. package/dist/js/uikit-core.js +69 -56
  37. package/dist/js/uikit-core.min.js +1 -1
  38. package/dist/js/uikit-icons.js +1 -1
  39. package/dist/js/uikit-icons.min.js +1 -1
  40. package/dist/js/uikit.js +76 -61
  41. package/dist/js/uikit.min.js +1 -1
  42. package/package.json +1 -1
  43. package/src/js/api/computed.js +24 -23
  44. package/src/js/api/observer.js +1 -1
  45. package/src/js/components/slider-parallax.js +2 -2
  46. package/src/js/core/drop.js +1 -2
  47. package/src/js/core/height-placeholder.js +5 -2
  48. package/src/js/core/height-viewport.js +1 -1
  49. package/src/js/core/icon.js +2 -3
  50. package/src/js/core/inverse.js +2 -0
  51. package/src/js/core/modal.js +5 -6
  52. package/src/js/core/sticky.js +1 -1
  53. package/src/js/core/switcher.js +5 -1
  54. package/src/js/core/toggle.js +7 -3
  55. package/src/js/mixin/internal/animate-fade.js +1 -3
  56. package/src/js/mixin/parallax.js +7 -3
  57. package/src/js/util/filter.js +7 -14
  58. package/src/js/util/selector.js +15 -10
  59. package/src/less/components/utility.less +1 -1
  60. package/src/scss/components/utility.scss +1 -1
  61. package/tests/js/index.js +12 -10
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.520984f53",
5
+ "version": "3.19.5-dev.5db24934f",
6
6
  "main": "dist/js/uikit.js",
7
7
  "style": "dist/css/uikit.css",
8
8
  "sideEffects": [
@@ -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 observeEl = cb.observe.call(instance, _computed[key]);
29
+ if (observeEl && observeEl !== $el) {
30
+ instance._computedObserver.observe(
31
+ commonAncestor(observeEl, $el),
32
+ mutationOptions,
33
+ );
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
- registerComputedObserver();
55
- instances.add(instance);
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
- instances?.delete(instance);
71
+ instance._computedObserver?.disconnect();
72
+ delete instance._computedObserver;
60
73
  resetComputed(instance);
61
74
  }
62
75
 
@@ -66,21 +79,9 @@ function resetComputed(instance) {
66
79
  return values;
67
80
  }
68
81
 
69
- let observer;
70
- let instances;
71
- function registerComputedObserver() {
72
- if (observer) {
73
- return;
82
+ function commonAncestor(element1, element2) {
83
+ while (element1 && !element1.contains(element2)) {
84
+ element1 = element1.parentNode;
74
85
  }
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
+ return element1;
86
87
  }
@@ -63,7 +63,7 @@ function updateTargets(observer, options) {
63
63
  if (!includes(targets, target)) {
64
64
  if (observer.unobserve) {
65
65
  observer.unobserve(target);
66
- } else {
66
+ } else if (observer.observe) {
67
67
  observer.disconnect();
68
68
  }
69
69
  }
@@ -1,11 +1,11 @@
1
- import { closest, css, endsWith, fastdom, noop, Transition } from 'uikit-util';
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 = closest(this.$el, `.${this.$options.id.replace('parallax', 'items')} > *`);
8
+ this.item = this.$el.closest(`.${this.$options.id.replace('parallax', 'items')} > *`);
9
9
  },
10
10
 
11
11
  disconnected() {
@@ -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
- !(drop.targetEl && within(target, drop.targetEl))
515
+ !drop.targetEl?.contains(target)
517
516
  ) {
518
517
  drop.hide(false);
519
518
  }
@@ -1,4 +1,4 @@
1
- import { css, query } from 'uikit-util';
1
+ import { css, parent, query } from 'uikit-util';
2
2
  import { resize } from '../api/observables';
3
3
 
4
4
  export default {
@@ -13,7 +13,10 @@ export default {
13
13
  },
14
14
 
15
15
  computed: {
16
- target: ({ target }, $el) => query(target, $el),
16
+ target: {
17
+ get: ({ target }, $el) => query(target, $el),
18
+ observe: (target) => parent(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, 'paddingTop')}`;
71
+ minHeight += ` - ${boxModelAdjust(scrollElement, 'height', css(scrollElement, 'boxSizing'))}px`;
72
72
  }
73
73
  }
74
74
 
@@ -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') && closest(this.$el, '.uk-search-large')
128
+ : hasClass(this.$el, 'uk-search-icon') && this.$el.closest('.uk-search-large')
130
129
  ? 'search-large'
131
- : closest(this.$el, '.uk-search-navbar')
130
+ : this.$el.closest('.uk-search-navbar')
132
131
  ? 'search-navbar'
133
132
  : this.$props.icon;
134
133
 
@@ -52,6 +52,8 @@ export default {
52
52
  ];
53
53
 
54
54
  return {
55
+ observe: observer.observe.bind(observer),
56
+ unobserve: observer.unobserve.bind(observer),
55
57
  disconnect() {
56
58
  observer.disconnect();
57
59
  listener.map((off) => off());
@@ -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
- `<div class="uk-modal">
75
- <div class="uk-modal-dialog">${content}</div>
76
- </div>`,
77
- { stack: true, role: 'alertdialog', ...options },
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
 
@@ -109,7 +109,7 @@ export default {
109
109
  target: () => document.scrollingElement,
110
110
  options: { box: 'content-box' },
111
111
  }),
112
- resize({ target: ({ $el }) => $el }),
112
+ resize(),
113
113
  ],
114
114
 
115
115
  events: [
@@ -12,6 +12,7 @@ import {
12
12
  isNode,
13
13
  isTag,
14
14
  matches,
15
+ parent,
15
16
  queryAll,
16
17
  toArray,
17
18
  toggleClass,
@@ -50,7 +51,10 @@ export default {
50
51
  },
51
52
 
52
53
  computed: {
53
- connects: ({ connect }, $el) => queryAll(connect, $el),
54
+ connects: {
55
+ get: ({ connect }, $el) => queryAll(connect, $el),
56
+ observe: (connects) => parent(connects[0]),
57
+ },
54
58
 
55
59
  connectChildren() {
56
60
  return this.connects.map((el) => children(el)).flat();
@@ -9,6 +9,7 @@ import {
9
9
  isTouch,
10
10
  matches,
11
11
  once,
12
+ parent,
12
13
  pointerDown,
13
14
  pointerEnter,
14
15
  pointerLeave,
@@ -41,9 +42,12 @@ export default {
41
42
  },
42
43
 
43
44
  computed: {
44
- target({ target }, $el) {
45
- target = queryAll(target || $el.hash, $el);
46
- return target.length ? target : [$el];
45
+ target: {
46
+ get: ({ target }, $el) => {
47
+ target = queryAll(target || $el.hash, $el);
48
+ return target.length ? target : [$el];
49
+ },
50
+ observe: (target) => parent(target[0]),
47
51
  },
48
52
  },
49
53
 
@@ -117,9 +117,7 @@ function waitTransitionend(target) {
117
117
  }
118
118
 
119
119
  function getTransitionNodes(target) {
120
- return getRows(children(target))
121
- .flat()
122
- .filter((node) => isVisible(node));
120
+ return getRows(children(target)).flat().filter(isVisible);
123
121
  }
124
122
 
125
123
  function awaitFrame() {
@@ -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.onload = () => {
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
  }
@@ -1,4 +1,4 @@
1
- import { isString, startsWith, toArray, toNode, toNodes } from './lang';
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
 
@@ -49,6 +49,12 @@ const parseSelector = memoize((selector) => {
49
49
  };
50
50
  });
51
51
 
52
+ const parsePositionSelector = memoize((selector) => {
53
+ selector = selector.substr(1).trim();
54
+ const index = selector.indexOf(' ');
55
+ return ~index ? [selector.substring(0, index), selector.substring(index + 1)] : [selector, ''];
56
+ });
57
+
52
58
  function _query(selector, context = document, queryFn) {
53
59
  if (!selector || !isString(selector)) {
54
60
  return selector;
@@ -63,23 +69,22 @@ function _query(selector, context = document, queryFn) {
63
69
  selector = '';
64
70
  const isSingle = parsed.selectors.length === 1;
65
71
  for (let sel of parsed.selectors) {
72
+ let positionSel;
66
73
  let ctx = context;
67
74
 
68
75
  if (sel[0] === '!') {
69
- const selectors = sel.substr(1).trim().split(' ');
70
- ctx = context.parentElement.closest(selectors[0]);
71
- sel = selectors.slice(1).join(' ').trim();
72
- if (!sel.length && isSingle) {
76
+ [positionSel, sel] = parsePositionSelector(sel);
77
+ ctx = context.parentElement.closest(positionSel);
78
+ if (!sel && isSingle) {
73
79
  return ctx;
74
80
  }
75
81
  }
76
82
 
77
- if (sel[0] === '-') {
78
- const selectors = sel.substr(1).trim().split(' ');
79
- const prev = (ctx || context).previousElementSibling;
80
- ctx = matches(prev, sel.substr(1)) ? prev : null;
81
- sel = selectors.slice(1).join(' ');
82
- if (!sel.length && isSingle) {
83
+ if (ctx && sel[0] === '-') {
84
+ [positionSel, sel] = parsePositionSelector(sel);
85
+ ctx = ctx.previousElementSibling;
86
+ ctx = matches(ctx, positionSel) ? ctx : null;
87
+ if (!sel && isSingle) {
83
88
  return ctx;
84
89
  }
85
90
  } else if (sel[0] === '~' || (sel[0] === '+' && isSingle)) {
@@ -129,7 +129,7 @@
129
129
  [class*="uk-float-"] { max-width: 100%; }
130
130
 
131
131
 
132
- /* Overfow
132
+ /* Overflow
133
133
  ========================================================================== */
134
134
 
135
135
  .uk-overflow-hidden { overflow: hidden; }
@@ -111,7 +111,7 @@
111
111
  [class*="uk-float-"] { max-width: 100%; }
112
112
 
113
113
 
114
- /* Overfow
114
+ /* Overflow
115
115
  ========================================================================== */
116
116
 
117
117
  .uk-overflow-hidden { overflow: hidden; }
package/tests/js/index.js CHANGED
@@ -5,7 +5,6 @@ const tests = TESTS;
5
5
  const storage = window.sessionStorage;
6
6
  const key = '_uikit_style';
7
7
  const keyinverse = '_uikit_inverse';
8
- const docEl = document.documentElement;
9
8
 
10
9
  // try to load themes.json
11
10
  const request = new XMLHttpRequest();
@@ -39,7 +38,7 @@ storage[keyinverse] = storage[keyinverse] || '';
39
38
  const dir = storage._uikit_dir || 'ltr';
40
39
 
41
40
  // set dir
42
- docEl.dir = dir;
41
+ document.documentElement.dir = dir;
43
42
 
44
43
  const style = styles[storage[key]] || styles.theme;
45
44
 
@@ -50,6 +49,10 @@ document.writeln(
50
49
  }">`,
51
50
  );
52
51
 
52
+ document.writeln(
53
+ `<style>body:not(:has([aria-label="Component switcher"])) {padding-top: 80px}</style>`,
54
+ );
55
+
53
56
  // add javascript
54
57
  document.writeln('<script src="../dist/js/uikit.js"></script>');
55
58
  document.writeln(
@@ -60,9 +63,8 @@ on(window, 'load', () =>
60
63
  setTimeout(
61
64
  () =>
62
65
  requestAnimationFrame(() => {
63
- const $body = document.body;
64
66
  const $container = prepend(
65
- $body,
67
+ document.body,
66
68
  `
67
69
  <div class="uk-container">
68
70
  <select class="uk-select uk-form-width-small" style="margin: 20px 20px 20px 0" aria-label="Component switcher">
@@ -144,8 +146,12 @@ on(window, 'load', () =>
144
146
 
145
147
  addClass($$('.uk-navbar-container'), 'uk-navbar-transparent');
146
148
 
147
- css(docEl, 'background', $inverse.value === 'dark' ? '#fff' : '#222');
148
- addClass($body, `uk-${$inverse.value}`);
149
+ css(
150
+ document.documentElement,
151
+ 'background',
152
+ $inverse.value === 'dark' ? '#fff' : '#222',
153
+ );
154
+ addClass(document.body, `uk-${$inverse.value}`);
149
155
  }
150
156
 
151
157
  on($inverse, 'change', () => {
@@ -161,15 +167,11 @@ on(window, 'load', () =>
161
167
  location.reload();
162
168
  });
163
169
  $rtl.firstElementChild.checked = dir === 'rtl';
164
-
165
- css(docEl, 'paddingTop', '');
166
170
  }),
167
171
  100,
168
172
  ),
169
173
  );
170
174
 
171
- css(docEl, 'paddingTop', '80px');
172
-
173
175
  function getParam(name) {
174
176
  const match = new RegExp(`[?&]${name}=([^&]*)`).exec(window.location.search);
175
177
  return match && decodeURIComponent(match[1].replace(/\+/g, ' '));