@nulogy/components 13.1.2 → 13.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/main.js CHANGED
@@ -355,12 +355,12 @@
355
355
  }
356
356
 
357
357
  var isBrowser$7 = typeof window !== "undefined";
358
- var useIsomorphicLayoutEffect$4 = isBrowser$7 ? React.useLayoutEffect : React.useEffect;
358
+ var useIsomorphicLayoutEffect$5 = isBrowser$7 ? React.useLayoutEffect : React.useEffect;
359
359
 
360
360
  function useSnapshotOnUnmount(visualElement) {
361
361
  var syncLayout = React.useContext(SharedLayoutContext);
362
362
  var framerSyncLayout = React.useContext(FramerTreeLayoutContext);
363
- useIsomorphicLayoutEffect$4(function () { return function () {
363
+ useIsomorphicLayoutEffect$5(function () { return function () {
364
364
  if (isSharedLayout(syncLayout)) {
365
365
  syncLayout.remove(visualElement);
366
366
  }
@@ -391,7 +391,7 @@
391
391
  blockInitialAnimation: (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false,
392
392
  });
393
393
  });
394
- useIsomorphicLayoutEffect$4(function () {
394
+ useIsomorphicLayoutEffect$5(function () {
395
395
  visualElement.setProps(__assign$3(__assign$3(__assign$3({}, config), props), { layoutId: layoutId }));
396
396
  visualElement.isPresent = isPresent(presenceContext);
397
397
  visualElement.isPresenceRoot =
@@ -10719,225 +10719,6 @@
10719
10719
  };
10720
10720
  }
10721
10721
 
10722
- function _toConsumableArray$1(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
10723
-
10724
- // Older browsers don't support event options, feature detect it.
10725
-
10726
- // Adopted and modified solution from Bohdan Didukh (2017)
10727
- // https://stackoverflow.com/questions/41594997/ios-10-safari-prevent-scrolling-behind-a-fixed-overlay-and-maintain-scroll-posi
10728
-
10729
- var hasPassiveEvents = false;
10730
- if (typeof window !== 'undefined') {
10731
- var passiveTestOptions = {
10732
- get passive() {
10733
- hasPassiveEvents = true;
10734
- return undefined;
10735
- }
10736
- };
10737
- window.addEventListener('testPassive', null, passiveTestOptions);
10738
- window.removeEventListener('testPassive', null, passiveTestOptions);
10739
- }
10740
-
10741
- var isIosDevice = typeof window !== 'undefined' && window.navigator && window.navigator.platform && (/iP(ad|hone|od)/.test(window.navigator.platform) || window.navigator.platform === 'MacIntel' && window.navigator.maxTouchPoints > 1);
10742
-
10743
-
10744
- var locks = [];
10745
- var documentListenerAdded = false;
10746
- var initialClientY = -1;
10747
- var previousBodyOverflowSetting = void 0;
10748
- var previousBodyPaddingRight = void 0;
10749
-
10750
- // returns true if `el` should be allowed to receive touchmove events.
10751
- var allowTouchMove$1 = function allowTouchMove(el) {
10752
- return locks.some(function (lock) {
10753
- if (lock.options.allowTouchMove && lock.options.allowTouchMove(el)) {
10754
- return true;
10755
- }
10756
-
10757
- return false;
10758
- });
10759
- };
10760
-
10761
- var preventDefault = function preventDefault(rawEvent) {
10762
- var e = rawEvent || window.event;
10763
-
10764
- // For the case whereby consumers adds a touchmove event listener to document.
10765
- // Recall that we do document.addEventListener('touchmove', preventDefault, { passive: false })
10766
- // in disableBodyScroll - so if we provide this opportunity to allowTouchMove, then
10767
- // the touchmove event on document will break.
10768
- if (allowTouchMove$1(e.target)) {
10769
- return true;
10770
- }
10771
-
10772
- // Do not prevent if the event has more than one touch (usually meaning this is a multi touch gesture like pinch to zoom).
10773
- if (e.touches.length > 1) return true;
10774
-
10775
- if (e.preventDefault) e.preventDefault();
10776
-
10777
- return false;
10778
- };
10779
-
10780
- var setOverflowHidden = function setOverflowHidden(options) {
10781
- // If previousBodyPaddingRight is already set, don't set it again.
10782
- if (previousBodyPaddingRight === undefined) {
10783
- var _reserveScrollBarGap = !!options && options.reserveScrollBarGap === true;
10784
- var scrollBarGap = window.innerWidth - document.documentElement.clientWidth;
10785
-
10786
- if (_reserveScrollBarGap && scrollBarGap > 0) {
10787
- previousBodyPaddingRight = document.body.style.paddingRight;
10788
- document.body.style.paddingRight = scrollBarGap + 'px';
10789
- }
10790
- }
10791
-
10792
- // If previousBodyOverflowSetting is already set, don't set it again.
10793
- if (previousBodyOverflowSetting === undefined) {
10794
- previousBodyOverflowSetting = document.body.style.overflow;
10795
- document.body.style.overflow = 'hidden';
10796
- }
10797
- };
10798
-
10799
- var restoreOverflowSetting = function restoreOverflowSetting() {
10800
- if (previousBodyPaddingRight !== undefined) {
10801
- document.body.style.paddingRight = previousBodyPaddingRight;
10802
-
10803
- // Restore previousBodyPaddingRight to undefined so setOverflowHidden knows it
10804
- // can be set again.
10805
- previousBodyPaddingRight = undefined;
10806
- }
10807
-
10808
- if (previousBodyOverflowSetting !== undefined) {
10809
- document.body.style.overflow = previousBodyOverflowSetting;
10810
-
10811
- // Restore previousBodyOverflowSetting to undefined
10812
- // so setOverflowHidden knows it can be set again.
10813
- previousBodyOverflowSetting = undefined;
10814
- }
10815
- };
10816
-
10817
- // https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#Problems_and_solutions
10818
- var isTargetElementTotallyScrolled = function isTargetElementTotallyScrolled(targetElement) {
10819
- return targetElement ? targetElement.scrollHeight - targetElement.scrollTop <= targetElement.clientHeight : false;
10820
- };
10821
-
10822
- var handleScroll$1 = function handleScroll(event, targetElement) {
10823
- var clientY = event.targetTouches[0].clientY - initialClientY;
10824
-
10825
- if (allowTouchMove$1(event.target)) {
10826
- return false;
10827
- }
10828
-
10829
- if (targetElement && targetElement.scrollTop === 0 && clientY > 0) {
10830
- // element is at the top of its scroll.
10831
- return preventDefault(event);
10832
- }
10833
-
10834
- if (isTargetElementTotallyScrolled(targetElement) && clientY < 0) {
10835
- // element is at the bottom of its scroll.
10836
- return preventDefault(event);
10837
- }
10838
-
10839
- event.stopPropagation();
10840
- return true;
10841
- };
10842
-
10843
- var disableBodyScroll = function disableBodyScroll(targetElement, options) {
10844
- // targetElement must be provided
10845
- if (!targetElement) {
10846
- // eslint-disable-next-line no-console
10847
- console.error('disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.');
10848
- return;
10849
- }
10850
-
10851
- // disableBodyScroll must not have been called on this targetElement before
10852
- if (locks.some(function (lock) {
10853
- return lock.targetElement === targetElement;
10854
- })) {
10855
- return;
10856
- }
10857
-
10858
- var lock = {
10859
- targetElement: targetElement,
10860
- options: options || {}
10861
- };
10862
-
10863
- locks = [].concat(_toConsumableArray$1(locks), [lock]);
10864
-
10865
- if (isIosDevice) {
10866
- targetElement.ontouchstart = function (event) {
10867
- if (event.targetTouches.length === 1) {
10868
- // detect single touch.
10869
- initialClientY = event.targetTouches[0].clientY;
10870
- }
10871
- };
10872
- targetElement.ontouchmove = function (event) {
10873
- if (event.targetTouches.length === 1) {
10874
- // detect single touch.
10875
- handleScroll$1(event, targetElement);
10876
- }
10877
- };
10878
-
10879
- if (!documentListenerAdded) {
10880
- document.addEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);
10881
- documentListenerAdded = true;
10882
- }
10883
- } else {
10884
- setOverflowHidden(options);
10885
- }
10886
- };
10887
-
10888
- var clearAllBodyScrollLocks = function clearAllBodyScrollLocks() {
10889
- if (isIosDevice) {
10890
- // Clear all locks ontouchstart/ontouchmove handlers, and the references.
10891
- locks.forEach(function (lock) {
10892
- lock.targetElement.ontouchstart = null;
10893
- lock.targetElement.ontouchmove = null;
10894
- });
10895
-
10896
- if (documentListenerAdded) {
10897
- document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);
10898
- documentListenerAdded = false;
10899
- }
10900
-
10901
- // Reset initial clientY.
10902
- initialClientY = -1;
10903
- } else {
10904
- restoreOverflowSetting();
10905
- }
10906
-
10907
- locks = [];
10908
- };
10909
-
10910
- var PreventBodyElementScrolling = /*#__PURE__*/function (_React$Component) {
10911
- _inheritsLoose__default["default"](PreventBodyElementScrolling, _React$Component);
10912
-
10913
- function PreventBodyElementScrolling() {
10914
- return _React$Component.apply(this, arguments) || this;
10915
- }
10916
-
10917
- var _proto = PreventBodyElementScrolling.prototype;
10918
-
10919
- _proto.componentDidMount = function componentDidMount() {
10920
- var scrollableRef = this.props.scrollableRef;
10921
- var refs = Array.isArray(scrollableRef) ? scrollableRef : [scrollableRef];
10922
- refs.every(function (ref) {
10923
- if (ref && ref.current) {
10924
- disableBodyScroll(ref.current);
10925
- }
10926
- });
10927
- };
10928
-
10929
- _proto.componentWillUnmount = function componentWillUnmount() {
10930
- clearAllBodyScrollLocks();
10931
- };
10932
-
10933
- _proto.render = function render() {
10934
- var children = this.props.children;
10935
- return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, children);
10936
- };
10937
-
10938
- return PreventBodyElementScrolling;
10939
- }(React__default["default"].Component);
10940
-
10941
10722
  var convertPxToNumber = function convertPxToNumber(px) {
10942
10723
  return parseFloat(px);
10943
10724
  };
@@ -11253,7 +11034,7 @@
11253
11034
  * Small wrapper around `useLayoutEffect` to get rid of the warning on SSR envs
11254
11035
  */
11255
11036
 
11256
- var useIsomorphicLayoutEffect$3 = typeof window !== 'undefined' && window.document && window.document.createElement ? React__namespace.useLayoutEffect : React__namespace.useEffect;
11037
+ var useIsomorphicLayoutEffect$4 = typeof window !== 'undefined' && window.document && window.document.createElement ? React__namespace.useLayoutEffect : React__namespace.useEffect;
11257
11038
 
11258
11039
  var top = 'top';
11259
11040
  var bottom = 'bottom';
@@ -13198,12 +12979,12 @@
13198
12979
  }
13199
12980
  }, [optionsWithDefaults.onFirstUpdate, optionsWithDefaults.placement, optionsWithDefaults.strategy, optionsWithDefaults.modifiers, updateStateModifier]);
13200
12981
  var popperInstanceRef = React__namespace.useRef();
13201
- useIsomorphicLayoutEffect$3(function () {
12982
+ useIsomorphicLayoutEffect$4(function () {
13202
12983
  if (popperInstanceRef.current) {
13203
12984
  popperInstanceRef.current.setOptions(popperOptions);
13204
12985
  }
13205
12986
  }, [popperOptions]);
13206
- useIsomorphicLayoutEffect$3(function () {
12987
+ useIsomorphicLayoutEffect$4(function () {
13207
12988
  if (referenceElement == null || popperElement == null) {
13208
12989
  return;
13209
12990
  }
@@ -16278,7 +16059,9 @@
16278
16059
  };
16279
16060
  }
16280
16061
 
16281
- var index = typeof document !== 'undefined' ? React.useLayoutEffect : React.useEffect;
16062
+ var isClient = typeof document !== 'undefined';
16063
+
16064
+ var index = isClient ? React.useLayoutEffect : React.useEffect;
16282
16065
 
16283
16066
  var _excluded$4$1 = ["className", "clearValue", "cx", "getStyles", "getClassNames", "getValue", "hasValue", "isMulti", "isRtl", "options", "selectOption", "selectProps", "setValue", "theme"];
16284
16067
  // ==============================
@@ -17089,7 +16872,7 @@
17089
16872
  } : {
17090
16873
  name: "tj5bde-Svg",
17091
16874
  styles: "display:inline-block;fill:currentColor;line-height:1;stroke:currentColor;stroke-width:0;label:Svg;",
17092
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAyBI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */",
16875
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAyBI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { JSX, ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */",
17093
16876
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
17094
16877
  };
17095
16878
  var Svg = function Svg(_ref) {
@@ -17224,7 +17007,7 @@
17224
17007
  height: '1em',
17225
17008
  verticalAlign: 'top',
17226
17009
  width: '1em'
17227
- }, process.env.NODE_ENV === "production" ? "" : ";label:LoadingDot;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAmQI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */")
17010
+ }, process.env.NODE_ENV === "production" ? "" : ";label:LoadingDot;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAmQI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { JSX, ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */")
17228
17011
  });
17229
17012
  };
17230
17013
  var LoadingIndicator = function LoadingIndicator(_ref7) {
@@ -17720,7 +17503,7 @@
17720
17503
  } : {
17721
17504
  name: "1f43avz-a11yText-A11yText",
17722
17505
  styles: "label:a11yText;z-index:9999;border:0;clip:rect(1px, 1px, 1px, 1px);height:1px;width:1px;position:absolute;overflow:hidden;padding:0;white-space:nowrap;label:A11yText;",
17723
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
17506
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IEpTWCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
17724
17507
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
17725
17508
  };
17726
17509
  var A11yText = function A11yText(props) {
@@ -18264,7 +18047,7 @@
18264
18047
  opacity: 0,
18265
18048
  position: 'relative',
18266
18049
  transform: 'scale(.01)'
18267
- }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgcmVtb3ZlUHJvcHMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIER1bW15SW5wdXQoe1xuICBpbm5lclJlZixcbiAgLi4ucHJvcHNcbn06IEpTWC5JbnRyaW5zaWNFbGVtZW50c1snaW5wdXQnXSAmIHtcbiAgcmVhZG9ubHkgaW5uZXJSZWY6IFJlZjxIVE1MSW5wdXRFbGVtZW50Pjtcbn0pIHtcbiAgLy8gUmVtb3ZlIGFuaW1hdGlvbiBwcm9wcyBub3QgbWVhbnQgZm9yIEhUTUwgZWxlbWVudHNcbiAgY29uc3QgZmlsdGVyZWRQcm9wcyA9IHJlbW92ZVByb3BzKFxuICAgIHByb3BzLFxuICAgICdvbkV4aXRlZCcsXG4gICAgJ2luJyxcbiAgICAnZW50ZXInLFxuICAgICdleGl0JyxcbiAgICAnYXBwZWFyJ1xuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGlucHV0XG4gICAgICByZWY9e2lubmVyUmVmfVxuICAgICAgey4uLmZpbHRlcmVkUHJvcHN9XG4gICAgICBjc3M9e3tcbiAgICAgICAgbGFiZWw6ICdkdW1teUlucHV0JyxcbiAgICAgICAgLy8gZ2V0IHJpZCBvZiBhbnkgZGVmYXVsdCBzdHlsZXNcbiAgICAgICAgYmFja2dyb3VuZDogMCxcbiAgICAgICAgYm9yZGVyOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHRoaXMgaGlkZXMgdGhlIGZsYXNoaW5nIGN1cnNvclxuICAgICAgICBjYXJldENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICAgICAgICBmb250U2l6ZTogJ2luaGVyaXQnLFxuICAgICAgICBncmlkQXJlYTogJzEgLyAxIC8gMiAvIDMnLFxuICAgICAgICBvdXRsaW5lOiAwLFxuICAgICAgICBwYWRkaW5nOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHdpdGhvdXQgYHdpZHRoYCBicm93c2VycyB3b24ndCBhbGxvdyBmb2N1c1xuICAgICAgICB3aWR0aDogMSxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIGRlc2t0b3BcbiAgICAgICAgY29sb3I6ICd0cmFuc3BhcmVudCcsXG5cbiAgICAgICAgLy8gcmVtb3ZlIGN1cnNvciBvbiBtb2JpbGUgd2hpbHN0IG1haW50YWluaW5nIFwic2Nyb2xsIGludG8gdmlld1wiIGJlaGF2aW91clxuICAgICAgICBsZWZ0OiAtMTAwLFxuICAgICAgICBvcGFjaXR5OiAwLFxuICAgICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgICAgdHJhbnNmb3JtOiAnc2NhbGUoLjAxKScsXG4gICAgICB9fVxuICAgIC8+XG4gICk7XG59XG4iXX0= */")
18050
+ }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgSlNYLCBSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBqc3ggfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyByZW1vdmVQcm9wcyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRHVtbXlJbnB1dCh7XG4gIGlubmVyUmVmLFxuICAuLi5wcm9wc1xufTogSlNYLkludHJpbnNpY0VsZW1lbnRzWydpbnB1dCddICYge1xuICByZWFkb25seSBpbm5lclJlZjogUmVmPEhUTUxJbnB1dEVsZW1lbnQ+O1xufSkge1xuICAvLyBSZW1vdmUgYW5pbWF0aW9uIHByb3BzIG5vdCBtZWFudCBmb3IgSFRNTCBlbGVtZW50c1xuICBjb25zdCBmaWx0ZXJlZFByb3BzID0gcmVtb3ZlUHJvcHMoXG4gICAgcHJvcHMsXG4gICAgJ29uRXhpdGVkJyxcbiAgICAnaW4nLFxuICAgICdlbnRlcicsXG4gICAgJ2V4aXQnLFxuICAgICdhcHBlYXInXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8aW5wdXRcbiAgICAgIHJlZj17aW5uZXJSZWZ9XG4gICAgICB7Li4uZmlsdGVyZWRQcm9wc31cbiAgICAgIGNzcz17e1xuICAgICAgICBsYWJlbDogJ2R1bW15SW5wdXQnLFxuICAgICAgICAvLyBnZXQgcmlkIG9mIGFueSBkZWZhdWx0IHN0eWxlc1xuICAgICAgICBiYWNrZ3JvdW5kOiAwLFxuICAgICAgICBib3JkZXI6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgdGhpcyBoaWRlcyB0aGUgZmxhc2hpbmcgY3Vyc29yXG4gICAgICAgIGNhcmV0Q29sb3I6ICd0cmFuc3BhcmVudCcsXG4gICAgICAgIGZvbnRTaXplOiAnaW5oZXJpdCcsXG4gICAgICAgIGdyaWRBcmVhOiAnMSAvIDEgLyAyIC8gMycsXG4gICAgICAgIG91dGxpbmU6IDAsXG4gICAgICAgIHBhZGRpbmc6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgd2l0aG91dCBgd2lkdGhgIGJyb3dzZXJzIHdvbid0IGFsbG93IGZvY3VzXG4gICAgICAgIHdpZHRoOiAxLFxuXG4gICAgICAgIC8vIHJlbW92ZSBjdXJzb3Igb24gZGVza3RvcFxuICAgICAgICBjb2xvcjogJ3RyYW5zcGFyZW50JyxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIG1vYmlsZSB3aGlsc3QgbWFpbnRhaW5pbmcgXCJzY3JvbGwgaW50byB2aWV3XCIgYmVoYXZpb3VyXG4gICAgICAgIGxlZnQ6IC0xMDAsXG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSguMDEpJyxcbiAgICAgIH19XG4gICAgLz5cbiAgKTtcbn1cbiJdfQ== */")
18268
18051
  }));
18269
18052
  }
18270
18053
 
@@ -18377,7 +18160,7 @@
18377
18160
  height: '100%'
18378
18161
  };
18379
18162
  function preventTouchMove(e) {
18380
- e.preventDefault();
18163
+ if (e.cancelable) e.preventDefault();
18381
18164
  }
18382
18165
  function allowTouchMove(e) {
18383
18166
  e.stopPropagation();
@@ -18404,7 +18187,7 @@
18404
18187
  capture: false,
18405
18188
  passive: false
18406
18189
  };
18407
- function useScrollLock(_ref) {
18190
+ function useScrollLock$1(_ref) {
18408
18191
  var isEnabled = _ref.isEnabled,
18409
18192
  _ref$accountForScroll = _ref.accountForScrollbars,
18410
18193
  accountForScrollbars = _ref$accountForScroll === void 0 ? true : _ref$accountForScroll;
@@ -18523,7 +18306,7 @@
18523
18306
  onTopArrive: onTopArrive,
18524
18307
  onTopLeave: onTopLeave
18525
18308
  });
18526
- var setScrollLockTarget = useScrollLock({
18309
+ var setScrollLockTarget = useScrollLock$1({
18527
18310
  isEnabled: lockEnabled
18528
18311
  });
18529
18312
  var targetRef = function targetRef(element) {
@@ -18999,10 +18782,12 @@
18999
18782
  var lastSelectedValue = selectValue[selectValue.length - 1];
19000
18783
  var newValueArray = selectValue.slice(0, selectValue.length - 1);
19001
18784
  var newValue = valueTernary(isMulti, newValueArray, newValueArray[0] || null);
19002
- _this.onChange(newValue, {
19003
- action: 'pop-value',
19004
- removedValue: lastSelectedValue
19005
- });
18785
+ if (lastSelectedValue) {
18786
+ _this.onChange(newValue, {
18787
+ action: 'pop-value',
18788
+ removedValue: lastSelectedValue
18789
+ });
18790
+ }
19006
18791
  };
19007
18792
  _this.getFocusedOptionId = function (focusedOption) {
19008
18793
  return getFocusedOptionId(_this.state.focusableOptionsWithIds, focusedOption);
@@ -24528,19 +24313,18 @@
24528
24313
  }
24529
24314
 
24530
24315
  var SelectControl$1 = function SelectControl(_a) {
24531
- var iconLeft = _a.iconLeft,
24532
- isFocused = _a.isFocused,
24316
+ var isFocused = _a.isFocused,
24533
24317
  children = _a.children,
24534
- props = __rest$3(_a, ["iconLeft", "isFocused", "children"]);
24318
+ props = __rest$3(_a, ["isFocused", "children"]);
24535
24319
 
24536
24320
  return /*#__PURE__*/React__default["default"].createElement("div", {
24537
24321
  "data-testid": "select-control"
24538
24322
  }, /*#__PURE__*/React__default["default"].createElement(components.Control, Object.assign({
24539
24323
  className: isFocused ? "nds-select--is-focused" : null,
24540
24324
  isFocused: isFocused
24541
- }, props), iconLeft && /*#__PURE__*/React__default["default"].createElement(InputIcon, {
24325
+ }, props), props.selectProps.iconLeft && /*#__PURE__*/React__default["default"].createElement(InputIcon, {
24542
24326
  left: "x1",
24543
- icon: iconLeft,
24327
+ icon: props.selectProps.iconLeft,
24544
24328
  size: "x3"
24545
24329
  }), children));
24546
24330
  };
@@ -24620,8 +24404,7 @@
24620
24404
  defaultOptions = _a.defaultOptions,
24621
24405
  loadOptions = _a.loadOptions,
24622
24406
  isClearable = _a.isClearable,
24623
- iconLeft = _a.iconLeft,
24624
- props = __rest$3(_a, ["autocomplete", "labelText", "required", "requirementText", "helpText", "noOptionsMessage", "disabled", "errorMessage", "errorList", "id", "initialIsOpen", "maxHeight", "menuPosition", "multiselect", "name", "onChange", "placeholder", "value", "defaultValue", "className", "classNamePrefix", "onBlur", "menuIsOpen", "onMenuOpen", "onMenuClose", "onInputChange", "components", "aria-label", "cacheOptions", "defaultOptions", "loadOptions", "isClearable", "iconLeft"]);
24407
+ props = __rest$3(_a, ["autocomplete", "labelText", "required", "requirementText", "helpText", "noOptionsMessage", "disabled", "errorMessage", "errorList", "id", "initialIsOpen", "maxHeight", "menuPosition", "multiselect", "name", "onChange", "placeholder", "value", "defaultValue", "className", "classNamePrefix", "onBlur", "menuIsOpen", "onMenuOpen", "onMenuClose", "onInputChange", "components", "aria-label", "cacheOptions", "defaultOptions", "loadOptions", "isClearable"]);
24625
24408
 
24626
24409
  var _useTranslation = useTranslation(),
24627
24410
  t = _useTranslation.t;
@@ -24635,7 +24418,7 @@
24635
24418
  labelText: labelText,
24636
24419
  requirementText: requirementText,
24637
24420
  helpText: helpText
24638
- }, /*#__PURE__*/React__default["default"].createElement(AsyncSelect$1$1, {
24421
+ }, /*#__PURE__*/React__default["default"].createElement(AsyncSelect$1$1, Object.assign({
24639
24422
  className: className,
24640
24423
  classNamePrefix: classNamePrefix,
24641
24424
  noOptionsMessage: noOptionsMessage,
@@ -24644,7 +24427,7 @@
24644
24427
  defaultInputValue: defaultValue,
24645
24428
  placeholder: placeholder || t("start typing"),
24646
24429
  styles: customStyles({
24647
- hasIcon: Boolean(iconLeft),
24430
+ hasIcon: Boolean(props.iconLeft),
24648
24431
  theme: theme,
24649
24432
  error: error,
24650
24433
  variant: variant,
@@ -24668,18 +24451,13 @@
24668
24451
  onMenuClose: onMenuClose,
24669
24452
  menuPosition: menuPosition,
24670
24453
  onInputChange: onInputChange,
24671
- theme: theme,
24672
24454
  components: Object.assign({
24673
24455
  Option: function Option(props) {
24674
24456
  return /*#__PURE__*/React__default["default"].createElement(SelectOption, Object.assign({
24675
24457
  variant: componentVariant
24676
24458
  }, props), props.children);
24677
24459
  },
24678
- Control: function Control(props) {
24679
- return /*#__PURE__*/React__default["default"].createElement(SelectControl$1, Object.assign({
24680
- iconLeft: iconLeft
24681
- }, props), props.children);
24682
- },
24460
+ Control: SelectControl$1,
24683
24461
  MultiValue: SelectMultiValue$1,
24684
24462
  ClearIndicator: SelectClearIndicator$1,
24685
24463
  DropdownIndicator: SelectDropdownIndicator$1,
@@ -24692,7 +24470,7 @@
24692
24470
  defaultOptions: defaultOptions,
24693
24471
  loadOptions: loadOptions,
24694
24472
  isClearable: isClearable
24695
- }), /*#__PURE__*/React__default["default"].createElement(InlineValidation, {
24473
+ }, props)), /*#__PURE__*/React__default["default"].createElement(InlineValidation, {
24696
24474
  mt: "x1",
24697
24475
  errorMessage: errorMessage,
24698
24476
  errorList: errorList
@@ -24745,7 +24523,7 @@
24745
24523
  * @param deps
24746
24524
  */
24747
24525
 
24748
- var useIsomorphicLayoutEffect$2 = /*#__PURE__*/canUseDOM() ? React.useLayoutEffect : React.useEffect;
24526
+ var useIsomorphicLayoutEffect$3 = /*#__PURE__*/canUseDOM() ? React.useLayoutEffect : React.useEffect;
24749
24527
 
24750
24528
  /**
24751
24529
  * Forces a re-render, similar to `forceUpdate` in class components.
@@ -24820,7 +24598,7 @@
24820
24598
  }, [containerRef]);
24821
24599
  }
24822
24600
 
24823
- useIsomorphicLayoutEffect$2(function () {
24601
+ useIsomorphicLayoutEffect$3(function () {
24824
24602
  // This ref may be null when a hot-loader replaces components on the page
24825
24603
  if (!mountNode.current) return; // It's possible that the content of the portal has, itself, been portaled.
24826
24604
  // In that case, it's important to append to the correct document element.
@@ -25141,7 +24919,7 @@
25141
24919
  return ref.facade;
25142
24920
  }
25143
24921
 
25144
- var useIsomorphicLayoutEffect$1 = typeof window !== 'undefined' ? React__namespace.useLayoutEffect : React__namespace.useEffect;
24922
+ var useIsomorphicLayoutEffect$2 = typeof window !== 'undefined' ? React__namespace.useLayoutEffect : React__namespace.useEffect;
25145
24923
  var currentValues = new WeakMap();
25146
24924
  /**
25147
24925
  * Merges two or more refs together providing a single interface to set their value
@@ -25162,7 +24940,7 @@
25162
24940
  return refs.forEach(function (ref) { return assignRef(ref, newValue); });
25163
24941
  });
25164
24942
  // handle refs changes - added or removed
25165
- useIsomorphicLayoutEffect$1(function () {
24943
+ useIsomorphicLayoutEffect$2(function () {
25166
24944
  var oldValue = currentValues.get(callbackRef);
25167
24945
  if (oldValue) {
25168
24946
  var prevRefs_1 = new Set(oldValue);
@@ -29614,6 +29392,116 @@
29614
29392
  };
29615
29393
  });
29616
29394
 
29395
+ var useIsomorphicLayoutEffect$1 = typeof window !== "undefined" ? React.useLayoutEffect : React.useEffect;
29396
+ var IS_SERVER = typeof window === "undefined";
29397
+ /**
29398
+ * A custom hook that locks and unlocks scroll.
29399
+ * @param {UseScrollLockOptions} [options] - Options to configure the hook, by default it will lock the scroll automatically.
29400
+ * @returns {UseScrollLockReturn} - An object containing the lock and unlock functions.
29401
+ * @public
29402
+ * @see [Documentation](https://usehooks-ts.com/react-hook/use-scroll-lock)
29403
+ * @example
29404
+ * ```tsx
29405
+ * // Lock the scroll when the modal is mounted, and unlock it when it's unmounted
29406
+ * useScrollLock()
29407
+ * ```
29408
+ * @example
29409
+ * ```tsx
29410
+ * // Manually lock and unlock the scroll
29411
+ * const { lock, unlock } = useScrollLock({ autoLock: false })
29412
+ *
29413
+ * return (
29414
+ * <div>
29415
+ * <button onClick={lock}>Lock</button>
29416
+ * <button onClick={unlock}>Unlock</button>
29417
+ * </div>
29418
+ * )
29419
+ * ```
29420
+ */
29421
+
29422
+ function useScrollLock(options) {
29423
+ if (options === void 0) {
29424
+ options = {};
29425
+ }
29426
+
29427
+ var _options = options,
29428
+ _options$autoLock = _options.autoLock,
29429
+ autoLock = _options$autoLock === void 0 ? true : _options$autoLock,
29430
+ lockTarget = _options.lockTarget,
29431
+ _options$widthReflow = _options.widthReflow,
29432
+ widthReflow = _options$widthReflow === void 0 ? true : _options$widthReflow;
29433
+
29434
+ var _useState = React.useState(false),
29435
+ isLocked = _useState[0],
29436
+ setIsLocked = _useState[1];
29437
+
29438
+ var target = React.useRef(null);
29439
+ var originalStyle = React.useRef(null);
29440
+
29441
+ var lock = function lock() {
29442
+ if (target.current) {
29443
+ var _target$current$style = target.current.style,
29444
+ overflow = _target$current$style.overflow,
29445
+ paddingRight = _target$current$style.paddingRight; // Save the original styles
29446
+
29447
+ originalStyle.current = {
29448
+ overflow: overflow,
29449
+ paddingRight: paddingRight
29450
+ }; // Prevent width reflow
29451
+
29452
+ if (widthReflow) {
29453
+ // Use window inner width if body is the target as global scrollbar isn't part of the document
29454
+ var offsetWidth = target.current === document.body ? window.innerWidth : target.current.offsetWidth; // Get current computed padding right in pixels
29455
+
29456
+ var currentPaddingRight = parseInt(window.getComputedStyle(target.current).paddingRight, 10) || 0;
29457
+ var scrollbarWidth = offsetWidth - target.current.scrollWidth;
29458
+ target.current.style.paddingRight = scrollbarWidth + currentPaddingRight + "px";
29459
+ } // Lock the scroll
29460
+
29461
+
29462
+ target.current.style.overflow = "hidden";
29463
+ setIsLocked(true);
29464
+ }
29465
+ };
29466
+
29467
+ var unlock = function unlock() {
29468
+ if (target.current && originalStyle.current) {
29469
+ target.current.style.overflow = originalStyle.current.overflow; // Only reset padding right if we changed it
29470
+
29471
+ if (widthReflow) {
29472
+ target.current.style.paddingRight = originalStyle.current.paddingRight;
29473
+ }
29474
+ }
29475
+
29476
+ setIsLocked(false);
29477
+ };
29478
+
29479
+ useIsomorphicLayoutEffect$1(function () {
29480
+ if (IS_SERVER) return;
29481
+
29482
+ if (lockTarget) {
29483
+ target.current = typeof lockTarget === "string" ? document.querySelector(lockTarget) : lockTarget;
29484
+ }
29485
+
29486
+ if (!target.current) {
29487
+ target.current = document.body;
29488
+ }
29489
+
29490
+ if (autoLock) {
29491
+ lock();
29492
+ }
29493
+
29494
+ return function () {
29495
+ unlock();
29496
+ }; // eslint-disable-next-line react-hooks/exhaustive-deps
29497
+ }, [autoLock, lockTarget, widthReflow]);
29498
+ return {
29499
+ isLocked: isLocked,
29500
+ lock: lock,
29501
+ unlock: unlock
29502
+ };
29503
+ }
29504
+
29617
29505
  var borderStyle = "1px solid #e4e7eb";
29618
29506
  var BrandingWrap = styled__default["default"].div.withConfig({
29619
29507
  displayName: "MobileMenu__BrandingWrap",
@@ -29844,6 +29732,7 @@
29844
29732
  showNulogyLogo = _a.showNulogyLogo,
29845
29733
  props = __rest$3(_a, ["menuData", "closeMenu", "subtext", "themeColorObject", "showNulogyLogo"]);
29846
29734
 
29735
+ useScrollLock();
29847
29736
  return /*#__PURE__*/React__default["default"].createElement(Nav, Object.assign({
29848
29737
  backgroundColor: themeColorObject && themeColorObject.background
29849
29738
  }, props), /*#__PURE__*/React__default["default"].createElement(BrandingWrap, null, /*#__PURE__*/React__default["default"].createElement(BrandingText, {
@@ -30000,13 +29889,13 @@
30000
29889
  "aria-expanded": ariaExpanded
30001
29890
  }), /*#__PURE__*/React__default["default"].createElement(MenuIcon, {
30002
29891
  isOpen: isOpen
30003
- }))))), isOpen && /*#__PURE__*/React__default["default"].createElement(PreventBodyElementScrolling, null, /*#__PURE__*/React__default["default"].createElement(MobileMenu, {
29892
+ }))))), isOpen && /*#__PURE__*/React__default["default"].createElement(MobileMenu, {
30004
29893
  themeColorObject: themeColorObject,
30005
29894
  subtext: subtext,
30006
29895
  menuData: menuData,
30007
29896
  closeMenu: closeMenu,
30008
29897
  showNulogyLogo: showNulogyLogo
30009
- })));
29898
+ }));
30010
29899
  };
30011
29900
  /* eslint-enable react/destructuring-assignment */
30012
29901
 
@@ -45496,6 +45385,9 @@
45496
45385
  var sideBarRef = React.useRef(null);
45497
45386
  var contentRef = React.useRef(null);
45498
45387
  var selectedWidth = (_b = sidebarWidths[width]) !== null && _b !== void 0 ? _b : width;
45388
+ useScrollLock({
45389
+ autoLock: overlay && disableScroll && isOpen
45390
+ });
45499
45391
  React.useEffect(function () {
45500
45392
  var _a;
45501
45393
 
@@ -45626,9 +45518,7 @@
45626
45518
  width: "100%",
45627
45519
  p: p,
45628
45520
  pt: "x2"
45629
- }, footer), overlay && disableScroll && isOpen && /*#__PURE__*/React__default["default"].createElement(PreventBodyElementScrolling, {
45630
- scrollRef: sideBarRef
45631
- })));
45521
+ }, footer)));
45632
45522
  }
45633
45523
 
45634
45524
  function LoadingAnimation(_ref) {
@@ -47686,7 +47576,7 @@
47686
47576
  footerContent = _ref4.footerContent,
47687
47577
  closeAriaLabel = _ref4.closeAriaLabel,
47688
47578
  parentSelector = _ref4.parentSelector;
47689
- var modalHasHeader = onRequestClose || title;
47579
+ var modalHasHeader = Boolean(onRequestClose || title);
47690
47580
  var themeContext = React.useContext(styled.ThemeContext);
47691
47581
  return /*#__PURE__*/React__default["default"].createElement(StyledReactModal, {
47692
47582
  maxWidth: maxWidth,
@@ -47712,22 +47602,40 @@
47712
47602
  appElement: appElement,
47713
47603
  ariaHideApp: ariaHideApp,
47714
47604
  parentSelector: parentSelector
47715
- }, /*#__PURE__*/React__default["default"].createElement(PreventBodyElementScrolling, null, modalHasHeader && /*#__PURE__*/React__default["default"].createElement(ModalHeader, {
47605
+ }, /*#__PURE__*/React__default["default"].createElement(ModalWrapper, {
47606
+ closeAriaLabel: closeAriaLabel,
47607
+ modalHasHeader: modalHasHeader,
47608
+ title: title,
47609
+ onRequestClose: onRequestClose,
47610
+ footerContent: footerContent
47611
+ }, children));
47612
+ };
47613
+
47614
+ function ModalWrapper(_ref5) {
47615
+ var modalHasHeader = _ref5.modalHasHeader,
47616
+ title = _ref5.title,
47617
+ onRequestClose = _ref5.onRequestClose,
47618
+ closeAriaLabel = _ref5.closeAriaLabel,
47619
+ children = _ref5.children,
47620
+ footerContent = _ref5.footerContent;
47621
+ var theme = styled.useTheme();
47622
+ useScrollLock();
47623
+ return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, modalHasHeader && /*#__PURE__*/React__default["default"].createElement(ModalHeader, {
47716
47624
  hasCloseButton: Boolean(onRequestClose)
47717
47625
  }, title ? /*#__PURE__*/React__default["default"].createElement(Heading2, {
47718
47626
  id: "modal-title",
47719
47627
  mb: "none"
47720
47628
  }, title) : /*#__PURE__*/React__default["default"].createElement("div", {
47721
47629
  style: {
47722
- height: themeContext.space.x4
47630
+ height: theme.space.x4
47723
47631
  }
47724
47632
  }), onRequestClose && /*#__PURE__*/React__default["default"].createElement(ModalCloseButton, {
47725
47633
  onClick: onRequestClose,
47726
47634
  "aria-label": closeAriaLabel
47727
47635
  })), /*#__PURE__*/React__default["default"].createElement(ModalContent, {
47728
47636
  hasFooter: !!footerContent
47729
- }, children), footerContent && /*#__PURE__*/React__default["default"].createElement(ModalFooter, null, footerContent)));
47730
- };
47637
+ }, children), footerContent && /*#__PURE__*/React__default["default"].createElement(ModalFooter, null, footerContent));
47638
+ }
47731
47639
 
47732
47640
  Modal.setAppElement = ReactModal.setAppElement;
47733
47641