@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.
@@ -338,12 +338,12 @@ function useVisualElementContext() {
338
338
  }
339
339
 
340
340
  var isBrowser$7 = typeof window !== "undefined";
341
- var useIsomorphicLayoutEffect$4 = isBrowser$7 ? useLayoutEffect : useEffect;
341
+ var useIsomorphicLayoutEffect$5 = isBrowser$7 ? useLayoutEffect : useEffect;
342
342
 
343
343
  function useSnapshotOnUnmount(visualElement) {
344
344
  var syncLayout = useContext(SharedLayoutContext);
345
345
  var framerSyncLayout = useContext(FramerTreeLayoutContext);
346
- useIsomorphicLayoutEffect$4(function () { return function () {
346
+ useIsomorphicLayoutEffect$5(function () { return function () {
347
347
  if (isSharedLayout(syncLayout)) {
348
348
  syncLayout.remove(visualElement);
349
349
  }
@@ -374,7 +374,7 @@ function useVisualElement(isStatic, visualState, createVisualElement, props) {
374
374
  blockInitialAnimation: (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false,
375
375
  });
376
376
  });
377
- useIsomorphicLayoutEffect$4(function () {
377
+ useIsomorphicLayoutEffect$5(function () {
378
378
  visualElement.setProps(__assign$3(__assign$3(__assign$3({}, config), props), { layoutId: layoutId }));
379
379
  visualElement.isPresent = isPresent(presenceContext);
380
380
  visualElement.isPresenceRoot =
@@ -10702,225 +10702,6 @@ function withMenuState(MenuComponent) {
10702
10702
  };
10703
10703
  }
10704
10704
 
10705
- 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); } }
10706
-
10707
- // Older browsers don't support event options, feature detect it.
10708
-
10709
- // Adopted and modified solution from Bohdan Didukh (2017)
10710
- // https://stackoverflow.com/questions/41594997/ios-10-safari-prevent-scrolling-behind-a-fixed-overlay-and-maintain-scroll-posi
10711
-
10712
- var hasPassiveEvents = false;
10713
- if (typeof window !== 'undefined') {
10714
- var passiveTestOptions = {
10715
- get passive() {
10716
- hasPassiveEvents = true;
10717
- return undefined;
10718
- }
10719
- };
10720
- window.addEventListener('testPassive', null, passiveTestOptions);
10721
- window.removeEventListener('testPassive', null, passiveTestOptions);
10722
- }
10723
-
10724
- 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);
10725
-
10726
-
10727
- var locks = [];
10728
- var documentListenerAdded = false;
10729
- var initialClientY = -1;
10730
- var previousBodyOverflowSetting = void 0;
10731
- var previousBodyPaddingRight = void 0;
10732
-
10733
- // returns true if `el` should be allowed to receive touchmove events.
10734
- var allowTouchMove$1 = function allowTouchMove(el) {
10735
- return locks.some(function (lock) {
10736
- if (lock.options.allowTouchMove && lock.options.allowTouchMove(el)) {
10737
- return true;
10738
- }
10739
-
10740
- return false;
10741
- });
10742
- };
10743
-
10744
- var preventDefault = function preventDefault(rawEvent) {
10745
- var e = rawEvent || window.event;
10746
-
10747
- // For the case whereby consumers adds a touchmove event listener to document.
10748
- // Recall that we do document.addEventListener('touchmove', preventDefault, { passive: false })
10749
- // in disableBodyScroll - so if we provide this opportunity to allowTouchMove, then
10750
- // the touchmove event on document will break.
10751
- if (allowTouchMove$1(e.target)) {
10752
- return true;
10753
- }
10754
-
10755
- // Do not prevent if the event has more than one touch (usually meaning this is a multi touch gesture like pinch to zoom).
10756
- if (e.touches.length > 1) return true;
10757
-
10758
- if (e.preventDefault) e.preventDefault();
10759
-
10760
- return false;
10761
- };
10762
-
10763
- var setOverflowHidden = function setOverflowHidden(options) {
10764
- // If previousBodyPaddingRight is already set, don't set it again.
10765
- if (previousBodyPaddingRight === undefined) {
10766
- var _reserveScrollBarGap = !!options && options.reserveScrollBarGap === true;
10767
- var scrollBarGap = window.innerWidth - document.documentElement.clientWidth;
10768
-
10769
- if (_reserveScrollBarGap && scrollBarGap > 0) {
10770
- previousBodyPaddingRight = document.body.style.paddingRight;
10771
- document.body.style.paddingRight = scrollBarGap + 'px';
10772
- }
10773
- }
10774
-
10775
- // If previousBodyOverflowSetting is already set, don't set it again.
10776
- if (previousBodyOverflowSetting === undefined) {
10777
- previousBodyOverflowSetting = document.body.style.overflow;
10778
- document.body.style.overflow = 'hidden';
10779
- }
10780
- };
10781
-
10782
- var restoreOverflowSetting = function restoreOverflowSetting() {
10783
- if (previousBodyPaddingRight !== undefined) {
10784
- document.body.style.paddingRight = previousBodyPaddingRight;
10785
-
10786
- // Restore previousBodyPaddingRight to undefined so setOverflowHidden knows it
10787
- // can be set again.
10788
- previousBodyPaddingRight = undefined;
10789
- }
10790
-
10791
- if (previousBodyOverflowSetting !== undefined) {
10792
- document.body.style.overflow = previousBodyOverflowSetting;
10793
-
10794
- // Restore previousBodyOverflowSetting to undefined
10795
- // so setOverflowHidden knows it can be set again.
10796
- previousBodyOverflowSetting = undefined;
10797
- }
10798
- };
10799
-
10800
- // https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#Problems_and_solutions
10801
- var isTargetElementTotallyScrolled = function isTargetElementTotallyScrolled(targetElement) {
10802
- return targetElement ? targetElement.scrollHeight - targetElement.scrollTop <= targetElement.clientHeight : false;
10803
- };
10804
-
10805
- var handleScroll$1 = function handleScroll(event, targetElement) {
10806
- var clientY = event.targetTouches[0].clientY - initialClientY;
10807
-
10808
- if (allowTouchMove$1(event.target)) {
10809
- return false;
10810
- }
10811
-
10812
- if (targetElement && targetElement.scrollTop === 0 && clientY > 0) {
10813
- // element is at the top of its scroll.
10814
- return preventDefault(event);
10815
- }
10816
-
10817
- if (isTargetElementTotallyScrolled(targetElement) && clientY < 0) {
10818
- // element is at the bottom of its scroll.
10819
- return preventDefault(event);
10820
- }
10821
-
10822
- event.stopPropagation();
10823
- return true;
10824
- };
10825
-
10826
- var disableBodyScroll = function disableBodyScroll(targetElement, options) {
10827
- // targetElement must be provided
10828
- if (!targetElement) {
10829
- // eslint-disable-next-line no-console
10830
- console.error('disableBodyScroll unsuccessful - targetElement must be provided when calling disableBodyScroll on IOS devices.');
10831
- return;
10832
- }
10833
-
10834
- // disableBodyScroll must not have been called on this targetElement before
10835
- if (locks.some(function (lock) {
10836
- return lock.targetElement === targetElement;
10837
- })) {
10838
- return;
10839
- }
10840
-
10841
- var lock = {
10842
- targetElement: targetElement,
10843
- options: options || {}
10844
- };
10845
-
10846
- locks = [].concat(_toConsumableArray$1(locks), [lock]);
10847
-
10848
- if (isIosDevice) {
10849
- targetElement.ontouchstart = function (event) {
10850
- if (event.targetTouches.length === 1) {
10851
- // detect single touch.
10852
- initialClientY = event.targetTouches[0].clientY;
10853
- }
10854
- };
10855
- targetElement.ontouchmove = function (event) {
10856
- if (event.targetTouches.length === 1) {
10857
- // detect single touch.
10858
- handleScroll$1(event, targetElement);
10859
- }
10860
- };
10861
-
10862
- if (!documentListenerAdded) {
10863
- document.addEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);
10864
- documentListenerAdded = true;
10865
- }
10866
- } else {
10867
- setOverflowHidden(options);
10868
- }
10869
- };
10870
-
10871
- var clearAllBodyScrollLocks = function clearAllBodyScrollLocks() {
10872
- if (isIosDevice) {
10873
- // Clear all locks ontouchstart/ontouchmove handlers, and the references.
10874
- locks.forEach(function (lock) {
10875
- lock.targetElement.ontouchstart = null;
10876
- lock.targetElement.ontouchmove = null;
10877
- });
10878
-
10879
- if (documentListenerAdded) {
10880
- document.removeEventListener('touchmove', preventDefault, hasPassiveEvents ? { passive: false } : undefined);
10881
- documentListenerAdded = false;
10882
- }
10883
-
10884
- // Reset initial clientY.
10885
- initialClientY = -1;
10886
- } else {
10887
- restoreOverflowSetting();
10888
- }
10889
-
10890
- locks = [];
10891
- };
10892
-
10893
- var PreventBodyElementScrolling = /*#__PURE__*/function (_React$Component) {
10894
- _inheritsLoose$3(PreventBodyElementScrolling, _React$Component);
10895
-
10896
- function PreventBodyElementScrolling() {
10897
- return _React$Component.apply(this, arguments) || this;
10898
- }
10899
-
10900
- var _proto = PreventBodyElementScrolling.prototype;
10901
-
10902
- _proto.componentDidMount = function componentDidMount() {
10903
- var scrollableRef = this.props.scrollableRef;
10904
- var refs = Array.isArray(scrollableRef) ? scrollableRef : [scrollableRef];
10905
- refs.every(function (ref) {
10906
- if (ref && ref.current) {
10907
- disableBodyScroll(ref.current);
10908
- }
10909
- });
10910
- };
10911
-
10912
- _proto.componentWillUnmount = function componentWillUnmount() {
10913
- clearAllBodyScrollLocks();
10914
- };
10915
-
10916
- _proto.render = function render() {
10917
- var children = this.props.children;
10918
- return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, children);
10919
- };
10920
-
10921
- return PreventBodyElementScrolling;
10922
- }(React__default.Component);
10923
-
10924
10705
  var convertPxToNumber = function convertPxToNumber(px) {
10925
10706
  return parseFloat(px);
10926
10707
  };
@@ -11236,7 +11017,7 @@ var fromEntries$1 = function fromEntries(entries) {
11236
11017
  * Small wrapper around `useLayoutEffect` to get rid of the warning on SSR envs
11237
11018
  */
11238
11019
 
11239
- var useIsomorphicLayoutEffect$3 = typeof window !== 'undefined' && window.document && window.document.createElement ? React.useLayoutEffect : React.useEffect;
11020
+ var useIsomorphicLayoutEffect$4 = typeof window !== 'undefined' && window.document && window.document.createElement ? React.useLayoutEffect : React.useEffect;
11240
11021
 
11241
11022
  var top = 'top';
11242
11023
  var bottom = 'bottom';
@@ -13181,12 +12962,12 @@ var usePopper$1 = function usePopper(referenceElement, popperElement, options) {
13181
12962
  }
13182
12963
  }, [optionsWithDefaults.onFirstUpdate, optionsWithDefaults.placement, optionsWithDefaults.strategy, optionsWithDefaults.modifiers, updateStateModifier]);
13183
12964
  var popperInstanceRef = React.useRef();
13184
- useIsomorphicLayoutEffect$3(function () {
12965
+ useIsomorphicLayoutEffect$4(function () {
13185
12966
  if (popperInstanceRef.current) {
13186
12967
  popperInstanceRef.current.setOptions(popperOptions);
13187
12968
  }
13188
12969
  }, [popperOptions]);
13189
- useIsomorphicLayoutEffect$3(function () {
12970
+ useIsomorphicLayoutEffect$4(function () {
13190
12971
  if (referenceElement == null || popperElement == null) {
13191
12972
  return;
13192
12973
  }
@@ -16261,7 +16042,9 @@ function autoUpdate(reference, floating, update, options) {
16261
16042
  };
16262
16043
  }
16263
16044
 
16264
- var index = typeof document !== 'undefined' ? useLayoutEffect : useEffect;
16045
+ var isClient = typeof document !== 'undefined';
16046
+
16047
+ var index = isClient ? useLayoutEffect : useEffect;
16265
16048
 
16266
16049
  var _excluded$4$1 = ["className", "clearValue", "cx", "getStyles", "getClassNames", "getValue", "hasValue", "isMulti", "isRtl", "options", "selectOption", "selectProps", "setValue", "theme"];
16267
16050
  // ==============================
@@ -17072,7 +16855,7 @@ var _ref2$2 = process.env.NODE_ENV === "production" ? {
17072
16855
  } : {
17073
16856
  name: "tj5bde-Svg",
17074
16857
  styles: "display:inline-block;fill:currentColor;line-height:1;stroke:currentColor;stroke-width:0;label:Svg;",
17075
- 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"]} */",
16858
+ 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"]} */",
17076
16859
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
17077
16860
  };
17078
16861
  var Svg = function Svg(_ref) {
@@ -17207,7 +16990,7 @@ var LoadingDot = function LoadingDot(_ref6) {
17207
16990
  height: '1em',
17208
16991
  verticalAlign: 'top',
17209
16992
  width: '1em'
17210
- }, 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"]} */")
16993
+ }, 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"]} */")
17211
16994
  });
17212
16995
  };
17213
16996
  var LoadingIndicator = function LoadingIndicator(_ref7) {
@@ -17703,7 +17486,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
17703
17486
  } : {
17704
17487
  name: "1f43avz-a11yText-A11yText",
17705
17488
  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;",
17706
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
17489
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IEpTWCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
17707
17490
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
17708
17491
  };
17709
17492
  var A11yText = function A11yText(props) {
@@ -18247,7 +18030,7 @@ function DummyInput(_ref) {
18247
18030
  opacity: 0,
18248
18031
  position: 'relative',
18249
18032
  transform: 'scale(.01)'
18250
- }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgcmVtb3ZlUHJvcHMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIER1bW15SW5wdXQoe1xuICBpbm5lclJlZixcbiAgLi4ucHJvcHNcbn06IEpTWC5JbnRyaW5zaWNFbGVtZW50c1snaW5wdXQnXSAmIHtcbiAgcmVhZG9ubHkgaW5uZXJSZWY6IFJlZjxIVE1MSW5wdXRFbGVtZW50Pjtcbn0pIHtcbiAgLy8gUmVtb3ZlIGFuaW1hdGlvbiBwcm9wcyBub3QgbWVhbnQgZm9yIEhUTUwgZWxlbWVudHNcbiAgY29uc3QgZmlsdGVyZWRQcm9wcyA9IHJlbW92ZVByb3BzKFxuICAgIHByb3BzLFxuICAgICdvbkV4aXRlZCcsXG4gICAgJ2luJyxcbiAgICAnZW50ZXInLFxuICAgICdleGl0JyxcbiAgICAnYXBwZWFyJ1xuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGlucHV0XG4gICAgICByZWY9e2lubmVyUmVmfVxuICAgICAgey4uLmZpbHRlcmVkUHJvcHN9XG4gICAgICBjc3M9e3tcbiAgICAgICAgbGFiZWw6ICdkdW1teUlucHV0JyxcbiAgICAgICAgLy8gZ2V0IHJpZCBvZiBhbnkgZGVmYXVsdCBzdHlsZXNcbiAgICAgICAgYmFja2dyb3VuZDogMCxcbiAgICAgICAgYm9yZGVyOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHRoaXMgaGlkZXMgdGhlIGZsYXNoaW5nIGN1cnNvclxuICAgICAgICBjYXJldENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICAgICAgICBmb250U2l6ZTogJ2luaGVyaXQnLFxuICAgICAgICBncmlkQXJlYTogJzEgLyAxIC8gMiAvIDMnLFxuICAgICAgICBvdXRsaW5lOiAwLFxuICAgICAgICBwYWRkaW5nOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHdpdGhvdXQgYHdpZHRoYCBicm93c2VycyB3b24ndCBhbGxvdyBmb2N1c1xuICAgICAgICB3aWR0aDogMSxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIGRlc2t0b3BcbiAgICAgICAgY29sb3I6ICd0cmFuc3BhcmVudCcsXG5cbiAgICAgICAgLy8gcmVtb3ZlIGN1cnNvciBvbiBtb2JpbGUgd2hpbHN0IG1haW50YWluaW5nIFwic2Nyb2xsIGludG8gdmlld1wiIGJlaGF2aW91clxuICAgICAgICBsZWZ0OiAtMTAwLFxuICAgICAgICBvcGFjaXR5OiAwLFxuICAgICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgICAgdHJhbnNmb3JtOiAnc2NhbGUoLjAxKScsXG4gICAgICB9fVxuICAgIC8+XG4gICk7XG59XG4iXX0= */")
18033
+ }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgSlNYLCBSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBqc3ggfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyByZW1vdmVQcm9wcyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRHVtbXlJbnB1dCh7XG4gIGlubmVyUmVmLFxuICAuLi5wcm9wc1xufTogSlNYLkludHJpbnNpY0VsZW1lbnRzWydpbnB1dCddICYge1xuICByZWFkb25seSBpbm5lclJlZjogUmVmPEhUTUxJbnB1dEVsZW1lbnQ+O1xufSkge1xuICAvLyBSZW1vdmUgYW5pbWF0aW9uIHByb3BzIG5vdCBtZWFudCBmb3IgSFRNTCBlbGVtZW50c1xuICBjb25zdCBmaWx0ZXJlZFByb3BzID0gcmVtb3ZlUHJvcHMoXG4gICAgcHJvcHMsXG4gICAgJ29uRXhpdGVkJyxcbiAgICAnaW4nLFxuICAgICdlbnRlcicsXG4gICAgJ2V4aXQnLFxuICAgICdhcHBlYXInXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8aW5wdXRcbiAgICAgIHJlZj17aW5uZXJSZWZ9XG4gICAgICB7Li4uZmlsdGVyZWRQcm9wc31cbiAgICAgIGNzcz17e1xuICAgICAgICBsYWJlbDogJ2R1bW15SW5wdXQnLFxuICAgICAgICAvLyBnZXQgcmlkIG9mIGFueSBkZWZhdWx0IHN0eWxlc1xuICAgICAgICBiYWNrZ3JvdW5kOiAwLFxuICAgICAgICBib3JkZXI6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgdGhpcyBoaWRlcyB0aGUgZmxhc2hpbmcgY3Vyc29yXG4gICAgICAgIGNhcmV0Q29sb3I6ICd0cmFuc3BhcmVudCcsXG4gICAgICAgIGZvbnRTaXplOiAnaW5oZXJpdCcsXG4gICAgICAgIGdyaWRBcmVhOiAnMSAvIDEgLyAyIC8gMycsXG4gICAgICAgIG91dGxpbmU6IDAsXG4gICAgICAgIHBhZGRpbmc6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgd2l0aG91dCBgd2lkdGhgIGJyb3dzZXJzIHdvbid0IGFsbG93IGZvY3VzXG4gICAgICAgIHdpZHRoOiAxLFxuXG4gICAgICAgIC8vIHJlbW92ZSBjdXJzb3Igb24gZGVza3RvcFxuICAgICAgICBjb2xvcjogJ3RyYW5zcGFyZW50JyxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIG1vYmlsZSB3aGlsc3QgbWFpbnRhaW5pbmcgXCJzY3JvbGwgaW50byB2aWV3XCIgYmVoYXZpb3VyXG4gICAgICAgIGxlZnQ6IC0xMDAsXG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSguMDEpJyxcbiAgICAgIH19XG4gICAgLz5cbiAgKTtcbn1cbiJdfQ== */")
18251
18034
  }));
18252
18035
  }
18253
18036
 
@@ -18360,7 +18143,7 @@ var LOCK_STYLES = {
18360
18143
  height: '100%'
18361
18144
  };
18362
18145
  function preventTouchMove(e) {
18363
- e.preventDefault();
18146
+ if (e.cancelable) e.preventDefault();
18364
18147
  }
18365
18148
  function allowTouchMove(e) {
18366
18149
  e.stopPropagation();
@@ -18387,7 +18170,7 @@ var listenerOptions = {
18387
18170
  capture: false,
18388
18171
  passive: false
18389
18172
  };
18390
- function useScrollLock(_ref) {
18173
+ function useScrollLock$1(_ref) {
18391
18174
  var isEnabled = _ref.isEnabled,
18392
18175
  _ref$accountForScroll = _ref.accountForScrollbars,
18393
18176
  accountForScrollbars = _ref$accountForScroll === void 0 ? true : _ref$accountForScroll;
@@ -18506,7 +18289,7 @@ function ScrollManager(_ref) {
18506
18289
  onTopArrive: onTopArrive,
18507
18290
  onTopLeave: onTopLeave
18508
18291
  });
18509
- var setScrollLockTarget = useScrollLock({
18292
+ var setScrollLockTarget = useScrollLock$1({
18510
18293
  isEnabled: lockEnabled
18511
18294
  });
18512
18295
  var targetRef = function targetRef(element) {
@@ -18982,10 +18765,12 @@ var Select = /*#__PURE__*/function (_Component) {
18982
18765
  var lastSelectedValue = selectValue[selectValue.length - 1];
18983
18766
  var newValueArray = selectValue.slice(0, selectValue.length - 1);
18984
18767
  var newValue = valueTernary(isMulti, newValueArray, newValueArray[0] || null);
18985
- _this.onChange(newValue, {
18986
- action: 'pop-value',
18987
- removedValue: lastSelectedValue
18988
- });
18768
+ if (lastSelectedValue) {
18769
+ _this.onChange(newValue, {
18770
+ action: 'pop-value',
18771
+ removedValue: lastSelectedValue
18772
+ });
18773
+ }
18989
18774
  };
18990
18775
  _this.getFocusedOptionId = function (focusedOption) {
18991
18776
  return getFocusedOptionId(_this.state.focusableOptionsWithIds, focusedOption);
@@ -24511,19 +24296,18 @@ function SelectOption$1(props) {
24511
24296
  }
24512
24297
 
24513
24298
  var SelectControl$1 = function SelectControl(_a) {
24514
- var iconLeft = _a.iconLeft,
24515
- isFocused = _a.isFocused,
24299
+ var isFocused = _a.isFocused,
24516
24300
  children = _a.children,
24517
- props = __rest$3(_a, ["iconLeft", "isFocused", "children"]);
24301
+ props = __rest$3(_a, ["isFocused", "children"]);
24518
24302
 
24519
24303
  return /*#__PURE__*/React__default.createElement("div", {
24520
24304
  "data-testid": "select-control"
24521
24305
  }, /*#__PURE__*/React__default.createElement(components.Control, Object.assign({
24522
24306
  className: isFocused ? "nds-select--is-focused" : null,
24523
24307
  isFocused: isFocused
24524
- }, props), iconLeft && /*#__PURE__*/React__default.createElement(InputIcon, {
24308
+ }, props), props.selectProps.iconLeft && /*#__PURE__*/React__default.createElement(InputIcon, {
24525
24309
  left: "x1",
24526
- icon: iconLeft,
24310
+ icon: props.selectProps.iconLeft,
24527
24311
  size: "x3"
24528
24312
  }), children));
24529
24313
  };
@@ -24603,8 +24387,7 @@ var AsyncSelect = /*#__PURE__*/forwardRef(function (_a, ref) {
24603
24387
  defaultOptions = _a.defaultOptions,
24604
24388
  loadOptions = _a.loadOptions,
24605
24389
  isClearable = _a.isClearable,
24606
- iconLeft = _a.iconLeft,
24607
- 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"]);
24390
+ 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"]);
24608
24391
 
24609
24392
  var _useTranslation = useTranslation(),
24610
24393
  t = _useTranslation.t;
@@ -24618,7 +24401,7 @@ var AsyncSelect = /*#__PURE__*/forwardRef(function (_a, ref) {
24618
24401
  labelText: labelText,
24619
24402
  requirementText: requirementText,
24620
24403
  helpText: helpText
24621
- }, /*#__PURE__*/React__default.createElement(AsyncSelect$1$1, {
24404
+ }, /*#__PURE__*/React__default.createElement(AsyncSelect$1$1, Object.assign({
24622
24405
  className: className,
24623
24406
  classNamePrefix: classNamePrefix,
24624
24407
  noOptionsMessage: noOptionsMessage,
@@ -24627,7 +24410,7 @@ var AsyncSelect = /*#__PURE__*/forwardRef(function (_a, ref) {
24627
24410
  defaultInputValue: defaultValue,
24628
24411
  placeholder: placeholder || t("start typing"),
24629
24412
  styles: customStyles({
24630
- hasIcon: Boolean(iconLeft),
24413
+ hasIcon: Boolean(props.iconLeft),
24631
24414
  theme: theme,
24632
24415
  error: error,
24633
24416
  variant: variant,
@@ -24651,18 +24434,13 @@ var AsyncSelect = /*#__PURE__*/forwardRef(function (_a, ref) {
24651
24434
  onMenuClose: onMenuClose,
24652
24435
  menuPosition: menuPosition,
24653
24436
  onInputChange: onInputChange,
24654
- theme: theme,
24655
24437
  components: Object.assign({
24656
24438
  Option: function Option(props) {
24657
24439
  return /*#__PURE__*/React__default.createElement(SelectOption, Object.assign({
24658
24440
  variant: componentVariant
24659
24441
  }, props), props.children);
24660
24442
  },
24661
- Control: function Control(props) {
24662
- return /*#__PURE__*/React__default.createElement(SelectControl$1, Object.assign({
24663
- iconLeft: iconLeft
24664
- }, props), props.children);
24665
- },
24443
+ Control: SelectControl$1,
24666
24444
  MultiValue: SelectMultiValue$1,
24667
24445
  ClearIndicator: SelectClearIndicator$1,
24668
24446
  DropdownIndicator: SelectDropdownIndicator$1,
@@ -24675,7 +24453,7 @@ var AsyncSelect = /*#__PURE__*/forwardRef(function (_a, ref) {
24675
24453
  defaultOptions: defaultOptions,
24676
24454
  loadOptions: loadOptions,
24677
24455
  isClearable: isClearable
24678
- }), /*#__PURE__*/React__default.createElement(InlineValidation, {
24456
+ }, props)), /*#__PURE__*/React__default.createElement(InlineValidation, {
24679
24457
  mt: "x1",
24680
24458
  errorMessage: errorMessage,
24681
24459
  errorList: errorList
@@ -24728,7 +24506,7 @@ function canUseDOM() {
24728
24506
  * @param deps
24729
24507
  */
24730
24508
 
24731
- var useIsomorphicLayoutEffect$2 = /*#__PURE__*/canUseDOM() ? useLayoutEffect : useEffect;
24509
+ var useIsomorphicLayoutEffect$3 = /*#__PURE__*/canUseDOM() ? useLayoutEffect : useEffect;
24732
24510
 
24733
24511
  /**
24734
24512
  * Forces a re-render, similar to `forceUpdate` in class components.
@@ -24803,7 +24581,7 @@ var PortalImpl = function PortalImpl(_ref) {
24803
24581
  }, [containerRef]);
24804
24582
  }
24805
24583
 
24806
- useIsomorphicLayoutEffect$2(function () {
24584
+ useIsomorphicLayoutEffect$3(function () {
24807
24585
  // This ref may be null when a hot-loader replaces components on the page
24808
24586
  if (!mountNode.current) return; // It's possible that the content of the portal has, itself, been portaled.
24809
24587
  // In that case, it's important to append to the correct document element.
@@ -25124,7 +24902,7 @@ function useCallbackRef(initialValue, callback) {
25124
24902
  return ref.facade;
25125
24903
  }
25126
24904
 
25127
- var useIsomorphicLayoutEffect$1 = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;
24905
+ var useIsomorphicLayoutEffect$2 = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;
25128
24906
  var currentValues = new WeakMap();
25129
24907
  /**
25130
24908
  * Merges two or more refs together providing a single interface to set their value
@@ -25145,7 +24923,7 @@ function useMergeRefs(refs, defaultValue) {
25145
24923
  return refs.forEach(function (ref) { return assignRef(ref, newValue); });
25146
24924
  });
25147
24925
  // handle refs changes - added or removed
25148
- useIsomorphicLayoutEffect$1(function () {
24926
+ useIsomorphicLayoutEffect$2(function () {
25149
24927
  var oldValue = currentValues.get(callbackRef);
25150
24928
  if (oldValue) {
25151
24929
  var prevRefs_1 = new Set(oldValue);
@@ -29597,6 +29375,116 @@ var NavBarSearch = styled(BaseNavBarSearch).withConfig({
29597
29375
  };
29598
29376
  });
29599
29377
 
29378
+ var useIsomorphicLayoutEffect$1 = typeof window !== "undefined" ? useLayoutEffect : useEffect;
29379
+ var IS_SERVER = typeof window === "undefined";
29380
+ /**
29381
+ * A custom hook that locks and unlocks scroll.
29382
+ * @param {UseScrollLockOptions} [options] - Options to configure the hook, by default it will lock the scroll automatically.
29383
+ * @returns {UseScrollLockReturn} - An object containing the lock and unlock functions.
29384
+ * @public
29385
+ * @see [Documentation](https://usehooks-ts.com/react-hook/use-scroll-lock)
29386
+ * @example
29387
+ * ```tsx
29388
+ * // Lock the scroll when the modal is mounted, and unlock it when it's unmounted
29389
+ * useScrollLock()
29390
+ * ```
29391
+ * @example
29392
+ * ```tsx
29393
+ * // Manually lock and unlock the scroll
29394
+ * const { lock, unlock } = useScrollLock({ autoLock: false })
29395
+ *
29396
+ * return (
29397
+ * <div>
29398
+ * <button onClick={lock}>Lock</button>
29399
+ * <button onClick={unlock}>Unlock</button>
29400
+ * </div>
29401
+ * )
29402
+ * ```
29403
+ */
29404
+
29405
+ function useScrollLock(options) {
29406
+ if (options === void 0) {
29407
+ options = {};
29408
+ }
29409
+
29410
+ var _options = options,
29411
+ _options$autoLock = _options.autoLock,
29412
+ autoLock = _options$autoLock === void 0 ? true : _options$autoLock,
29413
+ lockTarget = _options.lockTarget,
29414
+ _options$widthReflow = _options.widthReflow,
29415
+ widthReflow = _options$widthReflow === void 0 ? true : _options$widthReflow;
29416
+
29417
+ var _useState = useState(false),
29418
+ isLocked = _useState[0],
29419
+ setIsLocked = _useState[1];
29420
+
29421
+ var target = useRef(null);
29422
+ var originalStyle = useRef(null);
29423
+
29424
+ var lock = function lock() {
29425
+ if (target.current) {
29426
+ var _target$current$style = target.current.style,
29427
+ overflow = _target$current$style.overflow,
29428
+ paddingRight = _target$current$style.paddingRight; // Save the original styles
29429
+
29430
+ originalStyle.current = {
29431
+ overflow: overflow,
29432
+ paddingRight: paddingRight
29433
+ }; // Prevent width reflow
29434
+
29435
+ if (widthReflow) {
29436
+ // Use window inner width if body is the target as global scrollbar isn't part of the document
29437
+ var offsetWidth = target.current === document.body ? window.innerWidth : target.current.offsetWidth; // Get current computed padding right in pixels
29438
+
29439
+ var currentPaddingRight = parseInt(window.getComputedStyle(target.current).paddingRight, 10) || 0;
29440
+ var scrollbarWidth = offsetWidth - target.current.scrollWidth;
29441
+ target.current.style.paddingRight = scrollbarWidth + currentPaddingRight + "px";
29442
+ } // Lock the scroll
29443
+
29444
+
29445
+ target.current.style.overflow = "hidden";
29446
+ setIsLocked(true);
29447
+ }
29448
+ };
29449
+
29450
+ var unlock = function unlock() {
29451
+ if (target.current && originalStyle.current) {
29452
+ target.current.style.overflow = originalStyle.current.overflow; // Only reset padding right if we changed it
29453
+
29454
+ if (widthReflow) {
29455
+ target.current.style.paddingRight = originalStyle.current.paddingRight;
29456
+ }
29457
+ }
29458
+
29459
+ setIsLocked(false);
29460
+ };
29461
+
29462
+ useIsomorphicLayoutEffect$1(function () {
29463
+ if (IS_SERVER) return;
29464
+
29465
+ if (lockTarget) {
29466
+ target.current = typeof lockTarget === "string" ? document.querySelector(lockTarget) : lockTarget;
29467
+ }
29468
+
29469
+ if (!target.current) {
29470
+ target.current = document.body;
29471
+ }
29472
+
29473
+ if (autoLock) {
29474
+ lock();
29475
+ }
29476
+
29477
+ return function () {
29478
+ unlock();
29479
+ }; // eslint-disable-next-line react-hooks/exhaustive-deps
29480
+ }, [autoLock, lockTarget, widthReflow]);
29481
+ return {
29482
+ isLocked: isLocked,
29483
+ lock: lock,
29484
+ unlock: unlock
29485
+ };
29486
+ }
29487
+
29600
29488
  var borderStyle = "1px solid #e4e7eb";
29601
29489
  var BrandingWrap = styled.div.withConfig({
29602
29490
  displayName: "MobileMenu__BrandingWrap",
@@ -29827,6 +29715,7 @@ var BaseMobileMenu = function BaseMobileMenu(_a) {
29827
29715
  showNulogyLogo = _a.showNulogyLogo,
29828
29716
  props = __rest$3(_a, ["menuData", "closeMenu", "subtext", "themeColorObject", "showNulogyLogo"]);
29829
29717
 
29718
+ useScrollLock();
29830
29719
  return /*#__PURE__*/React__default.createElement(Nav, Object.assign({
29831
29720
  backgroundColor: themeColorObject && themeColorObject.background
29832
29721
  }, props), /*#__PURE__*/React__default.createElement(BrandingWrap, null, /*#__PURE__*/React__default.createElement(BrandingText, {
@@ -29983,13 +29872,13 @@ var SmallNavBarNoState = function SmallNavBarNoState(_a) {
29983
29872
  "aria-expanded": ariaExpanded
29984
29873
  }), /*#__PURE__*/React__default.createElement(MenuIcon, {
29985
29874
  isOpen: isOpen
29986
- }))))), isOpen && /*#__PURE__*/React__default.createElement(PreventBodyElementScrolling, null, /*#__PURE__*/React__default.createElement(MobileMenu, {
29875
+ }))))), isOpen && /*#__PURE__*/React__default.createElement(MobileMenu, {
29987
29876
  themeColorObject: themeColorObject,
29988
29877
  subtext: subtext,
29989
29878
  menuData: menuData,
29990
29879
  closeMenu: closeMenu,
29991
29880
  showNulogyLogo: showNulogyLogo
29992
- })));
29881
+ }));
29993
29882
  };
29994
29883
  /* eslint-enable react/destructuring-assignment */
29995
29884
 
@@ -45479,6 +45368,9 @@ function Sidebar(_a) {
45479
45368
  var sideBarRef = useRef(null);
45480
45369
  var contentRef = useRef(null);
45481
45370
  var selectedWidth = (_b = sidebarWidths[width]) !== null && _b !== void 0 ? _b : width;
45371
+ useScrollLock({
45372
+ autoLock: overlay && disableScroll && isOpen
45373
+ });
45482
45374
  useEffect(function () {
45483
45375
  var _a;
45484
45376
 
@@ -45609,9 +45501,7 @@ function Sidebar(_a) {
45609
45501
  width: "100%",
45610
45502
  p: p,
45611
45503
  pt: "x2"
45612
- }, footer), overlay && disableScroll && isOpen && /*#__PURE__*/React__default.createElement(PreventBodyElementScrolling, {
45613
- scrollRef: sideBarRef
45614
- })));
45504
+ }, footer)));
45615
45505
  }
45616
45506
 
45617
45507
  function LoadingAnimation(_ref) {
@@ -47669,7 +47559,7 @@ var Modal = function Modal(_ref4) {
47669
47559
  footerContent = _ref4.footerContent,
47670
47560
  closeAriaLabel = _ref4.closeAriaLabel,
47671
47561
  parentSelector = _ref4.parentSelector;
47672
- var modalHasHeader = onRequestClose || title;
47562
+ var modalHasHeader = Boolean(onRequestClose || title);
47673
47563
  var themeContext = useContext(ThemeContext$1);
47674
47564
  return /*#__PURE__*/React__default.createElement(StyledReactModal, {
47675
47565
  maxWidth: maxWidth,
@@ -47695,22 +47585,40 @@ var Modal = function Modal(_ref4) {
47695
47585
  appElement: appElement,
47696
47586
  ariaHideApp: ariaHideApp,
47697
47587
  parentSelector: parentSelector
47698
- }, /*#__PURE__*/React__default.createElement(PreventBodyElementScrolling, null, modalHasHeader && /*#__PURE__*/React__default.createElement(ModalHeader, {
47588
+ }, /*#__PURE__*/React__default.createElement(ModalWrapper, {
47589
+ closeAriaLabel: closeAriaLabel,
47590
+ modalHasHeader: modalHasHeader,
47591
+ title: title,
47592
+ onRequestClose: onRequestClose,
47593
+ footerContent: footerContent
47594
+ }, children));
47595
+ };
47596
+
47597
+ function ModalWrapper(_ref5) {
47598
+ var modalHasHeader = _ref5.modalHasHeader,
47599
+ title = _ref5.title,
47600
+ onRequestClose = _ref5.onRequestClose,
47601
+ closeAriaLabel = _ref5.closeAriaLabel,
47602
+ children = _ref5.children,
47603
+ footerContent = _ref5.footerContent;
47604
+ var theme = useTheme();
47605
+ useScrollLock();
47606
+ return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, modalHasHeader && /*#__PURE__*/React__default.createElement(ModalHeader, {
47699
47607
  hasCloseButton: Boolean(onRequestClose)
47700
47608
  }, title ? /*#__PURE__*/React__default.createElement(Heading2, {
47701
47609
  id: "modal-title",
47702
47610
  mb: "none"
47703
47611
  }, title) : /*#__PURE__*/React__default.createElement("div", {
47704
47612
  style: {
47705
- height: themeContext.space.x4
47613
+ height: theme.space.x4
47706
47614
  }
47707
47615
  }), onRequestClose && /*#__PURE__*/React__default.createElement(ModalCloseButton, {
47708
47616
  onClick: onRequestClose,
47709
47617
  "aria-label": closeAriaLabel
47710
47618
  })), /*#__PURE__*/React__default.createElement(ModalContent, {
47711
47619
  hasFooter: !!footerContent
47712
- }, children), footerContent && /*#__PURE__*/React__default.createElement(ModalFooter, null, footerContent)));
47713
- };
47620
+ }, children), footerContent && /*#__PURE__*/React__default.createElement(ModalFooter, null, footerContent));
47621
+ }
47714
47622
 
47715
47623
  Modal.setAppElement = ReactModal.setAppElement;
47716
47624