uikit 3.21.14-dev.028df7be8 → 3.21.14-dev.2e8a07c7e

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 (140) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/dist/css/uikit-core-rtl.css +233 -85
  3. package/dist/css/uikit-core-rtl.min.css +1 -1
  4. package/dist/css/uikit-core.css +233 -85
  5. package/dist/css/uikit-core.min.css +1 -1
  6. package/dist/css/uikit-rtl.css +237 -81
  7. package/dist/css/uikit-rtl.min.css +1 -1
  8. package/dist/css/uikit.css +237 -81
  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 -11
  13. package/dist/js/components/filter.min.js +1 -1
  14. package/dist/js/components/lightbox-panel.js +425 -126
  15. package/dist/js/components/lightbox-panel.min.js +1 -1
  16. package/dist/js/components/lightbox.js +442 -131
  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 +2 -2
  21. package/dist/js/components/parallax.min.js +1 -1
  22. package/dist/js/components/slider-parallax.js +2 -2
  23. package/dist/js/components/slider-parallax.min.js +1 -1
  24. package/dist/js/components/slider.js +17 -27
  25. package/dist/js/components/slider.min.js +1 -1
  26. package/dist/js/components/slideshow-parallax.js +2 -2
  27. package/dist/js/components/slideshow-parallax.min.js +1 -1
  28. package/dist/js/components/slideshow.js +22 -33
  29. package/dist/js/components/slideshow.min.js +1 -1
  30. package/dist/js/components/sortable.js +3 -3
  31. package/dist/js/components/sortable.min.js +1 -1
  32. package/dist/js/components/tooltip.js +8 -12
  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 +225 -221
  37. package/dist/js/uikit-core.min.js +1 -1
  38. package/dist/js/uikit-icons.js +20 -17
  39. package/dist/js/uikit-icons.min.js +1 -1
  40. package/dist/js/uikit.js +644 -530
  41. package/dist/js/uikit.min.js +1 -1
  42. package/package.json +2 -2
  43. package/src/images/icons/arrow-down-arrow-up.svg +6 -0
  44. package/src/images/icons/arrow-down.svg +3 -3
  45. package/src/images/icons/arrow-left.svg +3 -3
  46. package/src/images/icons/arrow-right.svg +3 -3
  47. package/src/images/icons/arrow-up-right.svg +3 -3
  48. package/src/images/icons/arrow-up.svg +3 -3
  49. package/src/images/icons/close-circle.svg +5 -0
  50. package/src/images/icons/cloud-download.svg +4 -4
  51. package/src/images/icons/cloud-upload.svg +4 -4
  52. package/src/images/icons/download.svg +4 -4
  53. package/src/images/icons/expand.svg +5 -5
  54. package/src/images/icons/link-external.svg +4 -4
  55. package/src/images/icons/pull.svg +4 -4
  56. package/src/images/icons/push.svg +3 -3
  57. package/src/images/icons/shrink.svg +5 -5
  58. package/src/images/icons/sign-in.svg +4 -3
  59. package/src/images/icons/sign-out.svg +4 -3
  60. package/src/images/icons/sorting.svg +6 -0
  61. package/src/images/icons/upload.svg +4 -4
  62. package/src/js/api/events.js +15 -14
  63. package/src/js/api/instance.js +1 -1
  64. package/src/js/components/internal/lightbox-animations.js +2 -1
  65. package/src/js/components/internal/slideshow-animations.js +5 -5
  66. package/src/js/components/lightbox-panel.js +180 -45
  67. package/src/js/components/lightbox.js +59 -6
  68. package/src/js/components/slideshow.js +1 -2
  69. package/src/js/components/sortable.js +2 -2
  70. package/src/js/core/grid.js +1 -1
  71. package/src/js/core/icon.js +2 -2
  72. package/src/js/core/img.js +3 -5
  73. package/src/js/core/navbar.js +6 -2
  74. package/src/js/core/scrollspy-nav.js +1 -1
  75. package/src/js/core/svg.js +8 -10
  76. package/src/js/core/video.js +4 -3
  77. package/src/js/mixin/internal/slideshow-animations.js +1 -6
  78. package/src/js/mixin/modal.js +1 -4
  79. package/src/js/mixin/slider-drag.js +5 -6
  80. package/src/js/mixin/slider-nav.js +1 -1
  81. package/src/js/mixin/slider.js +11 -13
  82. package/src/js/mixin/slideshow.js +1 -1
  83. package/src/js/mixin/togglable.js +7 -2
  84. package/src/js/util/dom.js +3 -1
  85. package/src/js/util/filter.js +3 -1
  86. package/src/js/util/player.js +0 -4
  87. package/src/less/components/background.less +1 -9
  88. package/src/less/components/breadcrumb.less +6 -2
  89. package/src/less/components/button.less +1 -1
  90. package/src/less/components/form-range.less +52 -0
  91. package/src/less/components/form.less +1 -1
  92. package/src/less/components/lightbox.less +57 -89
  93. package/src/less/components/margin.less +14 -0
  94. package/src/less/components/search.less +49 -23
  95. package/src/less/components/sticky.less +1 -10
  96. package/src/less/components/totop.less +1 -1
  97. package/src/less/components/transition.less +4 -4
  98. package/src/less/components/visibility.less +3 -2
  99. package/src/less/theme/form-range.less +12 -0
  100. package/src/less/theme/lightbox.less +2 -20
  101. package/src/less/theme/search.less +24 -10
  102. package/src/scss/components/background.scss +1 -9
  103. package/src/scss/components/breadcrumb.scss +6 -2
  104. package/src/scss/components/button.scss +1 -1
  105. package/src/scss/components/form-range.scss +12 -0
  106. package/src/scss/components/form.scss +1 -1
  107. package/src/scss/components/lightbox.scss +50 -77
  108. package/src/scss/components/margin.scss +13 -0
  109. package/src/scss/components/search.scss +30 -12
  110. package/src/scss/components/sticky.scss +1 -10
  111. package/src/scss/components/totop.scss +1 -1
  112. package/src/scss/components/transition.scss +4 -4
  113. package/src/scss/components/visibility.scss +3 -2
  114. package/src/scss/mixins-theme.scss +51 -12
  115. package/src/scss/mixins.scss +45 -6
  116. package/src/scss/theme/form-range.scss +10 -0
  117. package/src/scss/theme/lightbox.scss +2 -20
  118. package/src/scss/theme/search.scss +10 -6
  119. package/src/scss/variables-theme.scss +32 -20
  120. package/src/scss/variables.scss +29 -24
  121. package/tests/badge.html +2 -2
  122. package/tests/base.html +1 -1
  123. package/tests/breadcrumb.html +23 -5
  124. package/tests/card.html +24 -24
  125. package/tests/dropbar.html +15 -15
  126. package/tests/dropdown.html +6 -6
  127. package/tests/dropnav.html +100 -100
  128. package/tests/icon.html +8 -0
  129. package/tests/index.html +15 -15
  130. package/tests/lightbox.html +379 -28
  131. package/tests/margin.html +19 -0
  132. package/tests/nav.html +21 -21
  133. package/tests/navbar.html +292 -292
  134. package/tests/offcanvas.html +27 -27
  135. package/tests/placeholder.html +2 -2
  136. package/tests/slider.html +0 -1
  137. package/tests/slideshow.html +1 -1
  138. package/tests/sortable.html +5 -5
  139. package/tests/sticky-navbar.html +114 -114
  140. package/tests/transition.html +2 -1
package/dist/js/uikit.js CHANGED
@@ -1,4 +1,4 @@
1
- /*! UIkit 3.21.14-dev.028df7be8 | https://www.getuikit.com | (c) 2014 - 2024 YOOtheme | MIT License */
1
+ /*! UIkit 3.21.14-dev.2e8a07c7e | https://www.getuikit.com | (c) 2014 - 2024 YOOtheme | MIT License */
2
2
 
3
3
  (function (global, factory) {
4
4
  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
@@ -350,7 +350,7 @@
350
350
  if (isSameSiteAnchor(el)) {
351
351
  const { hash, ownerDocument } = toNode(el);
352
352
  const id = decodeURIComponent(hash).slice(1);
353
- return ownerDocument.getElementById(id) || ownerDocument.getElementsByName(id)[0];
353
+ return id ? ownerDocument.getElementById(id) || ownerDocument.getElementsByName(id)[0] : ownerDocument;
354
354
  }
355
355
  }
356
356
 
@@ -746,7 +746,9 @@
746
746
  }
747
747
  function empty(element) {
748
748
  element = $(element);
749
- element.innerHTML = "";
749
+ if (element) {
750
+ element.innerHTML = "";
751
+ }
750
752
  return element;
751
753
  }
752
754
  function html(parent2, html2) {
@@ -1138,9 +1140,6 @@
1138
1140
  el.muted = true;
1139
1141
  }
1140
1142
  }
1141
- function isVideo(el) {
1142
- return isHTML5(el) || isIFrame(el);
1143
- }
1144
1143
  function isHTML5(el) {
1145
1144
  return isTag(el, "video");
1146
1145
  }
@@ -1606,7 +1605,6 @@
1606
1605
  isTag: isTag,
1607
1606
  isTouch: isTouch,
1608
1607
  isUndefined: isUndefined,
1609
- isVideo: isVideo,
1610
1608
  isVisible: isVisible,
1611
1609
  isVoidElement: isVoidElement,
1612
1610
  isWindow: isWindow,
@@ -2446,6 +2444,121 @@
2446
2444
  return $("a,button", el) || el;
2447
2445
  }
2448
2446
 
2447
+ var img = {
2448
+ args: "dataSrc",
2449
+ props: {
2450
+ dataSrc: String,
2451
+ sources: String,
2452
+ margin: String,
2453
+ target: String,
2454
+ loading: String
2455
+ },
2456
+ data: {
2457
+ dataSrc: "",
2458
+ sources: false,
2459
+ margin: "50%",
2460
+ target: false,
2461
+ loading: "lazy"
2462
+ },
2463
+ connected() {
2464
+ if (this.loading !== "lazy") {
2465
+ this.load();
2466
+ } else if (isImg(this.$el)) {
2467
+ this.$el.loading = "lazy";
2468
+ setSrcAttrs(this.$el);
2469
+ }
2470
+ },
2471
+ disconnected() {
2472
+ if (this.img) {
2473
+ this.img.onload = "";
2474
+ }
2475
+ delete this.img;
2476
+ },
2477
+ observe: intersection({
2478
+ handler(entries, observer) {
2479
+ this.load();
2480
+ observer.disconnect();
2481
+ },
2482
+ options: ({ margin }) => ({ rootMargin: margin }),
2483
+ filter: ({ loading }) => loading === "lazy",
2484
+ target: ({ $el, $props }) => $props.target ? [$el, ...queryAll($props.target, $el)] : $el
2485
+ }),
2486
+ methods: {
2487
+ load() {
2488
+ if (this.img) {
2489
+ return this.img;
2490
+ }
2491
+ const image = isImg(this.$el) ? this.$el : getImageFromElement(this.$el, this.dataSrc, this.sources);
2492
+ removeAttr(image, "loading");
2493
+ setSrcAttrs(this.$el, image.currentSrc);
2494
+ return this.img = image;
2495
+ }
2496
+ }
2497
+ };
2498
+ function setSrcAttrs(el, src) {
2499
+ if (isImg(el)) {
2500
+ const parentNode = parent(el);
2501
+ const elements = isTag(parentNode, "picture") ? children(parentNode) : [el];
2502
+ elements.forEach((el2) => setSourceProps(el2, el2));
2503
+ } else if (src) {
2504
+ const change = !includes(el.style.backgroundImage, src);
2505
+ if (change) {
2506
+ css(el, "backgroundImage", `url(${escape(src)})`);
2507
+ trigger(el, createEvent("load", false));
2508
+ }
2509
+ }
2510
+ }
2511
+ const srcProps = ["data-src", "data-srcset", "sizes"];
2512
+ function setSourceProps(sourceEl, targetEl) {
2513
+ for (const prop of srcProps) {
2514
+ const value = data(sourceEl, prop);
2515
+ if (value) {
2516
+ attr(targetEl, prop.replace(/data-/g, ""), value);
2517
+ }
2518
+ }
2519
+ }
2520
+ function getImageFromElement(el, src, sources) {
2521
+ const img = new Image();
2522
+ wrapInPicture(img, sources);
2523
+ setSourceProps(el, img);
2524
+ img.onload = () => setSrcAttrs(el, img.currentSrc);
2525
+ attr(img, "src", src);
2526
+ return img;
2527
+ }
2528
+ function wrapInPicture(img, sources) {
2529
+ sources = parseSources(sources);
2530
+ if (sources.length) {
2531
+ const picture = fragment("<picture>");
2532
+ for (const attrs of sources) {
2533
+ const source = fragment("<source>");
2534
+ attr(source, attrs);
2535
+ append(picture, source);
2536
+ }
2537
+ append(picture, img);
2538
+ }
2539
+ }
2540
+ function parseSources(sources) {
2541
+ if (!sources) {
2542
+ return [];
2543
+ }
2544
+ if (startsWith(sources, "[")) {
2545
+ try {
2546
+ sources = JSON.parse(sources);
2547
+ } catch (e) {
2548
+ sources = [];
2549
+ }
2550
+ } else {
2551
+ sources = parseOptions(sources);
2552
+ }
2553
+ if (!isArray(sources)) {
2554
+ sources = [sources];
2555
+ }
2556
+ return sources.filter((source) => !isEmpty(source));
2557
+ }
2558
+ function isImg(el) {
2559
+ return isTag(el, "img");
2560
+ }
2561
+
2449
2562
  let prevented;
2450
2563
  function preventBackgroundScroll(el) {
2451
2564
  const off = on(
@@ -2512,6 +2625,82 @@
2512
2625
  }
2513
2626
  };
2514
2627
 
2628
+ var Position = {
2629
+ props: {
2630
+ pos: String,
2631
+ offset: Boolean,
2632
+ flip: Boolean,
2633
+ shift: Boolean,
2634
+ inset: Boolean
2635
+ },
2636
+ data: {
2637
+ pos: `bottom-${isRtl ? "right" : "left"}`,
2638
+ offset: false,
2639
+ flip: true,
2640
+ shift: true,
2641
+ inset: false
2642
+ },
2643
+ connected() {
2644
+ this.pos = this.$props.pos.split("-").concat("center").slice(0, 2);
2645
+ [this.dir, this.align] = this.pos;
2646
+ this.axis = includes(["top", "bottom"], this.dir) ? "y" : "x";
2647
+ },
2648
+ methods: {
2649
+ positionAt(element, target, boundary) {
2650
+ let offset = [this.getPositionOffset(element), this.getShiftOffset(element)];
2651
+ const placement = [this.flip && "flip", this.shift && "shift"];
2652
+ const attach = {
2653
+ element: [this.inset ? this.dir : flipPosition(this.dir), this.align],
2654
+ target: [this.dir, this.align]
2655
+ };
2656
+ if (this.axis === "y") {
2657
+ for (const prop in attach) {
2658
+ attach[prop].reverse();
2659
+ }
2660
+ offset.reverse();
2661
+ placement.reverse();
2662
+ }
2663
+ const restoreScrollPosition = storeScrollPosition(element);
2664
+ const elDim = dimensions$1(element);
2665
+ css(element, { top: -elDim.height, left: -elDim.width });
2666
+ positionAt(element, target, {
2667
+ attach,
2668
+ offset,
2669
+ boundary,
2670
+ placement,
2671
+ viewportOffset: this.getViewportOffset(element)
2672
+ });
2673
+ restoreScrollPosition();
2674
+ },
2675
+ getPositionOffset(element = this.$el) {
2676
+ return toPx(
2677
+ this.offset === false ? css(element, "--uk-position-offset") : this.offset,
2678
+ this.axis === "x" ? "width" : "height",
2679
+ element
2680
+ ) * (includes(["left", "top"], this.dir) ? -1 : 1) * (this.inset ? -1 : 1);
2681
+ },
2682
+ getShiftOffset(element = this.$el) {
2683
+ return this.align === "center" ? 0 : toPx(
2684
+ css(element, "--uk-position-shift-offset"),
2685
+ this.axis === "y" ? "width" : "height",
2686
+ element
2687
+ ) * (includes(["left", "top"], this.align) ? 1 : -1);
2688
+ },
2689
+ getViewportOffset(element) {
2690
+ return toPx(css(element, "--uk-position-viewport-offset"));
2691
+ }
2692
+ }
2693
+ };
2694
+ function storeScrollPosition(element) {
2695
+ const scrollElement = scrollParent(element);
2696
+ const { scrollTop } = scrollElement;
2697
+ return () => {
2698
+ if (scrollTop !== scrollElement.scrollTop) {
2699
+ scrollElement.scrollTop = scrollTop;
2700
+ }
2701
+ };
2702
+ }
2703
+
2515
2704
  var Togglable = {
2516
2705
  props: {
2517
2706
  cls: Boolean,
@@ -2549,8 +2738,14 @@
2549
2738
  addClass(el, cls);
2550
2739
  trigger(el, show ? "show" : "hide", [this]);
2551
2740
  const done = () => {
2741
+ var _a;
2552
2742
  removeClass(el, cls);
2553
2743
  trigger(el, show ? "shown" : "hidden", [this]);
2744
+ if (show) {
2745
+ const restoreScrollPosition = storeScrollPosition(el);
2746
+ (_a = $$("[autofocus]", el).find(isVisible)) == null ? void 0 : _a.focus();
2747
+ restoreScrollPosition();
2748
+ }
2554
2749
  };
2555
2750
  return promise ? promise.then(done, () => {
2556
2751
  removeClass(el, cls);
@@ -2583,7 +2778,6 @@
2583
2778
  if (changed) {
2584
2779
  trigger(el, "toggled", [toggled, this]);
2585
2780
  }
2586
- $$("[autofocus]", el).some((el2) => isVisible(el2) ? el2.focus() || true : el2.blur());
2587
2781
  }
2588
2782
  }
2589
2783
  };
@@ -2714,9 +2908,6 @@
2714
2908
  panel: ({ selPanel }, $el) => $(selPanel, $el),
2715
2909
  transitionElement() {
2716
2910
  return this.panel;
2717
- },
2718
- bgClose({ bgClose }) {
2719
- return bgClose && this.panel;
2720
2911
  }
2721
2912
  },
2722
2913
  connected() {
@@ -2879,7 +3070,7 @@
2879
3070
  }
2880
3071
  function listenForBackgroundClose$1(modal) {
2881
3072
  return on(document, pointerDown$1, ({ target }) => {
2882
- if (last(active$1) !== modal || modal.overlay && !modal.$el.contains(target) || modal.panel.contains(target)) {
3073
+ if (last(active$1) !== modal || modal.overlay && !modal.$el.contains(target) || !modal.panel || modal.panel.contains(target)) {
2883
3074
  return;
2884
3075
  }
2885
3076
  once(
@@ -2922,11 +3113,7 @@
2922
3113
  return Math.abs(new DOMMatrix(css(el, "transform")).m41 / el.offsetWidth);
2923
3114
  }
2924
3115
  function translate(value = 0, unit = "%") {
2925
- value += value ? unit : "";
2926
- return `translate3d(${value}, 0, 0)`;
2927
- }
2928
- function scale3d(value) {
2929
- return `scale3d(${value}, ${value}, 1)`;
3116
+ return value ? `translate3d(${value + unit}, 0, 0)` : "";
2930
3117
  }
2931
3118
 
2932
3119
  function Transitioner$1(prev, next, dir, { animation, easing }) {
@@ -3060,7 +3247,6 @@
3060
3247
  const pointerDown = "touchstart mousedown";
3061
3248
  const pointerMove = "touchmove mousemove";
3062
3249
  const pointerUp = "touchend touchcancel mouseup click input scroll";
3063
- const preventClick = (e) => e.preventDefault();
3064
3250
  var SliderDrag = {
3065
3251
  props: {
3066
3252
  draggable: Boolean
@@ -3128,9 +3314,6 @@
3128
3314
  if (distance === 0 || this.prevPos === this.pos || !this.dragging && Math.abs(distance) < this.threshold) {
3129
3315
  return;
3130
3316
  }
3131
- if (!this.dragging) {
3132
- on(this.list, "click", preventClick, pointerOptions);
3133
- }
3134
3317
  e.cancelable && e.preventDefault();
3135
3318
  this.dragging = true;
3136
3319
  this.dir = distance < 0 ? 1 : -1;
@@ -3179,6 +3362,7 @@
3179
3362
  off(document, pointerMove, this.move, pointerOptions);
3180
3363
  off(document, pointerUp, this.end, pointerUpOptions);
3181
3364
  if (this.dragging) {
3365
+ setTimeout(on(this.list, "click", (e) => e.preventDefault(), pointerOptions));
3182
3366
  this.dragging = null;
3183
3367
  if (this.index === this.prevIndex) {
3184
3368
  this.percent = 1 - this.percent;
@@ -3189,6 +3373,8 @@
3189
3373
  const dirChange = (isRtl ? this.dir * (isRtl ? 1 : -1) : this.dir) < 0 === this.prevPos > this.pos;
3190
3374
  this.index = dirChange ? this.index : this.prevIndex;
3191
3375
  if (dirChange) {
3376
+ trigger(this.slides[this.prevIndex], "itemhidden", [this]);
3377
+ trigger(this.slides[this.index], "itemshown", [this]);
3192
3378
  this.percent = 1 - this.percent;
3193
3379
  }
3194
3380
  this.show(
@@ -3197,7 +3383,6 @@
3197
3383
  );
3198
3384
  }
3199
3385
  }
3200
- setTimeout(() => off(this.list, "click", preventClick, pointerOptions));
3201
3386
  css(this.list, { userSelect: "" });
3202
3387
  this.drag = this.percent = null;
3203
3388
  }
@@ -3302,23 +3487,27 @@
3302
3487
  registerEvent(instance, event);
3303
3488
  } else {
3304
3489
  for (const key in event) {
3305
- registerEvent(instance, event[key], key);
3490
+ registerEvent(instance, { name: key, handler: event[key] });
3306
3491
  }
3307
3492
  }
3308
3493
  }
3309
3494
  }
3310
- function registerEvent(instance, event, key) {
3311
- let { name, el, handler, capture, passive, delegate, filter, self } = isPlainObject(event) ? event : { name: key, handler: event };
3312
- el = el ? el.call(instance, instance) : instance.$el;
3313
- if (!el || isArray(el) && !el.length || filter && !filter.call(instance, instance)) {
3495
+ function registerEvent(instance, { name, el, handler, capture, passive, delegate, filter, self }) {
3496
+ if (filter && !filter.call(instance, instance)) {
3314
3497
  return;
3315
3498
  }
3316
3499
  instance._disconnect.push(
3317
- on(el, name, delegate == null ? void 0 : delegate.call(instance, instance), handler.bind(instance), {
3318
- passive,
3319
- capture,
3320
- self
3321
- })
3500
+ on(
3501
+ el ? el.call(instance, instance) : instance.$el,
3502
+ name,
3503
+ delegate == null ? void 0 : delegate.call(instance, instance),
3504
+ handler.bind(instance),
3505
+ {
3506
+ passive,
3507
+ capture,
3508
+ self
3509
+ }
3510
+ )
3322
3511
  );
3323
3512
  }
3324
3513
 
@@ -3527,7 +3716,7 @@
3527
3716
  };
3528
3717
  App.util = util;
3529
3718
  App.options = {};
3530
- App.version = "3.21.14-dev.028df7be8";
3719
+ App.version = "3.21.14-dev.2e8a07c7e";
3531
3720
 
3532
3721
  const PREFIX = "uk-";
3533
3722
  const DATA = "__uikit__";
@@ -3646,7 +3835,7 @@
3646
3835
  const instance = this;
3647
3836
  attachToElement(el, instance);
3648
3837
  instance.$options.el = el;
3649
- if (document.contains(el)) {
3838
+ if (el.isConnected) {
3650
3839
  callConnected(instance);
3651
3840
  }
3652
3841
  };
@@ -3832,7 +4021,7 @@
3832
4021
  const item = toNumber(cmd);
3833
4022
  const active = item === index;
3834
4023
  toggleClass(el, this.clsActive, active);
3835
- toggleClass(button, "uk-disabled", this.parallax);
4024
+ toggleClass(button, "uk-disabled", !!this.parallax);
3836
4025
  attr(button, {
3837
4026
  "aria-selected": active,
3838
4027
  tabindex: active && !this.parallax ? null : -1
@@ -3935,7 +4124,7 @@
3935
4124
  }
3936
4125
  },
3937
4126
  methods: {
3938
- show(index, force = false) {
4127
+ async show(index, force = false) {
3939
4128
  var _a;
3940
4129
  if (this.dragging || !this.length || this.parallax) {
3941
4130
  return;
@@ -3971,18 +4160,16 @@
3971
4160
  reset();
3972
4161
  return;
3973
4162
  }
3974
- const promise = this._show(prev, next, force).then(() => {
3975
- prev && trigger(prev, "itemhidden", [this]);
3976
- trigger(next, "itemshown", [this]);
3977
- stack.shift();
3978
- this._transitioner = null;
3979
- if (stack.length) {
3980
- requestAnimationFrame(() => stack.length && this.show(stack.shift(), true));
3981
- }
3982
- });
3983
4163
  prev && trigger(prev, "itemhide", [this]);
3984
4164
  trigger(next, "itemshow", [this]);
3985
- return promise;
4165
+ await this._show(prev, next, force);
4166
+ prev && trigger(prev, "itemhidden", [this]);
4167
+ trigger(next, "itemshown", [this]);
4168
+ stack.shift();
4169
+ this._transitioner = null;
4170
+ if (stack.length) {
4171
+ requestAnimationFrame(() => stack.length && this.show(stack.shift(), true));
4172
+ }
3986
4173
  },
3987
4174
  getIndex(index = this.index, prev = this.index) {
3988
4175
  return clamp(
@@ -4052,7 +4239,7 @@
4052
4239
  },
4053
4240
  observe: resize(),
4054
4241
  events: {
4055
- beforeitemshow({ target }) {
4242
+ itemshow({ target }) {
4056
4243
  addClass(target, this.clsActive);
4057
4244
  },
4058
4245
  itemshown({ target }) {
@@ -4068,87 +4255,210 @@
4068
4255
  ...Animations$2,
4069
4256
  fade: {
4070
4257
  show() {
4071
- return [{ opacity: 0 }, { opacity: 1 }];
4258
+ return [{ opacity: 0, zIndex: 0 }, { zIndex: -1 }];
4072
4259
  },
4073
4260
  percent(current) {
4074
4261
  return 1 - css(current, "opacity");
4075
4262
  },
4076
4263
  translate(percent) {
4077
- return [{ opacity: 1 - percent }, { opacity: percent }];
4264
+ return [{ opacity: 1 - percent, zIndex: 0 }, { zIndex: -1 }];
4078
4265
  }
4079
4266
  },
4080
4267
  scale: {
4081
4268
  show() {
4082
- return [
4083
- { opacity: 0, transform: scale3d(1 - 0.2) },
4084
- { opacity: 1, transform: scale3d(1) }
4085
- ];
4269
+ return [{ opacity: 0, transform: scale3d(1 + 0.5), zIndex: 0 }, { zIndex: -1 }];
4086
4270
  },
4087
4271
  percent(current) {
4088
4272
  return 1 - css(current, "opacity");
4089
4273
  },
4090
4274
  translate(percent) {
4091
4275
  return [
4092
- { opacity: 1 - percent, transform: scale3d(1 - 0.2 * percent) },
4093
- { opacity: percent, transform: scale3d(1 - 0.2 + 0.2 * percent) }
4276
+ { opacity: 1 - percent, transform: scale3d(1 + 0.5 * percent), zIndex: 0 },
4277
+ { zIndex: -1 }
4094
4278
  ];
4095
4279
  }
4096
- }
4097
- };
4098
-
4099
- var LightboxPanel = {
4100
- mixins: [Modal, Slideshow],
4101
- functional: true,
4102
- props: {
4103
- delayControls: Number,
4104
- preload: Number,
4105
- videoAutoplay: Boolean,
4106
- template: String
4107
- },
4108
- data: () => ({
4109
- preload: 1,
4110
- videoAutoplay: false,
4111
- delayControls: 3e3,
4112
- items: [],
4113
- cls: "uk-open",
4114
- clsPage: "uk-lightbox-page",
4115
- selList: ".uk-lightbox-items",
4116
- attrItem: "uk-lightbox-item",
4117
- selClose: ".uk-close-large",
4118
- selCaption: ".uk-lightbox-caption",
4119
- pauseOnHover: false,
4120
- velocity: 2,
4121
- Animations: Animations$1,
4122
- template: `<div class="uk-lightbox uk-overflow-hidden"> <div class="uk-lightbox-items"></div> <div class="uk-lightbox-toolbar uk-position-top uk-text-right uk-transition-slide-top uk-transition-opaque"> <button class="uk-lightbox-toolbar-icon uk-close-large" type="button" uk-close></button> </div> <a class="uk-lightbox-button uk-position-center-left uk-position-medium uk-transition-fade" href uk-slidenav-previous uk-lightbox-item="previous"></a> <a class="uk-lightbox-button uk-position-center-right uk-position-medium uk-transition-fade" href uk-slidenav-next uk-lightbox-item="next"></a> <div class="uk-lightbox-toolbar uk-lightbox-caption uk-position-bottom uk-text-center uk-transition-slide-bottom uk-transition-opaque"></div> </div>`
4123
- }),
4124
- created() {
4125
- const $el = $(this.template);
4126
- const list = $(this.selList, $el);
4127
- this.items.forEach(() => append(list, "<div>"));
4128
- const close = $("[uk-close]", $el);
4129
- const closeLabel = this.t("close");
4130
- if (close && closeLabel) {
4131
- close.dataset.i18n = JSON.stringify({ label: closeLabel });
4132
- }
4133
- this.$mount(append(this.container, $el));
4280
+ },
4281
+ pull: {
4282
+ show(dir) {
4283
+ return dir < 0 ? [
4284
+ { transform: translate(30), zIndex: -1 },
4285
+ { transform: translate(), zIndex: 0 }
4286
+ ] : [
4287
+ { transform: translate(-100), zIndex: 0 },
4288
+ { transform: translate(), zIndex: -1 }
4289
+ ];
4290
+ },
4291
+ percent(current, next, dir) {
4292
+ return dir < 0 ? 1 - translated(next) : translated(current);
4293
+ },
4294
+ translate(percent, dir) {
4295
+ return dir < 0 ? [
4296
+ { transform: translate(30 * percent), zIndex: -1 },
4297
+ { transform: translate(-100 * (1 - percent)), zIndex: 0 }
4298
+ ] : [
4299
+ { transform: translate(-percent * 100), zIndex: 0 },
4300
+ { transform: translate(30 * (1 - percent)), zIndex: -1 }
4301
+ ];
4302
+ }
4303
+ },
4304
+ push: {
4305
+ show(dir) {
4306
+ return dir < 0 ? [
4307
+ { transform: translate(100), zIndex: 0 },
4308
+ { transform: translate(), zIndex: -1 }
4309
+ ] : [
4310
+ { transform: translate(-30), zIndex: -1 },
4311
+ { transform: translate(), zIndex: 0 }
4312
+ ];
4313
+ },
4314
+ percent(current, next, dir) {
4315
+ return dir > 0 ? 1 - translated(next) : translated(current);
4316
+ },
4317
+ translate(percent, dir) {
4318
+ return dir < 0 ? [
4319
+ { transform: translate(percent * 100), zIndex: 0 },
4320
+ { transform: translate(-30 * (1 - percent)), zIndex: -1 }
4321
+ ] : [
4322
+ { transform: translate(-30 * percent), zIndex: -1 },
4323
+ { transform: translate(100 * (1 - percent)), zIndex: 0 }
4324
+ ];
4325
+ }
4326
+ }
4327
+ };
4328
+ function scale3d(value) {
4329
+ return `scale3d(${value}, ${value}, 1)`;
4330
+ }
4331
+
4332
+ var Animations = {
4333
+ ...Animations$2,
4334
+ fade: {
4335
+ show() {
4336
+ return [{ opacity: 0 }, { opacity: 1 }];
4337
+ },
4338
+ percent(current) {
4339
+ return 1 - css(current, "opacity");
4340
+ },
4341
+ translate(percent) {
4342
+ return [{ opacity: 1 - percent }, { opacity: percent }];
4343
+ }
4344
+ },
4345
+ scale: {
4346
+ show() {
4347
+ return [
4348
+ { opacity: 0, transform: scale3d(1 - 0.2) },
4349
+ { opacity: 1, transform: scale3d(1) }
4350
+ ];
4351
+ },
4352
+ percent(current) {
4353
+ return 1 - css(current, "opacity");
4354
+ },
4355
+ translate(percent) {
4356
+ return [
4357
+ { opacity: 1 - percent, transform: scale3d(1 - 0.2 * percent) },
4358
+ { opacity: percent, transform: scale3d(1 - 0.2 + 0.2 * percent) }
4359
+ ];
4360
+ }
4361
+ }
4362
+ };
4363
+
4364
+ var LightboxPanel = {
4365
+ i18n: {
4366
+ counter: "%s / %s"
4367
+ },
4368
+ mixins: [Modal, Slideshow],
4369
+ functional: true,
4370
+ props: {
4371
+ counter: Boolean,
4372
+ preload: Number,
4373
+ nav: Boolean,
4374
+ slidenav: Boolean,
4375
+ delayControls: Number,
4376
+ videoAutoplay: Boolean,
4377
+ template: String
4378
+ },
4379
+ data: () => ({
4380
+ counter: false,
4381
+ preload: 1,
4382
+ nav: false,
4383
+ slidenav: true,
4384
+ delayControls: 3e3,
4385
+ videoAutoplay: false,
4386
+ items: [],
4387
+ cls: "uk-open",
4388
+ clsPage: "uk-lightbox-page",
4389
+ clsFit: "uk-lightbox-items-fit",
4390
+ clsZoom: "uk-lightbox-zoom",
4391
+ attrItem: "uk-lightbox-item",
4392
+ selList: ".uk-lightbox-items",
4393
+ selClose: ".uk-close-large",
4394
+ selNav: ".uk-lightbox-thumbnav, .uk-lightbox-dotnav",
4395
+ selCaption: ".uk-lightbox-caption",
4396
+ selCounter: ".uk-lightbox-counter",
4397
+ pauseOnHover: false,
4398
+ velocity: 2,
4399
+ Animations,
4400
+ template: `<div class="uk-lightbox uk-overflow-hidden"> <div class="uk-lightbox-items"></div> <div class="uk-position-top-right uk-position-small uk-transition-fade" uk-inverse> <button class="uk-lightbox-close uk-close-large" type="button" uk-close></button> </div> <div class="uk-lightbox-slidenav uk-position-center-left uk-position-medium uk-transition-fade" uk-inverse> <a href uk-slidenav-previous uk-lightbox-item="previous"></a> </div> <div class="uk-lightbox-slidenav uk-position-center-right uk-position-medium uk-transition-fade" uk-inverse> <a href uk-slidenav-next uk-lightbox-item="next"></a> </div> <div class="uk-position-center-right uk-position-medium uk-transition-fade" uk-inverse style="max-height: 90vh; overflow: auto;"> <ul class="uk-lightbox-thumbnav uk-lightbox-thumbnav-vertical uk-thumbnav uk-thumbnav-vertical"></ul> <ul class="uk-lightbox-dotnav uk-dotnav uk-dotnav-vertical"></ul> </div> <div class="uk-lightbox-counter uk-text-large uk-position-top-left uk-position-small uk-transition-fade" uk-inverse></div> <div class="uk-lightbox-caption uk-position-bottom uk-text-center uk-transition-slide-bottom uk-transition-opaque"></div> </div>`
4401
+ }),
4402
+ created() {
4403
+ let $el = $(this.template);
4404
+ if (isTag($el, "template")) {
4405
+ $el = fragment(html($el));
4406
+ }
4407
+ const list = $(this.selList, $el);
4408
+ const navType = this.$props.nav;
4409
+ remove$1($$(this.selNav, $el).filter((el) => !matches(el, `.uk-${navType}`)));
4410
+ for (const [i, item] of this.items.entries()) {
4411
+ append(list, "<div>");
4412
+ if (navType === "thumbnav") {
4413
+ wrapAll(
4414
+ toThumbnavItem(item, this.videoAutoplay),
4415
+ append($(this.selNav, $el), `<li uk-lightbox-item="${i}"><a href></a></li>`)
4416
+ );
4417
+ }
4418
+ }
4419
+ if (!this.slidenav) {
4420
+ remove$1($$(".uk-lightbox-slidenav", $el));
4421
+ }
4422
+ if (!this.counter) {
4423
+ remove$1($(this.selCounter, $el));
4424
+ }
4425
+ addClass(list, this.clsFit);
4426
+ const close = $("[uk-close]", $el);
4427
+ const closeLabel = this.t("close");
4428
+ if (close && closeLabel) {
4429
+ close.dataset.i18n = JSON.stringify({ label: closeLabel });
4430
+ }
4431
+ this.$mount(append(this.container, $el));
4134
4432
  },
4135
4433
  events: [
4136
4434
  {
4137
- name: `${pointerMove$1} ${pointerDown$1} keydown`,
4138
- handler() {
4139
- this.showControls();
4435
+ name: "click",
4436
+ self: true,
4437
+ filter: ({ bgClose }) => bgClose,
4438
+ delegate: ({ selList }) => `${selList} > *`,
4439
+ handler(e) {
4440
+ if (!e.defaultPrevented) {
4441
+ this.hide();
4442
+ }
4140
4443
  }
4141
4444
  },
4142
4445
  {
4143
4446
  name: "click",
4144
4447
  self: true,
4145
- delegate: ({ selList }) => `${selList} > *`,
4448
+ delegate: ({ clsZoom }) => `.${clsZoom}`,
4146
4449
  handler(e) {
4147
4450
  if (!e.defaultPrevented) {
4148
- this.hide();
4451
+ toggleClass(this.list, this.clsFit);
4149
4452
  }
4150
4453
  }
4151
4454
  },
4455
+ {
4456
+ name: `${pointerMove$1} ${pointerDown$1} keydown`,
4457
+ filter: ({ delayControls }) => delayControls,
4458
+ handler() {
4459
+ this.showControls();
4460
+ }
4461
+ },
4152
4462
  {
4153
4463
  name: "shown",
4154
4464
  self: true,
@@ -4197,26 +4507,25 @@
4197
4507
  {
4198
4508
  name: "beforeitemshow",
4199
4509
  handler(e) {
4510
+ html($(this.selCaption, this.$el), this.getItem().caption || "");
4511
+ html(
4512
+ $(this.selCounter, this.$el),
4513
+ this.t("counter", this.index + 1, this.slides.length)
4514
+ );
4515
+ for (let j = -this.preload; j <= this.preload; j++) {
4516
+ this.loadItem(this.index + j);
4517
+ }
4200
4518
  if (this.isToggled()) {
4201
4519
  return;
4202
4520
  }
4203
4521
  this.draggable = false;
4204
4522
  e.preventDefault();
4205
4523
  this.toggleElement(this.$el, true, false);
4206
- this.animation = Animations$1["scale"];
4524
+ this.animation = Animations.scale;
4207
4525
  removeClass(e.target, this.clsActive);
4208
4526
  this.stack.splice(1, 0, this.index);
4209
4527
  }
4210
4528
  },
4211
- {
4212
- name: "itemshow",
4213
- handler() {
4214
- html($(this.selCaption, this.$el), this.getItem().caption || "");
4215
- for (let j = -this.preload; j <= this.preload; j++) {
4216
- this.loadItem(this.index + j);
4217
- }
4218
- }
4219
- },
4220
4529
  {
4221
4530
  name: "itemshown",
4222
4531
  handler() {
@@ -4226,29 +4535,36 @@
4226
4535
  {
4227
4536
  name: "itemload",
4228
4537
  async handler(_, item) {
4229
- const { source: src, type, alt = "", poster, attrs = {} } = item;
4230
- this.setItem(item, "<span uk-spinner></span>");
4538
+ const { source: src, type, attrs = {} } = item;
4539
+ this.setItem(item, "<span uk-spinner uk-inverse></span>");
4231
4540
  if (!src) {
4232
4541
  return;
4233
4542
  }
4234
- let matches;
4543
+ let matches2;
4235
4544
  const iframeAttrs = {
4236
4545
  allowfullscreen: "",
4237
4546
  style: "max-width: 100%; box-sizing: border-box;",
4238
4547
  "uk-responsive": "",
4239
- "uk-video": `${this.videoAutoplay}`
4548
+ "uk-video": `${Boolean(this.videoAutoplay)}`
4240
4549
  };
4241
- if (type === "image" || src.match(/\.(avif|jpe?g|jfif|a?png|gif|svg|webp)($|\?)/i)) {
4242
- const img = createEl("img", { src, alt, ...attrs });
4243
- on(img, "load", () => this.setItem(item, img));
4550
+ if (type === "image" || isImage(src)) {
4551
+ const img = createEl("img");
4552
+ wrapInPicture(img, item.sources);
4553
+ attr(img, {
4554
+ src,
4555
+ ...pick(item, ["alt", "srcset", "sizes"]),
4556
+ ...attrs
4557
+ });
4558
+ on(img, "load", () => this.setItem(item, parent(img) || img));
4244
4559
  on(img, "error", () => this.setError(item));
4245
- } else if (type === "video" || src.match(/\.(mp4|webm|ogv)($|\?)/i)) {
4560
+ } else if (type === "video" || isVideo(src)) {
4561
+ const inline = this.videoAutoplay === "inline";
4246
4562
  const video = createEl("video", {
4247
4563
  src,
4248
- poster,
4249
- controls: "",
4250
4564
  playsinline: "",
4251
- "uk-video": `${this.videoAutoplay}`,
4565
+ controls: inline ? null : "",
4566
+ poster: this.videoAutoplay ? null : item.poster,
4567
+ "uk-video": inline ? "automute: true" : Boolean(this.videoAutoplay),
4252
4568
  ...attrs
4253
4569
  });
4254
4570
  on(video, "loadedmetadata", () => this.setItem(item, video));
@@ -4263,20 +4579,20 @@
4263
4579
  ...attrs
4264
4580
  })
4265
4581
  );
4266
- } else if (matches = src.match(
4582
+ } else if (matches2 = src.match(
4267
4583
  /\/\/(?:.*?youtube(-nocookie)?\..*?(?:[?&]v=|\/shorts\/)|youtu\.be\/)([\w-]{11})[&?]?(.*)?/
4268
4584
  )) {
4269
4585
  this.setItem(
4270
4586
  item,
4271
4587
  createEl("iframe", {
4272
- src: `https://www.youtube${matches[1] || ""}.com/embed/${matches[2]}${matches[3] ? `?${matches[3]}` : ""}`,
4588
+ src: `https://www.youtube${matches2[1] || ""}.com/embed/${matches2[2]}${matches2[3] ? `?${matches2[3]}` : ""}`,
4273
4589
  width: 1920,
4274
4590
  height: 1080,
4275
4591
  ...iframeAttrs,
4276
4592
  ...attrs
4277
4593
  })
4278
4594
  );
4279
- } else if (matches = src.match(/\/\/.*?vimeo\.[a-z]+\/(\d+)[&?]?(.*)?/)) {
4595
+ } else if (matches2 = src.match(/\/\/.*?vimeo\.[a-z]+\/(\d+)[&?]?(.*)?/)) {
4280
4596
  try {
4281
4597
  const { height, width } = await (await fetch(
4282
4598
  `https://vimeo.com/api/oembed.json?maxwidth=1920&url=${encodeURI(
@@ -4287,7 +4603,7 @@
4287
4603
  this.setItem(
4288
4604
  item,
4289
4605
  createEl("iframe", {
4290
- src: `https://player.vimeo.com/video/${matches[1]}${matches[2] ? `?${matches[2]}` : ""}`,
4606
+ src: `https://player.vimeo.com/video/${matches2[1]}${matches2[2] ? `?${matches2[2]}` : ""}`,
4291
4607
  width,
4292
4608
  height,
4293
4609
  ...iframeAttrs,
@@ -4299,8 +4615,29 @@
4299
4615
  }
4300
4616
  }
4301
4617
  }
4618
+ },
4619
+ {
4620
+ name: "itemloaded",
4621
+ handler() {
4622
+ this.$emit("resize");
4623
+ }
4302
4624
  }
4303
4625
  ],
4626
+ update: {
4627
+ read() {
4628
+ for (const media of $$(`${this.selList} :not([controls]):is(img,video)`, this.$el)) {
4629
+ toggleClass(
4630
+ media,
4631
+ this.clsZoom,
4632
+ (media.naturalHeight || media.videoHeight) - this.$el.offsetHeight > Math.max(
4633
+ 0,
4634
+ (media.naturalWidth || media.videoWidth) - this.$el.offsetWidth
4635
+ )
4636
+ );
4637
+ }
4638
+ },
4639
+ events: ["resize"]
4640
+ },
4304
4641
  methods: {
4305
4642
  loadItem(index = this.index) {
4306
4643
  const item = this.getItem(index);
@@ -4318,11 +4655,11 @@
4318
4655
  return this.slides[this.items.indexOf(item)];
4319
4656
  },
4320
4657
  setError(item) {
4321
- this.setItem(item, '<span uk-icon="icon: bolt; ratio: 2"></span>');
4658
+ this.setItem(item, '<span uk-icon="icon: bolt; ratio: 2" uk-inverse></span>');
4322
4659
  },
4323
4660
  showControls() {
4324
4661
  clearTimeout(this.controlsTimer);
4325
- this.controlsTimer = setTimeout(this.hideControls, this.delayControls);
4662
+ this.controlsTimer = this.delayControls && setTimeout(this.hideControls, this.delayControls);
4326
4663
  addClass(this.$el, "uk-active", "uk-transition-active");
4327
4664
  },
4328
4665
  hideControls() {
@@ -4335,7 +4672,26 @@
4335
4672
  attr(el, attrs);
4336
4673
  return el;
4337
4674
  }
4675
+ function toThumbnavItem(item, videoAutoplay) {
4676
+ const el = item.poster || item.thumb && (item.type === "image" || isImage(item.thumb)) ? createEl("img", { src: item.poster || item.thumb, alt: "" }) : item.thumb && (item.type === "video" || isVideo(item.thumb)) ? createEl("video", {
4677
+ src: item.thumb,
4678
+ loop: "",
4679
+ playsinline: "",
4680
+ "uk-video": `autoplay: ${Boolean(videoAutoplay)}; automute: true`
4681
+ }) : createEl("canvas");
4682
+ if (item.thumbRatio) {
4683
+ el.style.aspectRatio = item.thumbRatio;
4684
+ }
4685
+ return el;
4686
+ }
4687
+ function isImage(src) {
4688
+ return src == null ? void 0 : src.match(/\.(avif|jpe?g|jfif|a?png|gif|svg|webp)($|\?)/i);
4689
+ }
4690
+ function isVideo(src) {
4691
+ return src == null ? void 0 : src.match(/\.(mp4|webm|ogv)($|\?)/i);
4692
+ }
4338
4693
 
4694
+ const selDisabled$1 = ".uk-disabled *, .uk-disabled, [disabled]";
4339
4695
  var lightbox = {
4340
4696
  install: install$3,
4341
4697
  props: { toggle: String },
@@ -4358,17 +4714,23 @@
4358
4714
  },
4359
4715
  events: {
4360
4716
  name: "click",
4361
- delegate: ({ toggle }) => `${toggle}:not(.uk-disabled)`,
4717
+ delegate: ({ toggle }) => toggle,
4362
4718
  handler(e) {
4363
4719
  if (!e.defaultPrevented) {
4364
4720
  e.preventDefault();
4365
- this.show(e.current);
4721
+ if (!matches(e.current, selDisabled$1)) {
4722
+ this.show(e.current);
4723
+ }
4366
4724
  }
4367
4725
  }
4368
4726
  },
4369
4727
  methods: {
4370
4728
  show(index) {
4371
- const items = uniqueBy(this.toggles.map(toItem), "source");
4729
+ let items = this.toggles.map(toItem);
4730
+ if (this.nav === "thumbnav") {
4731
+ ensureThumb.call(this, this.toggles, items);
4732
+ }
4733
+ items = uniqueBy(items, "source");
4372
4734
  if (isElement(index)) {
4373
4735
  const { source } = toItem(index);
4374
4736
  index = findIndex(items, ({ source: src }) => source === src);
@@ -4389,10 +4751,29 @@
4389
4751
  }
4390
4752
  assign(Lightbox.props, UIkit.component("lightboxPanel").options.props);
4391
4753
  }
4754
+ function ensureThumb(toggles, items) {
4755
+ for (const [i, toggle] of Object.entries(toggles)) {
4756
+ if (items[i].thumb) {
4757
+ continue;
4758
+ }
4759
+ const parent = parents(toggle).reverse().concat(toggle).find(
4760
+ (parent2) => this.$el.contains(parent2) && (parent2 === toggle || $$(this.toggle, parent2).length === 1)
4761
+ );
4762
+ if (!parent) {
4763
+ continue;
4764
+ }
4765
+ const media = $("img,video", parent);
4766
+ if (media) {
4767
+ items[i].thumb = media.currentSrc || media.poster || media.src;
4768
+ items[i].thumbRatio = (media.naturalWidth || media.videoWidth) / (media.naturalHeight || media.videoHeight);
4769
+ }
4770
+ }
4771
+ }
4392
4772
  function toItem(el) {
4393
4773
  const item = {};
4394
- for (const attr2 of ["href", "caption", "type", "poster", "alt", "attrs"]) {
4395
- item[attr2 === "href" ? "source" : attr2] = data(el, attr2);
4774
+ for (const attribute of el.getAttributeNames()) {
4775
+ const key = attribute.replace(/^data-/, "");
4776
+ item[key === "href" ? "source" : key] = el.getAttribute(attribute);
4396
4777
  }
4397
4778
  item.attrs = parseOptions(item.attrs);
4398
4779
  return item;
@@ -5500,106 +5881,30 @@
5500
5881
  return isIn(type) ^ dir < 0 ? percent : 1 - percent;
5501
5882
  }
5502
5883
 
5503
- var Animations = {
5504
- ...Animations$2,
5505
- fade: {
5506
- show() {
5507
- return [{ opacity: 0, zIndex: 0 }, { zIndex: -1 }];
5508
- },
5509
- percent(current) {
5510
- return 1 - css(current, "opacity");
5511
- },
5512
- translate(percent) {
5513
- return [{ opacity: 1 - percent, zIndex: 0 }, { zIndex: -1 }];
5514
- }
5884
+ var slideshow = {
5885
+ mixins: [Class, Slideshow, SliderReactive, SliderParallax, SliderPreload],
5886
+ props: {
5887
+ ratio: String,
5888
+ minHeight: String,
5889
+ maxHeight: String
5515
5890
  },
5516
- scale: {
5517
- show() {
5518
- return [{ opacity: 0, transform: scale3d(1 + 0.5), zIndex: 0 }, { zIndex: -1 }];
5519
- },
5520
- percent(current) {
5521
- return 1 - css(current, "opacity");
5522
- },
5523
- translate(percent) {
5524
- return [
5525
- { opacity: 1 - percent, transform: scale3d(1 + 0.5 * percent), zIndex: 0 },
5526
- { zIndex: -1 }
5527
- ];
5528
- }
5891
+ data: {
5892
+ ratio: "16:9",
5893
+ minHeight: void 0,
5894
+ maxHeight: void 0,
5895
+ selList: ".uk-slideshow-items",
5896
+ attrItem: "uk-slideshow-item",
5897
+ selNav: ".uk-slideshow-nav",
5898
+ Animations: Animations$1
5529
5899
  },
5530
- pull: {
5531
- show(dir) {
5532
- return dir < 0 ? [
5533
- { transform: translate(30), zIndex: -1 },
5534
- { transform: translate(), zIndex: 0 }
5535
- ] : [
5536
- { transform: translate(-100), zIndex: 0 },
5537
- { transform: translate(), zIndex: -1 }
5538
- ];
5539
- },
5540
- percent(current, next, dir) {
5541
- return dir < 0 ? 1 - translated(next) : translated(current);
5542
- },
5543
- translate(percent, dir) {
5544
- return dir < 0 ? [
5545
- { transform: translate(30 * percent), zIndex: -1 },
5546
- { transform: translate(-100 * (1 - percent)), zIndex: 0 }
5547
- ] : [
5548
- { transform: translate(-percent * 100), zIndex: 0 },
5549
- { transform: translate(30 * (1 - percent)), zIndex: -1 }
5550
- ];
5551
- }
5552
- },
5553
- push: {
5554
- show(dir) {
5555
- return dir < 0 ? [
5556
- { transform: translate(100), zIndex: 0 },
5557
- { transform: translate(), zIndex: -1 }
5558
- ] : [
5559
- { transform: translate(-30), zIndex: -1 },
5560
- { transform: translate(), zIndex: 0 }
5561
- ];
5562
- },
5563
- percent(current, next, dir) {
5564
- return dir > 0 ? 1 - translated(next) : translated(current);
5565
- },
5566
- translate(percent, dir) {
5567
- return dir < 0 ? [
5568
- { transform: translate(percent * 100), zIndex: 0 },
5569
- { transform: translate(-30 * (1 - percent)), zIndex: -1 }
5570
- ] : [
5571
- { transform: translate(-30 * percent), zIndex: -1 },
5572
- { transform: translate(100 * (1 - percent)), zIndex: 0 }
5573
- ];
5574
- }
5575
- }
5576
- };
5577
-
5578
- var slideshow = {
5579
- mixins: [Class, Slideshow, SliderReactive, SliderParallax, SliderPreload],
5580
- props: {
5581
- ratio: String,
5582
- minHeight: String,
5583
- maxHeight: String
5584
- },
5585
- data: {
5586
- ratio: "16:9",
5587
- minHeight: void 0,
5588
- maxHeight: void 0,
5589
- selList: ".uk-slideshow-items",
5590
- attrItem: "uk-slideshow-item",
5591
- selNav: ".uk-slideshow-nav",
5592
- Animations
5593
- },
5594
- watch: {
5595
- list(list) {
5596
- css(list, {
5597
- aspectRatio: this.ratio ? this.ratio.replace(":", "/") : void 0,
5598
- minHeight: this.minHeight,
5599
- maxHeight: this.maxHeight,
5600
- minWidth: "100%",
5601
- maxWidth: "100%"
5602
- });
5900
+ watch: {
5901
+ list(list) {
5902
+ css(list, {
5903
+ aspectRatio: this.ratio ? this.ratio.replace(":", "/") : void 0,
5904
+ minHeight: this.minHeight,
5905
+ maxHeight: this.maxHeight,
5906
+ width: "100%"
5907
+ });
5603
5908
  }
5604
5909
  },
5605
5910
  methods: {
@@ -5641,8 +5946,8 @@
5641
5946
  events: {
5642
5947
  name: pointerDown$1,
5643
5948
  passive: false,
5644
- handler() {
5645
- this.init();
5949
+ handler(e) {
5950
+ this.init(e);
5646
5951
  }
5647
5952
  },
5648
5953
  computed: {
@@ -5919,82 +6224,6 @@
5919
6224
  };
5920
6225
  }
5921
6226
 
5922
- var Position = {
5923
- props: {
5924
- pos: String,
5925
- offset: Boolean,
5926
- flip: Boolean,
5927
- shift: Boolean,
5928
- inset: Boolean
5929
- },
5930
- data: {
5931
- pos: `bottom-${isRtl ? "right" : "left"}`,
5932
- offset: false,
5933
- flip: true,
5934
- shift: true,
5935
- inset: false
5936
- },
5937
- connected() {
5938
- this.pos = this.$props.pos.split("-").concat("center").slice(0, 2);
5939
- [this.dir, this.align] = this.pos;
5940
- this.axis = includes(["top", "bottom"], this.dir) ? "y" : "x";
5941
- },
5942
- methods: {
5943
- positionAt(element, target, boundary) {
5944
- let offset = [this.getPositionOffset(element), this.getShiftOffset(element)];
5945
- const placement = [this.flip && "flip", this.shift && "shift"];
5946
- const attach = {
5947
- element: [this.inset ? this.dir : flipPosition(this.dir), this.align],
5948
- target: [this.dir, this.align]
5949
- };
5950
- if (this.axis === "y") {
5951
- for (const prop in attach) {
5952
- attach[prop].reverse();
5953
- }
5954
- offset.reverse();
5955
- placement.reverse();
5956
- }
5957
- const restoreScrollPosition = storeScrollPosition(element);
5958
- const elDim = dimensions$1(element);
5959
- css(element, { top: -elDim.height, left: -elDim.width });
5960
- positionAt(element, target, {
5961
- attach,
5962
- offset,
5963
- boundary,
5964
- placement,
5965
- viewportOffset: this.getViewportOffset(element)
5966
- });
5967
- restoreScrollPosition();
5968
- },
5969
- getPositionOffset(element = this.$el) {
5970
- return toPx(
5971
- this.offset === false ? css(element, "--uk-position-offset") : this.offset,
5972
- this.axis === "x" ? "width" : "height",
5973
- element
5974
- ) * (includes(["left", "top"], this.dir) ? -1 : 1) * (this.inset ? -1 : 1);
5975
- },
5976
- getShiftOffset(element = this.$el) {
5977
- return this.align === "center" ? 0 : toPx(
5978
- css(element, "--uk-position-shift-offset"),
5979
- this.axis === "y" ? "width" : "height",
5980
- element
5981
- ) * (includes(["left", "top"], this.align) ? 1 : -1);
5982
- },
5983
- getViewportOffset(element) {
5984
- return toPx(css(element, "--uk-position-viewport-offset"));
5985
- }
5986
- }
5987
- };
5988
- function storeScrollPosition(element) {
5989
- const scrollElement = scrollParent(element);
5990
- const { scrollTop } = scrollElement;
5991
- return () => {
5992
- if (scrollTop !== scrollElement.scrollTop) {
5993
- scrollElement.scrollTop = scrollTop;
5994
- }
5995
- };
5996
- }
5997
-
5998
6227
  var tooltip = {
5999
6228
  mixins: [Container, Togglable, Position],
6000
6229
  data: {
@@ -6683,7 +6912,7 @@
6683
6912
  ],
6684
6913
  observe: [
6685
6914
  intersection({
6686
- filter: ({ $el, autoplay }) => autoplay !== "hover" && isVideo($el),
6915
+ filter: ({ autoplay }) => autoplay !== "hover",
6687
6916
  handler([{ isIntersecting }]) {
6688
6917
  if (!document.fullscreenElement) {
6689
6918
  if (isIntersecting) {
@@ -6696,7 +6925,9 @@
6696
6925
  }
6697
6926
  },
6698
6927
  args: { intersecting: false },
6699
- options: ({ $el, autoplay }) => ({ root: autoplay === "inview" ? null : parent($el) })
6928
+ options: ({ $el, autoplay }) => ({
6929
+ root: autoplay === "inview" ? null : parent($el).closest(":not(a)")
6930
+ })
6700
6931
  })
6701
6932
  ]
6702
6933
  };
@@ -7596,7 +7827,7 @@
7596
7827
  let rowHeights = 0;
7597
7828
  for (let row of rows) {
7598
7829
  if (isRtl) {
7599
- row = row.reverse();
7830
+ row.reverse();
7600
7831
  }
7601
7832
  let height = 0;
7602
7833
  for (const j in row) {
@@ -7891,107 +8122,6 @@
7891
8122
  dimensions.forEach((val, i) => attr(el, props[i], toFloat(val) * this.ratio || null));
7892
8123
  }
7893
8124
 
7894
- var svg = {
7895
- mixins: [Svg],
7896
- args: "src",
7897
- props: {
7898
- src: String,
7899
- icon: String,
7900
- attributes: "list",
7901
- strokeAnimation: Boolean
7902
- },
7903
- data: {
7904
- strokeAnimation: false
7905
- },
7906
- observe: [
7907
- mutation({
7908
- async handler() {
7909
- const svg = await this.svg;
7910
- if (svg) {
7911
- applyAttributes.call(this, svg);
7912
- }
7913
- },
7914
- options: {
7915
- attributes: true,
7916
- attributeFilter: ["id", "class", "style"]
7917
- }
7918
- })
7919
- ],
7920
- async connected() {
7921
- if (includes(this.src, "#")) {
7922
- [this.src, this.icon] = this.src.split("#");
7923
- }
7924
- const svg = await this.svg;
7925
- if (svg) {
7926
- applyAttributes.call(this, svg);
7927
- if (this.strokeAnimation) {
7928
- applyAnimation(svg);
7929
- }
7930
- }
7931
- },
7932
- methods: {
7933
- async getSvg() {
7934
- if (isTag(this.$el, "img") && !this.$el.complete && this.$el.loading === "lazy") {
7935
- await new Promise((resolve) => once(this.$el, "load", resolve));
7936
- }
7937
- return parseSVG(await loadSVG(this.src), this.icon) || Promise.reject("SVG not found.");
7938
- }
7939
- }
7940
- };
7941
- function applyAttributes(el) {
7942
- const { $el } = this;
7943
- addClass(el, attr($el, "class"), "uk-svg");
7944
- for (let i = 0; i < $el.style.length; i++) {
7945
- const prop = $el.style[i];
7946
- css(el, prop, css($el, prop));
7947
- }
7948
- for (const attribute in this.attributes) {
7949
- const [prop, value] = this.attributes[attribute].split(":", 2);
7950
- attr(el, prop, value);
7951
- }
7952
- if (!this.$el.id) {
7953
- removeAttr(el, "id");
7954
- }
7955
- }
7956
- const loadSVG = memoize(async (src) => {
7957
- if (src) {
7958
- if (startsWith(src, "data:")) {
7959
- return decodeURIComponent(src.split(",")[1]);
7960
- } else {
7961
- return (await fetch(src)).text();
7962
- }
7963
- } else {
7964
- return Promise.reject();
7965
- }
7966
- });
7967
- function parseSVG(svg, icon) {
7968
- if (icon && includes(svg, "<symbol")) {
7969
- svg = parseSymbols(svg)[icon] || svg;
7970
- }
7971
- return stringToSvg(svg);
7972
- }
7973
- const symbolRe = /<symbol([^]*?id=(['"])(.+?)\2[^]*?<\/)symbol>/g;
7974
- const parseSymbols = memoize(function(svg) {
7975
- const symbols = {};
7976
- symbolRe.lastIndex = 0;
7977
- let match;
7978
- while (match = symbolRe.exec(svg)) {
7979
- symbols[match[3]] = `<svg ${match[1]}svg>`;
7980
- }
7981
- return symbols;
7982
- });
7983
- function applyAnimation(el) {
7984
- const length = getMaxPathLength(el);
7985
- if (length) {
7986
- css(el, "--uk-animation-stroke", length);
7987
- }
7988
- }
7989
- function stringToSvg(string) {
7990
- const container = document.createElement("template");
7991
- container.innerHTML = string;
7992
- return container.content.firstElementChild;
7993
- }
7994
-
7995
8125
  const icons = {
7996
8126
  spinner,
7997
8127
  totop,
@@ -8162,7 +8292,7 @@
8162
8292
  return null;
8163
8293
  }
8164
8294
  if (!parsed[icon]) {
8165
- parsed[icon] = stringToSvg(icons[applyRtl(icon)] || icons[icon]);
8295
+ parsed[icon] = fragment(icons[applyRtl(icon)] || icons[icon]);
8166
8296
  }
8167
8297
  return parsed[icon].cloneNode(true);
8168
8298
  }
@@ -8170,123 +8300,6 @@
8170
8300
  return isRtl ? swap(swap(icon, "left", "right"), "previous", "next") : icon;
8171
8301
  }
8172
8302
 
8173
- var img = {
8174
- args: "dataSrc",
8175
- props: {
8176
- dataSrc: String,
8177
- sources: String,
8178
- margin: String,
8179
- target: String,
8180
- loading: String
8181
- },
8182
- data: {
8183
- dataSrc: "",
8184
- sources: false,
8185
- margin: "50%",
8186
- target: false,
8187
- loading: "lazy"
8188
- },
8189
- connected() {
8190
- if (this.loading !== "lazy") {
8191
- this.load();
8192
- } else if (isImg(this.$el)) {
8193
- this.$el.loading = "lazy";
8194
- setSrcAttrs(this.$el);
8195
- }
8196
- },
8197
- disconnected() {
8198
- if (this.img) {
8199
- this.img.onload = "";
8200
- }
8201
- delete this.img;
8202
- },
8203
- observe: intersection({
8204
- handler(entries, observer) {
8205
- this.load();
8206
- observer.disconnect();
8207
- },
8208
- options: ({ margin }) => ({ rootMargin: margin }),
8209
- filter: ({ loading }) => loading === "lazy",
8210
- target: ({ $el, $props }) => $props.target ? [$el, ...queryAll($props.target, $el)] : $el
8211
- }),
8212
- methods: {
8213
- load() {
8214
- if (this.img) {
8215
- return this.img;
8216
- }
8217
- const image = isImg(this.$el) ? this.$el : getImageFromElement(this.$el, this.dataSrc, this.sources);
8218
- removeAttr(image, "loading");
8219
- setSrcAttrs(this.$el, image.currentSrc);
8220
- return this.img = image;
8221
- }
8222
- }
8223
- };
8224
- function setSrcAttrs(el, src) {
8225
- if (isImg(el)) {
8226
- const parentNode = parent(el);
8227
- const elements = isTag(parentNode, "picture") ? children(parentNode) : [el];
8228
- elements.forEach((el2) => setSourceProps(el2, el2));
8229
- } else if (src) {
8230
- const change = !includes(el.style.backgroundImage, src);
8231
- if (change) {
8232
- css(el, "backgroundImage", `url(${escape(src)})`);
8233
- trigger(el, createEvent("load", false));
8234
- }
8235
- }
8236
- }
8237
- const srcProps = ["data-src", "data-srcset", "sizes"];
8238
- function setSourceProps(sourceEl, targetEl) {
8239
- for (const prop of srcProps) {
8240
- const value = data(sourceEl, prop);
8241
- if (value) {
8242
- attr(targetEl, prop.replace(/^(data-)+/, ""), value);
8243
- }
8244
- }
8245
- }
8246
- function getImageFromElement(el, src, sources) {
8247
- const img = new Image();
8248
- wrapInPicture(img, sources);
8249
- setSourceProps(el, img);
8250
- img.onload = () => {
8251
- setSrcAttrs(el, img.currentSrc);
8252
- };
8253
- attr(img, "src", src);
8254
- return img;
8255
- }
8256
- function wrapInPicture(img, sources) {
8257
- sources = parseSources(sources);
8258
- if (sources.length) {
8259
- const picture = fragment("<picture>");
8260
- for (const attrs of sources) {
8261
- const source = fragment("<source>");
8262
- attr(source, attrs);
8263
- append(picture, source);
8264
- }
8265
- append(picture, img);
8266
- }
8267
- }
8268
- function parseSources(sources) {
8269
- if (!sources) {
8270
- return [];
8271
- }
8272
- if (startsWith(sources, "[")) {
8273
- try {
8274
- sources = JSON.parse(sources);
8275
- } catch (e) {
8276
- sources = [];
8277
- }
8278
- } else {
8279
- sources = parseOptions(sources);
8280
- }
8281
- if (!isArray(sources)) {
8282
- sources = [sources];
8283
- }
8284
- return sources.filter((source) => !isEmpty(source));
8285
- }
8286
- function isImg(el) {
8287
- return isTag(el, "img");
8288
- }
8289
-
8290
8303
  var inverse = {
8291
8304
  props: {
8292
8305
  target: String,
@@ -8601,7 +8614,10 @@
8601
8614
  {
8602
8615
  name: "hide",
8603
8616
  el: ({ dropContainer }) => dropContainer,
8604
- async handler() {
8617
+ async handler(e) {
8618
+ if (parent(e.target) !== this.dropContainer) {
8619
+ return;
8620
+ }
8605
8621
  await awaitMacroTask();
8606
8622
  if (!this.getActive() && this._transparent) {
8607
8623
  addClass(this.navbarContainer, clsNavbarTransparent);
@@ -8990,7 +9006,7 @@
8990
9006
  update: [
8991
9007
  {
8992
9008
  read() {
8993
- const targets = this.links.map((el) => getTargetedElement(el) || el.ownerDocument);
9009
+ const targets = this.links.map((el) => getTargetedElement(el)).filter(Boolean);
8994
9010
  const { length } = targets;
8995
9011
  if (!length || !isVisible(this.$el)) {
8996
9012
  return false;
@@ -9389,6 +9405,104 @@
9389
9405
  }
9390
9406
  }
9391
9407
 
9408
+ var svg = {
9409
+ mixins: [Svg],
9410
+ args: "src",
9411
+ props: {
9412
+ src: String,
9413
+ icon: String,
9414
+ attributes: "list",
9415
+ strokeAnimation: Boolean
9416
+ },
9417
+ data: {
9418
+ strokeAnimation: false
9419
+ },
9420
+ observe: [
9421
+ mutation({
9422
+ async handler() {
9423
+ const svg = await this.svg;
9424
+ if (svg) {
9425
+ applyAttributes.call(this, svg);
9426
+ }
9427
+ },
9428
+ options: {
9429
+ attributes: true,
9430
+ attributeFilter: ["id", "class", "style"]
9431
+ }
9432
+ })
9433
+ ],
9434
+ async connected() {
9435
+ if (includes(this.src, "#")) {
9436
+ [this.src, this.icon] = this.src.split("#");
9437
+ }
9438
+ const svg = await this.svg;
9439
+ if (svg) {
9440
+ applyAttributes.call(this, svg);
9441
+ if (this.strokeAnimation) {
9442
+ applyAnimation(svg);
9443
+ }
9444
+ }
9445
+ },
9446
+ methods: {
9447
+ async getSvg() {
9448
+ if (isTag(this.$el, "img") && !this.$el.complete && this.$el.loading === "lazy") {
9449
+ await new Promise((resolve) => once(this.$el, "load", resolve));
9450
+ }
9451
+ return parseSVG(await loadSVG(this.src), this.icon) || Promise.reject("SVG not found.");
9452
+ }
9453
+ }
9454
+ };
9455
+ function applyAttributes(el) {
9456
+ const { $el } = this;
9457
+ addClass(el, attr($el, "class"), "uk-svg");
9458
+ for (let i = 0; i < $el.style.length; i++) {
9459
+ const prop = $el.style[i];
9460
+ css(el, prop, css($el, prop));
9461
+ }
9462
+ for (const attribute in this.attributes) {
9463
+ const [prop, value] = this.attributes[attribute].split(":", 2);
9464
+ attr(el, prop, value);
9465
+ }
9466
+ if (!this.$el.id) {
9467
+ removeAttr(el, "id");
9468
+ }
9469
+ }
9470
+ const loadSVG = memoize(async (src) => {
9471
+ if (src) {
9472
+ if (startsWith(src, "data:")) {
9473
+ return decodeURIComponent(src.split(",")[1]);
9474
+ } else {
9475
+ const response = await fetch(src);
9476
+ if (response.headers.get("Content-Type") === "image/svg+xml") {
9477
+ return response.text();
9478
+ }
9479
+ }
9480
+ }
9481
+ return Promise.reject();
9482
+ });
9483
+ function parseSVG(svg, icon) {
9484
+ if (icon && includes(svg, "<symbol")) {
9485
+ svg = parseSymbols(svg)[icon] || svg;
9486
+ }
9487
+ return fragment(svg);
9488
+ }
9489
+ const symbolRe = /<symbol([^]*?id=(['"])(.+?)\2[^]*?<\/)symbol>/g;
9490
+ const parseSymbols = memoize(function(svg) {
9491
+ const symbols = {};
9492
+ symbolRe.lastIndex = 0;
9493
+ let match;
9494
+ while (match = symbolRe.exec(svg)) {
9495
+ symbols[match[3]] = `<svg ${match[1]}svg>`;
9496
+ }
9497
+ return symbols;
9498
+ });
9499
+ function applyAnimation(el) {
9500
+ const length = getMaxPathLength(el);
9501
+ if (length) {
9502
+ css(el, "--uk-animation-stroke", length);
9503
+ }
9504
+ }
9505
+
9392
9506
  const selDisabled = ".uk-disabled *, .uk-disabled, [disabled]";
9393
9507
  var Switcher = {
9394
9508
  mixins: [Togglable],