@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 +175 -267
- package/dist/main.module.js +175 -267
- package/dist/src/AsyncSelect/AsyncSelect.graphql.story.d.ts +6 -0
- package/dist/src/AsyncSelect/AsyncSelectComponents.d.ts +6 -2
- package/dist/src/Layout/Sidebar.d.ts +1 -1
- package/dist/src/utils/index.d.ts +0 -1
- package/dist/src/utils/testing/useUrlProps.d.ts +6 -0
- package/dist/src/utils/useScrollLock.d.ts +55 -0
- package/package.json +4 -2
- package/dist/src/utils/PreventBodyElementScrolling.d.ts +0 -8
- /package/dist/src/utils/{testHelpers → testing}/createMatchMedia.d.ts +0 -0
package/dist/main.js
CHANGED
|
@@ -355,12 +355,12 @@
|
|
|
355
355
|
}
|
|
356
356
|
|
|
357
357
|
var isBrowser$7 = typeof window !== "undefined";
|
|
358
|
-
var useIsomorphicLayoutEffect$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
12982
|
+
useIsomorphicLayoutEffect$4(function () {
|
|
13202
12983
|
if (popperInstanceRef.current) {
|
|
13203
12984
|
popperInstanceRef.current.setOptions(popperOptions);
|
|
13204
12985
|
}
|
|
13205
12986
|
}, [popperOptions]);
|
|
13206
|
-
useIsomorphicLayoutEffect$
|
|
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
|
|
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,
|
|
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,
|
|
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
|
-
|
|
19003
|
-
|
|
19004
|
-
|
|
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
|
|
24532
|
-
isFocused = _a.isFocused,
|
|
24316
|
+
var isFocused = _a.isFocused,
|
|
24533
24317
|
children = _a.children,
|
|
24534
|
-
props = __rest$3(_a, ["
|
|
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
|
-
|
|
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:
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
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(
|
|
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)
|
|
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(
|
|
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:
|
|
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
|
|