uikit 3.13.10 → 3.13.11-dev.1296bb84c

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 (100) hide show
  1. package/CHANGELOG.md +33 -1
  2. package/dist/css/uikit-core-rtl.css +49 -8
  3. package/dist/css/uikit-core-rtl.min.css +1 -1
  4. package/dist/css/uikit-core.css +49 -8
  5. package/dist/css/uikit-core.min.css +1 -1
  6. package/dist/css/uikit-rtl.css +49 -6
  7. package/dist/css/uikit-rtl.min.css +1 -1
  8. package/dist/css/uikit.css +49 -6
  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 +1 -1
  13. package/dist/js/components/filter.min.js +1 -1
  14. package/dist/js/components/lightbox-panel.js +7 -3
  15. package/dist/js/components/lightbox-panel.min.js +1 -1
  16. package/dist/js/components/lightbox.js +7 -3
  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 +21 -12
  21. package/dist/js/components/parallax.min.js +1 -1
  22. package/dist/js/components/slider-parallax.js +21 -12
  23. package/dist/js/components/slider-parallax.min.js +1 -1
  24. package/dist/js/components/slider.js +2 -2
  25. package/dist/js/components/slider.min.js +1 -1
  26. package/dist/js/components/slideshow-parallax.js +21 -12
  27. package/dist/js/components/slideshow-parallax.min.js +1 -1
  28. package/dist/js/components/slideshow.js +1 -1
  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 +62 -30
  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 +422 -299
  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 +469 -307
  41. package/dist/js/uikit.min.js +1 -1
  42. package/package.json +1 -1
  43. package/src/js/components/slider.js +1 -1
  44. package/src/js/components/sortable.js +2 -3
  45. package/src/js/components/tooltip.js +38 -3
  46. package/src/js/core/cover.js +27 -14
  47. package/src/js/core/drop.js +40 -11
  48. package/src/js/core/height-match.js +1 -1
  49. package/src/js/core/margin.js +9 -2
  50. package/src/js/core/navbar.js +18 -6
  51. package/src/js/core/scrollspy-nav.js +6 -11
  52. package/src/js/core/sticky.js +55 -21
  53. package/src/js/mixin/media.js +12 -9
  54. package/src/js/mixin/modal.js +6 -2
  55. package/src/js/mixin/parallax.js +8 -3
  56. package/src/js/mixin/position.js +24 -24
  57. package/src/js/uikit-core.js +0 -4
  58. package/src/js/util/lang.js +34 -42
  59. package/src/js/util/position.js +180 -125
  60. package/src/js/util/viewport.js +42 -22
  61. package/src/less/components/drop.less +0 -1
  62. package/src/less/components/dropdown.less +11 -1
  63. package/src/less/components/icon.less +3 -0
  64. package/src/less/components/nav.less +23 -0
  65. package/src/less/components/navbar.less +26 -2
  66. package/src/less/components/search.less +2 -0
  67. package/src/less/components/sticky.less +8 -3
  68. package/src/less/components/utility.less +1 -0
  69. package/src/less/theme/dropdown.less +4 -0
  70. package/src/less/theme/nav.less +6 -0
  71. package/src/less/theme/navbar.less +4 -0
  72. package/src/less/theme/search.less +6 -0
  73. package/src/scss/components/drop.scss +0 -1
  74. package/src/scss/components/dropdown.scss +11 -1
  75. package/src/scss/components/icon.scss +3 -0
  76. package/src/scss/components/nav.scss +23 -0
  77. package/src/scss/components/navbar.scss +26 -2
  78. package/src/scss/components/search.scss +2 -0
  79. package/src/scss/components/sticky.scss +8 -3
  80. package/src/scss/components/utility.scss +1 -0
  81. package/src/scss/mixins-theme.scss +5 -0
  82. package/src/scss/mixins.scss +5 -0
  83. package/src/scss/theme/dropdown.scss +4 -0
  84. package/src/scss/theme/nav.scss +6 -0
  85. package/src/scss/theme/navbar.scss +4 -0
  86. package/src/scss/theme/search.scss +6 -0
  87. package/src/scss/variables-theme.scss +5 -1
  88. package/src/scss/variables.scss +5 -1
  89. package/tests/alert.html +1 -1
  90. package/tests/animation.html +216 -214
  91. package/tests/drop.html +154 -80
  92. package/tests/dropdown.html +16 -2
  93. package/tests/nav.html +27 -0
  94. package/tests/navbar.html +56 -5
  95. package/tests/parallax.html +5 -5
  96. package/tests/position.html +38 -39
  97. package/tests/sticky-navbar.html +6 -6
  98. package/tests/sticky-parallax.html +29 -13
  99. package/tests/sticky.html +300 -49
  100. package/src/js/core/core.js +0 -25
@@ -1,4 +1,4 @@
1
- /*! UIkit 3.13.10 | https://www.getuikit.com | (c) 2014 - 2022 YOOtheme | MIT License */
1
+ /*! UIkit 3.13.11-dev.1296bb84c | https://www.getuikit.com | (c) 2014 - 2022 YOOtheme | MIT License */
2
2
 
3
3
  (function (global, factory) {
4
4
  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
@@ -141,10 +141,6 @@
141
141
  return (document == null ? void 0 : document.defaultView) || window;
142
142
  }
143
143
 
144
- function toMs(time) {
145
- return time ? endsWith(time, 'ms') ? toFloat(time) : toFloat(time) * 1000 : 0;
146
- }
147
-
148
144
  function isEqual(value, other) {
149
145
  return (
150
146
  value === other ||
@@ -212,48 +208,44 @@
212
208
 
213
209
  }
214
210
 
215
- const Dimensions = {
216
- ratio(dimensions, prop, value) {
217
- const aProp = prop === 'width' ? 'height' : 'width';
211
+ function ratio(dimensions, prop, value) {
212
+ const aProp = prop === 'width' ? 'height' : 'width';
218
213
 
219
- return {
220
- [aProp]: dimensions[prop] ?
221
- Math.round(value * dimensions[aProp] / dimensions[prop]) :
222
- dimensions[aProp],
223
- [prop]: value };
214
+ return {
215
+ [aProp]: dimensions[prop] ?
216
+ Math.round(value * dimensions[aProp] / dimensions[prop]) :
217
+ dimensions[aProp],
218
+ [prop]: value };
224
219
 
225
- },
220
+ }
226
221
 
227
- contain(dimensions, maxDimensions) {
228
- dimensions = { ...dimensions };
222
+ function contain(dimensions, maxDimensions) {
223
+ dimensions = { ...dimensions };
229
224
 
230
- each(
231
- dimensions,
232
- (_, prop) =>
225
+ for (const prop in dimensions) {
233
226
  dimensions =
234
227
  dimensions[prop] > maxDimensions[prop] ?
235
- this.ratio(dimensions, prop, maxDimensions[prop]) :
236
- dimensions);
237
-
228
+ ratio(dimensions, prop, maxDimensions[prop]) :
229
+ dimensions;
230
+ }
238
231
 
239
- return dimensions;
240
- },
232
+ return dimensions;
233
+ }
241
234
 
242
- cover(dimensions, maxDimensions) {
243
- dimensions = this.contain(dimensions, maxDimensions);
235
+ function cover$1(dimensions, maxDimensions) {
236
+ dimensions = contain(dimensions, maxDimensions);
244
237
 
245
- each(
246
- dimensions,
247
- (_, prop) =>
238
+ for (const prop in dimensions) {
248
239
  dimensions =
249
240
  dimensions[prop] < maxDimensions[prop] ?
250
- this.ratio(dimensions, prop, maxDimensions[prop]) :
251
- dimensions);
252
-
241
+ ratio(dimensions, prop, maxDimensions[prop]) :
242
+ dimensions;
243
+ }
253
244
 
254
- return dimensions;
255
- } };
245
+ return dimensions;
246
+ }
256
247
 
248
+ const Dimensions = { ratio, contain, cover: cover$1 };
257
249
 
258
250
  function getIndex(i, elements, current, finite) {if (current === void 0) {current = 0;}if (finite === void 0) {finite = false;}
259
251
  elements = toNodes(elements);
@@ -1788,7 +1780,7 @@
1788
1780
  return intersectRect(
1789
1781
  ...scrollParents(element).
1790
1782
  map((parent) => {
1791
- const { top, left, bottom, right } = offset(getViewport$1(parent));
1783
+ const { top, left, bottom, right } = offsetViewport(parent);
1792
1784
 
1793
1785
  return {
1794
1786
  top: top - offsetTop,
@@ -1803,7 +1795,7 @@
1803
1795
 
1804
1796
  function scrollTop(element, top) {
1805
1797
  if (isWindow(element) || isDocument(element)) {
1806
- element = getScrollingElement(element);
1798
+ element = scrollingElement(element);
1807
1799
  } else {
1808
1800
  element = toNode(element);
1809
1801
  }
@@ -1820,12 +1812,13 @@
1820
1812
  return parents.reduce(
1821
1813
  (fn, scrollElement, i) => {
1822
1814
  const { scrollTop, scrollHeight, offsetHeight } = scrollElement;
1823
- const maxScroll = scrollHeight - getViewportClientHeight(scrollElement);
1824
- const { height: elHeight, top: elTop } = offset(parents[i - 1] || element);
1825
-
1826
- let top = Math.ceil(
1827
- elTop - offset(getViewport$1(scrollElement)).top - offsetBy + scrollTop);
1815
+ const viewport = offsetViewport(scrollElement);
1816
+ const maxScroll = scrollHeight - viewport.height;
1817
+ const { height: elHeight, top: elTop } = parents[i - 1] ?
1818
+ offsetViewport(parents[i - 1]) :
1819
+ offset(element);
1828
1820
 
1821
+ let top = Math.ceil(elTop - viewport.top - offsetBy + scrollTop);
1829
1822
 
1830
1823
  if (offsetBy > 0 && offsetHeight < elHeight + offsetBy) {
1831
1824
  top += offsetBy;
@@ -1883,7 +1876,7 @@
1883
1876
 
1884
1877
  const [scrollElement] = scrollParents(element, /auto|scroll/, true);
1885
1878
  const { scrollHeight, scrollTop } = scrollElement;
1886
- const viewportHeight = getViewportClientHeight(scrollElement);
1879
+ const { height: viewportHeight } = offsetViewport(scrollElement);
1887
1880
  const maxScroll = scrollHeight - viewportHeight;
1888
1881
  const elementOffsetTop = offsetPosition(element)[0] - offsetPosition(scrollElement)[0];
1889
1882
 
@@ -1894,7 +1887,7 @@
1894
1887
  }
1895
1888
 
1896
1889
  function scrollParents(element, overflowRe, scrollable) {if (overflowRe === void 0) {overflowRe = /auto|scroll|hidden/;}if (scrollable === void 0) {scrollable = false;}
1897
- const scrollEl = getScrollingElement(element);
1890
+ const scrollEl = scrollingElement(element);
1898
1891
 
1899
1892
  let ancestors = parents(element).reverse();
1900
1893
  ancestors = ancestors.slice(ancestors.indexOf(scrollEl) + 1);
@@ -1909,181 +1902,253 @@
1909
1902
  ancestors.filter(
1910
1903
  (parent) =>
1911
1904
  overflowRe.test(css(parent, 'overflow')) && (
1912
- !scrollable || parent.scrollHeight > getViewportClientHeight(parent)))).
1905
+ !scrollable || parent.scrollHeight > offsetViewport(parent).height))).
1913
1906
 
1914
1907
 
1915
1908
  reverse();
1916
1909
  }
1917
1910
 
1918
- function getViewport$1(scrollElement) {
1919
- return scrollElement === getScrollingElement(scrollElement) ? window : scrollElement;
1911
+ function offsetViewport(scrollElement) {
1912
+ let viewportElement = getViewport$1(scrollElement);
1913
+
1914
+ // iOS 12 returns <body> as scrollingElement
1915
+ if (viewportElement === scrollingElement(viewportElement)) {
1916
+ viewportElement = document.documentElement;
1917
+ }
1918
+
1919
+ let rect = offset(viewportElement);
1920
+ for (let [prop, dir, start, end] of [
1921
+ ['width', 'x', 'left', 'right'],
1922
+ ['height', 'y', 'top', 'bottom']])
1923
+ {
1924
+ if (!isWindow(getViewport$1(viewportElement))) {
1925
+ rect[start] += toFloat(css(viewportElement, "border" + ucfirst(start) + "Width"));
1926
+ }
1927
+ rect[prop] = rect[dir] = (
1928
+ isWindow(viewportElement) ? scrollingElement(viewportElement) : viewportElement)["client" +
1929
+ ucfirst(prop)];
1930
+ rect[end] = rect[prop] + rect[start];
1931
+ }
1932
+ return rect;
1920
1933
  }
1921
1934
 
1922
- // iOS 12 returns <body> as scrollingElement
1923
- function getViewportClientHeight(scrollElement) {
1924
- return (
1925
- scrollElement === getScrollingElement(scrollElement) ?
1926
- document.documentElement :
1927
- scrollElement).
1928
- clientHeight;
1935
+ function scrollingElement(element) {
1936
+ const {
1937
+ document: { scrollingElement } } =
1938
+ toWindow(element);
1939
+ return scrollingElement;
1929
1940
  }
1930
1941
 
1931
- function getScrollingElement(element) {
1932
- const { document } = toWindow(element);
1933
- return document.scrollingElement || document.documentElement;
1942
+ function getViewport$1(scrollElement) {
1943
+ return scrollElement === scrollingElement(scrollElement) ? window : scrollElement;
1934
1944
  }
1935
1945
 
1936
- const dirs = {
1937
- width: ['x', 'left', 'right'],
1938
- height: ['y', 'top', 'bottom'] };
1946
+ const dirs = [
1947
+ ['width', 'x', 'left', 'right'],
1948
+ ['height', 'y', 'top', 'bottom']];
1949
+
1950
+
1951
+ function positionAt(element, target, options) {
1952
+ options = {
1953
+ attach: {
1954
+ element: ['left', 'top'],
1955
+ target: ['left', 'top'],
1956
+ ...options.attach },
1957
+
1958
+ offset: [0, 0],
1959
+ ...options };
1960
+
1961
+
1962
+ const dim = options.flip ?
1963
+ attachToWithFlip(element, target, options) :
1964
+ attachTo(element, target, options);
1965
+
1966
+ offset(element, dim);
1967
+ }
1939
1968
 
1969
+ function attachTo(element, target, options) {
1970
+ let { attach, offset: offsetBy } = {
1971
+ attach: {
1972
+ element: ['left', 'top'],
1973
+ target: ['left', 'top'],
1974
+ ...options.attach },
1940
1975
 
1941
- function positionAt(
1942
- element,
1943
- target,
1944
- elAttach,
1945
- targetAttach,
1946
- elOffset,
1947
- targetOffset,
1948
- flip,
1949
- boundary)
1950
- {
1951
- elAttach = getPos(elAttach);
1952
- targetAttach = getPos(targetAttach);
1976
+ offset: [0, 0],
1977
+ ...options };
1953
1978
 
1954
- const flipped = { element: elAttach, target: targetAttach };
1955
1979
 
1956
- if (!element || !target) {
1957
- return flipped;
1980
+ const position = offset(element);
1981
+ const targetOffset = offset(target);
1982
+ for (const [i, [prop, dir, start, end]] of Object.entries(dirs)) {
1983
+ position[start] = position[dir] =
1984
+ targetOffset[start] +
1985
+ moveBy(attach.target[i], end, targetOffset[prop]) -
1986
+ moveBy(attach.element[i], end, position[prop]) +
1987
+ +offsetBy[i];
1988
+ position[end] = position[start] + position[prop];
1958
1989
  }
1990
+ return position;
1991
+ }
1959
1992
 
1960
- const dim = offset(element);
1993
+ function attachToWithFlip(element, target, options) {
1994
+ const position = attachTo(element, target, options);
1961
1995
  const targetDim = offset(target);
1962
- const position = targetDim;
1963
1996
 
1964
- moveTo(position, elAttach, dim, -1);
1965
- moveTo(position, targetAttach, targetDim, 1);
1997
+ let {
1998
+ flip,
1999
+ attach: { element: elAttach, target: targetAttach },
2000
+ offset: elOffset,
2001
+ boundary,
2002
+ viewport,
2003
+ viewportPadding } =
2004
+ options;
2005
+
2006
+ let viewports = scrollParents(element);
2007
+ if (boundary === target) {
2008
+ viewports = viewports.filter((viewport) => viewport !== boundary);
2009
+ }
2010
+ const [scrollElement] = viewports;
2011
+ viewports.push(viewport);
1966
2012
 
1967
- elOffset = getOffsets(elOffset, dim.width, dim.height);
1968
- targetOffset = getOffsets(targetOffset, targetDim.width, targetDim.height);
2013
+ const offsetPosition = { ...position };
2014
+ for (const [i, [prop, dir, start, end]] of Object.entries(dirs)) {
2015
+ if (flip !== true && !includes(flip, dir)) {
2016
+ continue;
2017
+ }
1969
2018
 
1970
- elOffset['x'] += targetOffset['x'];
1971
- elOffset['y'] += targetOffset['y'];
2019
+ const willFlip =
2020
+ !intersectLine(position, targetDim, i) && intersectLine(position, targetDim, 1 - i);
1972
2021
 
1973
- position.left += elOffset['x'];
1974
- position.top += elOffset['y'];
2022
+ viewport = getIntersectionArea(...viewports.filter(Boolean).map(offsetViewport));
1975
2023
 
1976
- if (flip) {
1977
- let boundaries = scrollParents(element).map(getViewport$1);
2024
+ if (viewportPadding) {
2025
+ viewport[start] += viewportPadding;
2026
+ viewport[end] -= viewportPadding;
2027
+ }
1978
2028
 
1979
- if (boundary && !includes(boundaries, boundary)) {
1980
- boundaries.unshift(boundary);
2029
+ if (boundary && !willFlip && position[prop] <= offset(boundary)[prop]) {
2030
+ viewport = getIntersectionArea(viewport, offset(boundary));
1981
2031
  }
1982
2032
 
1983
- boundaries = boundaries.map((el) => offset(el));
2033
+ const isInStartBoundary = position[start] >= viewport[start];
2034
+ const isInEndBoundary = position[end] <= viewport[end];
1984
2035
 
1985
- each(dirs, (_ref, prop) => {let [dir, align, alignFlip] = _ref;
1986
- if (!(flip === true || includes(flip, dir))) {
1987
- return;
1988
- }
2036
+ if (isInStartBoundary && isInEndBoundary) {
2037
+ continue;
2038
+ }
1989
2039
 
1990
- boundaries.some((boundary) => {
1991
- const elemOffset =
1992
- elAttach[dir] === align ?
1993
- -dim[prop] :
1994
- elAttach[dir] === alignFlip ?
1995
- dim[prop] :
1996
- 0;
2040
+ let offsetBy;
1997
2041
 
1998
- const targetOffset =
1999
- targetAttach[dir] === align ?
2000
- targetDim[prop] :
2001
- targetAttach[dir] === alignFlip ?
2002
- -targetDim[prop] :
2003
- 0;
2042
+ // Flip
2043
+ if (willFlip) {
2044
+ if (
2045
+ elAttach[i] === end && isInStartBoundary ||
2046
+ elAttach[i] === start && isInEndBoundary)
2047
+ {
2048
+ continue;
2049
+ }
2004
2050
 
2005
- if (
2006
- position[align] < boundary[align] ||
2007
- position[align] + dim[prop] > boundary[alignFlip])
2008
- {
2009
- const centerOffset = dim[prop] / 2;
2010
- const centerTargetOffset =
2011
- targetAttach[dir] === 'center' ? -targetDim[prop] / 2 : 0;
2051
+ offsetBy =
2052
+ (elAttach[i] === start ?
2053
+ -position[prop] :
2054
+ elAttach[i] === end ?
2055
+ position[prop] :
2056
+ 0) + (
2057
+ targetAttach[i] === start ?
2058
+ targetDim[prop] :
2059
+ targetAttach[i] === end ?
2060
+ -targetDim[prop] :
2061
+ 0) -
2062
+ elOffset[i] * 2;
2063
+
2064
+ if (
2065
+ !isInScrollArea(
2066
+ {
2067
+ ...position,
2068
+ [start]: position[start] + offsetBy,
2069
+ [end]: position[end] + offsetBy },
2012
2070
 
2013
- return (
2014
- elAttach[dir] === 'center' && (
2015
- apply(centerOffset, centerTargetOffset) ||
2016
- apply(-centerOffset, -centerTargetOffset)) ||
2017
- apply(elemOffset, targetOffset));
2071
+ scrollElement,
2072
+ i))
2018
2073
 
2074
+ {
2075
+ if (isInScrollArea(position, scrollElement, i)) {
2076
+ continue;
2019
2077
  }
2020
2078
 
2021
- function apply(elemOffset, targetOffset) {
2022
- const newVal = toFloat(
2023
- (position[align] + elemOffset + targetOffset - elOffset[dir] * 2).toFixed(4));
2079
+ if (options.recursion) {
2080
+ return false;
2081
+ }
2024
2082
 
2083
+ const newPos = attachToWithFlip(element, target, {
2084
+ ...options,
2085
+ attach: {
2086
+ element: elAttach.map(flipDir).reverse(),
2087
+ target: targetAttach.map(flipDir).reverse() },
2025
2088
 
2026
- if (newVal >= boundary[align] && newVal + dim[prop] <= boundary[alignFlip]) {
2027
- position[align] = newVal;
2089
+ offset: elOffset.reverse(),
2090
+ flip: flip === true ? flip : [...flip, dirs[1 - i][1]],
2091
+ recursion: true });
2028
2092
 
2029
- for (const el of ['element', 'target']) {
2030
- if (elemOffset) {
2031
- flipped[el][dir] =
2032
- flipped[el][dir] === dirs[prop][1] ?
2033
- dirs[prop][2] :
2034
- dirs[prop][1];
2035
- }
2036
- }
2037
2093
 
2038
- return true;
2039
- }
2094
+ if (newPos && isInScrollArea(newPos, scrollElement, 1 - i)) {
2095
+ return newPos;
2040
2096
  }
2041
- });
2042
- });
2043
- }
2097
+ }
2044
2098
 
2045
- offset(element, position);
2099
+ // Move
2100
+ } else {
2101
+ offsetBy =
2102
+ clamp(
2103
+ clamp(position[start], viewport[start], viewport[end] - position[prop]),
2104
+ targetDim[start] - position[prop] + elOffset[i],
2105
+ targetDim[end] - elOffset[i]) -
2106
+ position[start];
2107
+ }
2046
2108
 
2047
- return flipped;
2048
- }
2109
+ offsetPosition[start] = position[dir] = position[start] + offsetBy;
2110
+ offsetPosition[end] += offsetBy;
2111
+ }
2049
2112
 
2050
- function moveTo(position, attach, dim, factor) {
2051
- each(dirs, (_ref2, prop) => {let [dir, align, alignFlip] = _ref2;
2052
- if (attach[dir] === alignFlip) {
2053
- position[align] += dim[prop] * factor;
2054
- } else if (attach[dir] === 'center') {
2055
- position[align] += dim[prop] * factor / 2;
2056
- }
2057
- });
2113
+ return offsetPosition;
2058
2114
  }
2059
2115
 
2060
- function getPos(pos) {
2061
- const x = /left|center|right/;
2062
- const y = /top|center|bottom/;
2063
-
2064
- pos = (pos || '').split(' ');
2116
+ function moveBy(start, end, dim) {
2117
+ return start === 'center' ? dim / 2 : start === end ? dim : 0;
2118
+ }
2065
2119
 
2066
- if (pos.length === 1) {
2067
- pos = x.test(pos[0]) ?
2068
- pos.concat('center') :
2069
- y.test(pos[0]) ?
2070
- ['center'].concat(pos) :
2071
- ['center', 'center'];
2120
+ function getIntersectionArea() {
2121
+ let area = {};for (var _len = arguments.length, rects = new Array(_len), _key = 0; _key < _len; _key++) {rects[_key] = arguments[_key];}
2122
+ for (const rect of rects) {
2123
+ for (const [,, start, end] of dirs) {
2124
+ area[start] = Math.max(area[start] || 0, rect[start]);
2125
+ area[end] = Math.min(...[area[end], rect[end]].filter(Boolean));
2126
+ }
2072
2127
  }
2128
+ return area;
2129
+ }
2073
2130
 
2074
- return {
2075
- x: x.test(pos[0]) ? pos[0] : 'center',
2076
- y: y.test(pos[1]) ? pos[1] : 'center' };
2131
+ function isInScrollArea(position, scrollElement, dir) {
2132
+ const viewport = offsetViewport(scrollElement);
2133
+ const [prop,, start, end] = dirs[dir];
2134
+ viewport[start] -= scrollElement["scroll" + ucfirst(start)];
2135
+ viewport[end] = viewport[start] + scrollElement["scroll" + ucfirst(prop)];
2077
2136
 
2137
+ return position[start] >= viewport[start] && position[end] <= viewport[end];
2078
2138
  }
2079
2139
 
2080
- function getOffsets(offsets, width, height) {
2081
- const [x, y] = (offsets || '').split(' ');
2082
-
2083
- return {
2084
- x: x ? toFloat(x) * (endsWith(x, '%') ? width / 100 : 1) : 0,
2085
- y: y ? toFloat(y) * (endsWith(y, '%') ? height / 100 : 1) : 0 };
2140
+ function intersectLine(dimA, dimB, dir) {
2141
+ const [,, start, end] = dirs[dir];
2142
+ return dimA[end] > dimB[start] && dimB[end] > dimA[start];
2143
+ }
2086
2144
 
2145
+ function flipDir(prop) {
2146
+ for (let i = 0; i < dirs.length; i++) {
2147
+ const index = dirs[i].indexOf(prop);
2148
+ if (~index) {
2149
+ return dirs[1 - i][index % 2 + 2];
2150
+ }
2151
+ }
2087
2152
  }
2088
2153
 
2089
2154
  var util = /*#__PURE__*/Object.freeze({
@@ -2192,7 +2257,6 @@
2192
2257
  toNode: toNode,
2193
2258
  toNodes: toNodes,
2194
2259
  toWindow: toWindow,
2195
- toMs: toMs,
2196
2260
  isEqual: isEqual,
2197
2261
  swap: swap,
2198
2262
  last: last,
@@ -2231,9 +2295,7 @@
2231
2295
  scrollIntoView: scrollIntoView,
2232
2296
  scrolledOver: scrolledOver,
2233
2297
  scrollParents: scrollParents,
2234
- getViewport: getViewport$1,
2235
- getViewportClientHeight: getViewportClientHeight,
2236
- getScrollingElement: getScrollingElement
2298
+ offsetViewport: offsetViewport
2237
2299
  });
2238
2300
 
2239
2301
  function globalAPI (UIkit) {
@@ -2550,7 +2612,7 @@
2550
2612
  continue;
2551
2613
  }
2552
2614
 
2553
- value = props[key] === Boolean && value === '' ? true : coerce(props[key], value);
2615
+ value = props[key] === Boolean && value === '' ? true : coerce$1(props[key], value);
2554
2616
 
2555
2617
  if (prop === 'target' && (!value || startsWith(value, '_'))) {
2556
2618
  continue;
@@ -2564,7 +2626,7 @@
2564
2626
  for (const key in options) {
2565
2627
  const prop = camelize(key);
2566
2628
  if (props[prop] !== undefined) {
2567
- data$1[prop] = coerce(props[prop], options[key]);
2629
+ data$1[prop] = coerce$1(props[prop], options[key]);
2568
2630
  }
2569
2631
  }
2570
2632
 
@@ -2629,7 +2691,7 @@
2629
2691
  return options.every((arr) => !arr || !hasOwn(arr, key));
2630
2692
  }
2631
2693
 
2632
- function coerce(type, value) {
2694
+ function coerce$1(type, value) {
2633
2695
  if (type === Boolean) {
2634
2696
  return toBoolean(value);
2635
2697
  } else if (type === Number) {
@@ -2667,7 +2729,7 @@
2667
2729
  if (isUndefined(data[key])) {
2668
2730
  delete data[key];
2669
2731
  } else if (props[key]) {
2670
- data[key] = coerce(props[key], data[key]);
2732
+ data[key] = coerce$1(props[key], data[key]);
2671
2733
  }
2672
2734
  }
2673
2735
 
@@ -2892,7 +2954,7 @@
2892
2954
  UIkit.data = '__uikit__';
2893
2955
  UIkit.prefix = 'uk-';
2894
2956
  UIkit.options = {};
2895
- UIkit.version = '3.13.10';
2957
+ UIkit.version = '3.13.11-dev.1296bb84c';
2896
2958
 
2897
2959
  globalAPI(UIkit);
2898
2960
  hooksAPI(UIkit);
@@ -2900,30 +2962,6 @@
2900
2962
  componentAPI(UIkit);
2901
2963
  instanceAPI(UIkit);
2902
2964
 
2903
- function Core () {
2904
- if (!inBrowser) {
2905
- return;
2906
- }
2907
-
2908
- let started = 0;
2909
- on(
2910
- document,
2911
- 'animationstart',
2912
- (_ref) => {let { target } = _ref;
2913
- if ((css(target, 'animationName') || '').match(/^uk-.*(left|right)/)) {
2914
- started++;
2915
- css(document.documentElement, 'overflowX', 'hidden');
2916
- setTimeout(() => {
2917
- if (! --started) {
2918
- css(document.documentElement, 'overflowX', '');
2919
- }
2920
- }, toMs(css(target, 'animationDuration')) + 100);
2921
- }
2922
- },
2923
- true);
2924
-
2925
- }
2926
-
2927
2965
  function boot (UIkit) {
2928
2966
  const { connect, disconnect } = UIkit;
2929
2967
 
@@ -3440,25 +3478,38 @@
3440
3478
 
3441
3479
  update: {
3442
3480
  read() {
3443
- const el = this.$el;
3444
- const { offsetHeight: height, offsetWidth: width } =
3445
- getPositionedParent(el) || parent(el);
3446
- const dim = Dimensions.cover(
3447
- {
3448
- width: this.width || el.naturalWidth || el.videoWidth || el.clientWidth,
3449
- height: this.height || el.naturalHeight || el.videoHeight || el.clientHeight },
3481
+ const { ratio, cover } = Dimensions;
3482
+ const { $el, width, height } = this;
3450
3483
 
3451
- {
3452
- width: width + (width % 2 ? 1 : 0),
3453
- height: height + (height % 2 ? 1 : 0) });
3484
+ let dim = { width, height };
3454
3485
 
3486
+ if (!dim.width || !dim.height) {
3487
+ const intrinsic = {
3488
+ width: $el.naturalWidth || $el.videoWidth || $el.clientWidth,
3489
+ height: $el.naturalHeight || $el.videoHeight || $el.clientHeight };
3455
3490
 
3456
3491
 
3457
- if (!dim.width || !dim.height) {
3492
+ if (dim.width) {
3493
+ dim = ratio(intrinsic, 'width', dim.width);
3494
+ } else if (height) {
3495
+ dim = ratio(intrinsic, 'height', dim.height);
3496
+ } else {
3497
+ dim = intrinsic;
3498
+ }
3499
+ }
3500
+
3501
+ const { offsetHeight: coverHeight, offsetWidth: coverWidth } =
3502
+ getPositionedParent($el) || parent($el);
3503
+ const coverDim = cover(dim, {
3504
+ width: coverWidth + (coverWidth % 2 ? 1 : 0),
3505
+ height: coverHeight + (coverHeight % 2 ? 1 : 0) });
3506
+
3507
+
3508
+ if (!coverDim.width || !coverDim.height) {
3458
3509
  return false;
3459
3510
  }
3460
3511
 
3461
- return dim;
3512
+ return coverDim;
3462
3513
  },
3463
3514
 
3464
3515
  write(_ref) {let { height, width } = _ref;
@@ -3501,50 +3552,49 @@
3501
3552
  data: {
3502
3553
  pos: "bottom-" + (isRtl ? 'right' : 'left'),
3503
3554
  flip: true,
3504
- offset: false },
3555
+ offset: false,
3556
+ viewportPadding: 10 },
3505
3557
 
3506
3558
 
3507
3559
  connected() {
3508
3560
  this.pos = this.$props.pos.split('-').concat('center').slice(0, 2);
3509
- this.dir = this.pos[0];
3510
- this.align = this.pos[1];
3561
+ this.axis = includes(['top', 'bottom'], this.pos[0]) ? 'y' : 'x';
3511
3562
  },
3512
3563
 
3513
3564
  methods: {
3514
3565
  positionAt(element, target, boundary) {
3515
- const axis = this.getAxis();
3516
- const dir = this.pos[0];
3517
- const align = this.pos[1];
3566
+ const [dir, align] = this.pos;
3518
3567
 
3519
3568
  let { offset: offset$1 } = this;
3520
3569
  if (!isNumeric(offset$1)) {
3521
3570
  const node = $(offset$1);
3522
3571
  offset$1 = node ?
3523
- offset(node)[axis === 'x' ? 'left' : 'top'] -
3524
- offset(target)[axis === 'x' ? 'right' : 'bottom'] :
3572
+ offset(node)[this.axis === 'x' ? 'left' : 'top'] -
3573
+ offset(target)[this.axis === 'x' ? 'right' : 'bottom'] :
3525
3574
  0;
3526
3575
  }
3527
3576
  offset$1 = toPx(offset$1) + toPx(getCssVar('position-offset', element));
3577
+ offset$1 = [includes(['left', 'top'], dir) ? -offset$1 : +offset$1, 0];
3528
3578
 
3529
- const { x, y } = positionAt(
3530
- element,
3531
- target,
3532
- axis === 'x' ? flipPosition(dir) + " " + align : align + " " + flipPosition(dir),
3533
- axis === 'x' ? dir + " " + align : align + " " + dir,
3534
- axis === 'x' ? "" + (
3535
- dir === 'left' ? -offset$1 : offset$1) : " " + (
3536
- dir === 'top' ? -offset$1 : offset$1),
3537
- null,
3538
- this.flip,
3539
- boundary).
3540
- target;
3541
-
3542
- this.dir = axis === 'x' ? x : y;
3543
- this.align = axis === 'x' ? y : x;
3544
- },
3579
+ const attach = {
3580
+ element: [flipPosition(dir), align],
3581
+ target: [dir, align] };
3582
+
3583
+
3584
+ if (this.axis === 'y') {
3585
+ for (const prop in attach) {
3586
+ attach[prop] = attach[prop].reverse();
3587
+ }
3588
+ offset$1 = offset$1.reverse();
3589
+ }
3590
+
3591
+ positionAt(element, target, {
3592
+ attach,
3593
+ offset: offset$1,
3594
+ boundary,
3595
+ viewportPadding: this.viewportPadding,
3596
+ flip: this.flip });
3545
3597
 
3546
- getAxis() {
3547
- return this.dir === 'top' || this.dir === 'bottom' ? 'y' : 'x';
3548
3598
  } } };
3549
3599
 
3550
3600
  let active$1;
@@ -3561,6 +3611,7 @@
3561
3611
  boundaryAlign: Boolean,
3562
3612
  delayShow: Number,
3563
3613
  delayHide: Number,
3614
+ display: String,
3564
3615
  clsDrop: String },
3565
3616
 
3566
3617
 
@@ -3571,6 +3622,7 @@
3571
3622
  boundaryAlign: false,
3572
3623
  delayShow: 0,
3573
3624
  delayHide: 800,
3625
+ display: null,
3574
3626
  clsDrop: false,
3575
3627
  animation: ['uk-animation-fade'],
3576
3628
  cls: 'uk-open',
@@ -3761,7 +3813,23 @@
3761
3813
  this.hide(false);
3762
3814
  }
3763
3815
  }),
3764
- on(window, 'resize', () => this.$emit())])
3816
+
3817
+ ...(this.display === 'static' ?
3818
+ [] :
3819
+ (() => {
3820
+ const handler = () => this.$emit();
3821
+ return [
3822
+ on(window, 'resize', handler),
3823
+ on(document, 'scroll', handler, true),
3824
+ (() => {
3825
+ const observer = observeResize(
3826
+ scrollParents(this.$el),
3827
+ handler);
3828
+
3829
+ return () => observer.disconnect();
3830
+ })()];
3831
+
3832
+ })())])
3765
3833
  {
3766
3834
  once(this.$el, 'hide', handler, { self: true });
3767
3835
  }
@@ -3872,25 +3940,33 @@
3872
3940
  },
3873
3941
 
3874
3942
  position() {
3875
- const boundary = query(this.boundary, this.$el) || window;
3876
3943
  removeClass(this.$el, this.clsDrop + "-stack");
3877
3944
  toggleClass(this.$el, this.clsDrop + "-boundary", this.boundaryAlign);
3878
3945
 
3879
- const boundaryOffset = offset(boundary);
3880
- const targetOffset = offset(this.target);
3881
- const alignTo = this.boundaryAlign ? boundaryOffset : targetOffset;
3946
+ const boundary = query(this.boundary, this.$el);
3947
+ const [scrollParent] = scrollParents(this.$el);
3948
+ const scrollParentOffset = offsetViewport(scrollParent);
3949
+ const boundaryOffset = boundary ? offset(boundary) : scrollParentOffset;
3950
+
3951
+ css(this.$el, 'maxWidth', '');
3952
+ const maxWidth = scrollParentOffset.width - (boundary ? 0 : 2 * this.viewportPadding);
3882
3953
 
3883
3954
  if (this.pos[1] === 'justify') {
3884
- const prop = this.getAxis() === 'y' ? 'width' : 'height';
3955
+ const prop = this.axis === 'y' ? 'width' : 'height';
3956
+ const targetOffset = offset(this.target);
3957
+ const alignTo = this.boundaryAlign ? boundaryOffset : targetOffset;
3885
3958
  css(this.$el, prop, alignTo[prop]);
3886
- } else if (
3887
- this.$el.offsetWidth >
3888
- Math.max(boundaryOffset.right - alignTo.left, alignTo.right - boundaryOffset.left))
3889
- {
3959
+ } else if (this.$el.offsetWidth > maxWidth) {
3890
3960
  addClass(this.$el, this.clsDrop + "-stack");
3891
3961
  }
3892
3962
 
3893
- this.positionAt(this.$el, this.boundaryAlign ? boundary : this.target, boundary);
3963
+ css(this.$el, 'maxWidth', maxWidth);
3964
+
3965
+ this.positionAt(
3966
+ this.$el,
3967
+ boundary && this.boundaryAlign ? boundary : this.target,
3968
+ boundary);
3969
+
3894
3970
  } } };
3895
3971
 
3896
3972
 
@@ -3988,7 +4064,7 @@
3988
4064
 
3989
4065
 
3990
4066
  resizeTargets() {
3991
- return [this.$el, this.$el.children];
4067
+ return [this.$el, ...toArray(this.$el.children)];
3992
4068
  },
3993
4069
 
3994
4070
  connected() {
@@ -4305,7 +4381,7 @@
4305
4381
 
4306
4382
 
4307
4383
  resizeTargets() {
4308
- return [this.$el, this.elements];
4384
+ return [this.$el, ...this.elements];
4309
4385
  },
4310
4386
 
4311
4387
  update: {
@@ -4994,16 +5070,19 @@
4994
5070
 
4995
5071
  connected() {
4996
5072
  const media = toMedia(this.media);
4997
- this.mediaObj = window.matchMedia(media);
4998
- const handler = () => {
4999
- this.matchMedia = this.mediaObj.matches;
5000
- trigger(this.$el, createEvent('mediachange', false, true, [this.mediaObj]));
5001
- };
5002
- this.offMediaObj = on(this.mediaObj, 'change', () => {
5073
+ this.matchMedia = true;
5074
+ if (media) {
5075
+ this.mediaObj = window.matchMedia(media);
5076
+ const handler = () => {
5077
+ this.matchMedia = this.mediaObj.matches;
5078
+ trigger(this.$el, createEvent('mediachange', false, true, [this.mediaObj]));
5079
+ };
5080
+ this.offMediaObj = on(this.mediaObj, 'change', () => {
5081
+ handler();
5082
+ this.$emit('resize');
5083
+ });
5003
5084
  handler();
5004
- this.$emit('resize');
5005
- });
5006
- handler();
5085
+ }
5007
5086
  },
5008
5087
 
5009
5088
  disconnected() {var _this$offMediaObj;
@@ -5292,7 +5371,7 @@
5292
5371
  return (el, show) =>
5293
5372
  new Promise((resolve, reject) =>
5294
5373
  once(el, 'show hide', () => {
5295
- el._reject && el._reject();
5374
+ el._reject == null ? void 0 : el._reject();
5296
5375
  el._reject = reject;
5297
5376
 
5298
5377
  _toggle(el, show);
@@ -5317,6 +5396,10 @@
5317
5396
  then(() => delete el._reject);
5318
5397
  }
5319
5398
 
5399
+ function toMs(time) {
5400
+ return time ? endsWith(time, 'ms') ? toFloat(time) : toFloat(time) * 1000 : 0;
5401
+ }
5402
+
5320
5403
  var modal = {
5321
5404
  install,
5322
5405
 
@@ -5470,8 +5553,6 @@
5470
5553
  toggle: '> a',
5471
5554
  content: '> ul' } };
5472
5555
 
5473
- const navItem = '.uk-navbar-nav > li > a, .uk-navbar-item, .uk-navbar-toggle';
5474
-
5475
5556
  var navbar = {
5476
5557
  mixins: [Class, Container],
5477
5558
 
@@ -5491,7 +5572,7 @@
5491
5572
 
5492
5573
 
5493
5574
  data: {
5494
- dropdown: navItem,
5575
+ dropdown: '.uk-navbar-nav > li > a, .uk-navbar-item, .uk-navbar-toggle',
5495
5576
  align: isRtl ? 'right' : 'left',
5496
5577
  clsDrop: 'uk-navbar-dropdown',
5497
5578
  mode: undefined,
@@ -5577,9 +5658,23 @@
5577
5658
  immediate: true },
5578
5659
 
5579
5660
 
5580
- toggles(_ref6, $el) {let { dropdown } = _ref6;
5581
- return $$(dropdown, $el);
5582
- } },
5661
+ toggles: {
5662
+ get(_ref6, $el) {let { dropdown } = _ref6;
5663
+ return $$(dropdown, $el);
5664
+ },
5665
+
5666
+ watch() {
5667
+ const justify = hasClass(this.$el, 'uk-navbar-justify');
5668
+ for (const container of $$(
5669
+ '.uk-navbar-nav, .uk-navbar-left, .uk-navbar-right',
5670
+ this.$el))
5671
+ {
5672
+ css(container, 'flexGrow', justify ? $$(this.dropdown, container).length : '');
5673
+ }
5674
+ },
5675
+
5676
+ immediate: true } },
5677
+
5583
5678
 
5584
5679
 
5585
5680
  disconnected() {
@@ -5740,7 +5835,7 @@
5740
5835
  return this.dropbar;
5741
5836
  },
5742
5837
 
5743
- handler(_, _ref10) {let { $el, dir } = _ref10;
5838
+ handler(_, _ref10) {let { $el, pos: [dir] = [] } = _ref10;
5744
5839
  if (!hasClass($el, this.clsDrop)) {
5745
5840
  return;
5746
5841
  }
@@ -6474,19 +6569,15 @@
6474
6569
 
6475
6570
  const [scrollElement] = scrollParents(targets, /auto|scroll/, true);
6476
6571
  const { scrollTop, scrollHeight } = scrollElement;
6477
- const max = scrollHeight - getViewportClientHeight(scrollElement);
6572
+ const viewport = offsetViewport(scrollElement);
6573
+ const max = scrollHeight - viewport.height;
6478
6574
  let active = false;
6479
6575
 
6480
6576
  if (scrollTop === max) {
6481
6577
  active = length - 1;
6482
6578
  } else {
6483
- for (const i in targets) {
6484
- if (
6485
- offset(targets[i]).top -
6486
- offset(getViewport$1(scrollElement)).top -
6487
- this.offset >
6488
- 0)
6489
- {
6579
+ for (let i = 0; i < targets.length; i++) {
6580
+ if (offset(targets[i]).top - viewport.top - this.offset > 0) {
6490
6581
  break;
6491
6582
  }
6492
6583
  active = +i;
@@ -6504,7 +6595,7 @@
6504
6595
  const changed = active !== false && !hasClass(this.elements[active], this.cls);
6505
6596
 
6506
6597
  this.links.forEach((el) => el.blur());
6507
- for (const i in this.elements) {
6598
+ for (let i = 0; i < this.elements.length; i++) {
6508
6599
  toggleClass(this.elements[i], this.cls, +i === active);
6509
6600
  }
6510
6601
 
@@ -6521,8 +6612,11 @@
6521
6612
  props: {
6522
6613
  position: String,
6523
6614
  top: null,
6524
- bottom: Boolean,
6615
+ bottom: null,
6616
+ start: null,
6617
+ end: null,
6525
6618
  offset: String,
6619
+ overflowFlip: Boolean,
6526
6620
  animation: String,
6527
6621
  clsActive: String,
6528
6622
  clsInactive: String,
@@ -6535,9 +6629,12 @@
6535
6629
 
6536
6630
  data: {
6537
6631
  position: 'top',
6538
- top: 0,
6632
+ top: false,
6539
6633
  bottom: false,
6634
+ start: false,
6635
+ end: false,
6540
6636
  offset: 0,
6637
+ overflowFlip: false,
6541
6638
  animation: '',
6542
6639
  clsActive: 'uk-active',
6543
6640
  clsInactive: '',
@@ -6559,6 +6656,9 @@
6559
6656
  },
6560
6657
 
6561
6658
  connected() {
6659
+ this.start = coerce(this.start || this.top);
6660
+ this.end = coerce(this.end || this.bottom);
6661
+
6562
6662
  this.placeholder =
6563
6663
  $('+ .uk-sticky-placeholder', this.$el) ||
6564
6664
  $('<div class="uk-sticky-placeholder"></div>');
@@ -6577,6 +6677,17 @@
6577
6677
  },
6578
6678
 
6579
6679
  events: [
6680
+ {
6681
+ name: 'resize',
6682
+
6683
+ el() {
6684
+ return window;
6685
+ },
6686
+
6687
+ handler() {
6688
+ this.$emit('resize');
6689
+ } },
6690
+
6580
6691
  {
6581
6692
  name: 'load hashchange popstate',
6582
6693
 
@@ -6593,7 +6704,7 @@
6593
6704
  return;
6594
6705
  }
6595
6706
 
6596
- fastdom.read(() => {
6707
+ setTimeout(() => {
6597
6708
  const targetOffset = offset($(location.hash));
6598
6709
  const elOffset = offset(this.$el);
6599
6710
 
@@ -6602,8 +6713,8 @@
6602
6713
  window,
6603
6714
  targetOffset.top -
6604
6715
  elOffset.height -
6605
- toPx(this.targetOffset, 'height') -
6606
- toPx(this.offset, 'height'));
6716
+ toPx(this.targetOffset, 'height', this.placeholder) -
6717
+ toPx(this.offset, 'height', this.placeholder));
6607
6718
 
6608
6719
  }
6609
6720
  });
@@ -6633,32 +6744,38 @@
6633
6744
 
6634
6745
  if (hide) {
6635
6746
  this.show();
6636
- fastdom.write(() => css(this.selTarget, 'transition', ''));
6747
+ requestAnimationFrame(() => css(this.selTarget, 'transition', ''));
6637
6748
  }
6638
6749
 
6639
6750
  const referenceElement = this.isFixed ? this.placeholder : this.$el;
6640
6751
  const windowHeight = height(window);
6641
6752
 
6642
6753
  let position = this.position;
6643
- if (position === 'auto' && height$1 > windowHeight) {
6644
- position = 'bottom';
6754
+ if (this.overflowFlip && height$1 > windowHeight) {
6755
+ position = position === 'top' ? 'bottom' : 'top';
6645
6756
  }
6646
6757
 
6647
6758
  let offset$1 = toPx(this.offset, 'height', referenceElement);
6648
- if (position === 'bottom') {
6759
+ if (position === 'bottom' && (height$1 < windowHeight || this.overflowFlip)) {
6649
6760
  offset$1 += windowHeight - height$1;
6650
6761
  }
6651
6762
 
6652
- const overflow = Math.max(0, height$1 + offset$1 - windowHeight);
6763
+ const overflow = this.overflowFlip ?
6764
+ 0 :
6765
+ Math.max(0, height$1 + offset$1 - windowHeight);
6653
6766
  const topOffset = offset(referenceElement).top;
6654
6767
 
6655
- const top = parseProp(this.top, this.$el, topOffset);
6656
- const bottom = parseProp(this.bottom, this.$el, topOffset + height$1, true);
6657
-
6658
- const start = Math.max(top, topOffset) - offset$1;
6659
- const end = bottom ?
6660
- bottom - offset(this.$el).height + overflow - offset$1 :
6661
- getScrollingElement(this.$el).scrollHeight - windowHeight;
6768
+ const start =
6769
+ (this.start === false ?
6770
+ topOffset :
6771
+ parseProp(this.start, this.$el, topOffset)) - offset$1;
6772
+ const end =
6773
+ this.end === false ?
6774
+ document.scrollingElement.scrollHeight - windowHeight :
6775
+ parseProp(this.end, this.$el, topOffset + height$1, true) -
6776
+ offset(this.$el).height +
6777
+ overflow -
6778
+ offset$1;
6662
6779
 
6663
6780
  return {
6664
6781
  start,
@@ -6861,8 +6978,8 @@
6861
6978
  return 0;
6862
6979
  }
6863
6980
 
6864
- if (isString(value) && value.match(/^-?\d/)) {
6865
- return propOffset + toPx(value);
6981
+ if (isNumeric(value) || isString(value) && value.match(/^-?\d/)) {
6982
+ return propOffset + toPx(value, 'height', el, true);
6866
6983
  } else {
6867
6984
  const refElement = value === true ? parent(el) : query(value, el);
6868
6985
  return (
@@ -6874,6 +6991,15 @@
6874
6991
  }
6875
6992
  }
6876
6993
 
6994
+ function coerce(value) {
6995
+ if (value === 'true') {
6996
+ return true;
6997
+ } else if (value === 'false') {
6998
+ return false;
6999
+ }
7000
+ return value;
7001
+ }
7002
+
6877
7003
  var Switcher = {
6878
7004
  mixins: [Lazyload, Swipe, Togglable],
6879
7005
 
@@ -7326,9 +7452,6 @@
7326
7452
  // register components
7327
7453
  each(components, (component, name) => UIkit.component(name, component));
7328
7454
 
7329
- // core functionality
7330
- UIkit.use(Core);
7331
-
7332
7455
  boot(UIkit);
7333
7456
 
7334
7457
  return UIkit;