@leafygreen-ui/combobox 2.0.2 → 3.0.0
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/CHANGELOG.md +20 -0
- package/dist/Chip.d.ts.map +1 -1
- package/dist/Combobox.d.ts.map +1 -1
- package/dist/Combobox.styles.d.ts +7 -4
- package/dist/Combobox.styles.d.ts.map +1 -1
- package/dist/Combobox.types.d.ts +10 -1
- package/dist/Combobox.types.d.ts.map +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
- package/src/Chip.tsx +22 -5
- package/src/Combobox.spec.tsx +0 -1
- package/src/Combobox.styles.ts +22 -62
- package/src/Combobox.tsx +2 -8
- package/src/Combobox.types.ts +10 -1
- package/tsconfig.tsbuildinfo +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,25 @@
|
|
|
1
1
|
# @leafygreen-ui/combobox
|
|
2
2
|
|
|
3
|
+
## 3.0.0
|
|
4
|
+
|
|
5
|
+
### Major Changes
|
|
6
|
+
|
|
7
|
+
- 2ff9ac32: Removes `Overflow.ExpandX` option.
|
|
8
|
+
|
|
9
|
+
Overflow.ExpandX has always been an edge case, and is causing some issues with styling. Instead of increasing the complexity of the component to account for this edge case, we are removing this option.
|
|
10
|
+
|
|
11
|
+
In most cases the `x` direction will be more space-limited and not many folks will opt to use this option. And if they do use expand-x, it's inherently limited to the size of the container/window and we'll need to restrict the width regardless. Just providing scroll-x and expand-y overflow options will cover most use cases.
|
|
12
|
+
|
|
13
|
+
### Patch Changes
|
|
14
|
+
|
|
15
|
+
- 090bd806: Fixes broken button styles in Combobox Chip.
|
|
16
|
+
Reduces inline padding when `overflow === 'scroll-x'`.
|
|
17
|
+
Flags `Overflow.ExpandX` as deprecated. Will be removed in the next major release.
|
|
18
|
+
- Updated dependencies [19a62173]
|
|
19
|
+
- Updated dependencies [30e038a3]
|
|
20
|
+
- @leafygreen-ui/checkbox@10.0.1
|
|
21
|
+
- @leafygreen-ui/palette@3.4.1
|
|
22
|
+
|
|
3
23
|
## 2.0.2
|
|
4
24
|
|
|
5
25
|
### Patch Changes
|
package/dist/Chip.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Chip.d.ts","sourceRoot":"","sources":["../src/Chip.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiD,MAAM,OAAO,CAAC;AAOtE,OAAO,EAAE,SAAS,EAA+B,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"Chip.d.ts","sourceRoot":"","sources":["../src/Chip.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiD,MAAM,OAAO,CAAC;AAOtE,OAAO,EAAE,SAAS,EAA+B,MAAM,kBAAkB,CAAC;AAsI1E,eAAO,MAAM,IAAI,mFA0IhB,CAAC"}
|
package/dist/Combobox.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Combobox.d.ts","sourceRoot":"","sources":["../src/Combobox.tsx"],"names":[],"mappings":";AAyBA,OAAO,EACL,aAAa,EAQd,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"Combobox.d.ts","sourceRoot":"","sources":["../src/Combobox.tsx"],"names":[],"mappings":";AAyBA,OAAO,EACL,aAAa,EAQd,MAAM,kBAAkB,CAAC;AAkC1B;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAC,CAAC,SAAS,OAAO,EAAE,EAClD,QAAQ,EACR,KAAK,EACL,WAAW,EACX,WAAsB,EACtB,YAAY,EAAE,SAAS,EACvB,QAAgB,EAChB,IAA2B,EAC3B,QAAgB,EAChB,KAAc,EACd,YAAY,EACZ,WAAqB,EACrB,kBAAuC,EACvC,kBAA6C,EAC7C,oBAA2C,EAC3C,eAAe,EACf,QAAQ,EACR,SAAgB,EAChB,OAAO,EACP,QAAqB,EACrB,WAAwB,EACxB,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,sBAAsB,EACtB,kBAAuB,EACvB,SAAS,EACT,SAAgB,EAChB,eAAe,EACf,eAAe,EACf,eAAe,EACf,aAAa,EACb,GAAG,IAAI,EACR,EAAE,aAAa,CAAC,CAAC,CAAC,eA4tClB;AACD;;;GAGG"}
|
|
@@ -10,6 +10,10 @@ export declare const chipWrapperPaddingY: {
|
|
|
10
10
|
readonly default: 2;
|
|
11
11
|
readonly large: 4;
|
|
12
12
|
};
|
|
13
|
+
/**
|
|
14
|
+
* Height of the input element (in px)
|
|
15
|
+
*/
|
|
16
|
+
export declare const inputHeight: Record<Size, number>;
|
|
13
17
|
/**
|
|
14
18
|
* Size of combobox x & y padding (in px)
|
|
15
19
|
*/
|
|
@@ -20,7 +24,7 @@ export declare const comboboxPadding: Record<Size, {
|
|
|
20
24
|
/** Width of the dropdown caret icon (in px) */
|
|
21
25
|
export declare const caretIconSize: 16;
|
|
22
26
|
export declare const chipClassName: string;
|
|
23
|
-
export declare const comboboxParentStyle: (size: Size
|
|
27
|
+
export declare const comboboxParentStyle: (size: Size) => string;
|
|
24
28
|
export declare const baseComboboxStyles: string;
|
|
25
29
|
export declare const comboboxThemeStyles: Record<Theme, string>;
|
|
26
30
|
export declare const comboboxSizeStyles: (size: Size) => string;
|
|
@@ -30,14 +34,13 @@ export declare const comboboxFocusStyle: Record<Theme, string>;
|
|
|
30
34
|
export declare const inputWrapperStyle: ({ overflow, size, }: {
|
|
31
35
|
overflow: Overflow;
|
|
32
36
|
size: Size;
|
|
33
|
-
}) => string;
|
|
37
|
+
}) => string | undefined;
|
|
34
38
|
export declare const baseInputElementStyle: string;
|
|
35
39
|
export declare const inputElementThemeStyle: Record<Theme, string>;
|
|
36
40
|
export declare const inputElementSizeStyle: Record<Size, string>;
|
|
37
|
-
export declare const inputElementTransitionStyles: (isOpen: boolean
|
|
41
|
+
export declare const inputElementTransitionStyles: (isOpen: boolean) => string;
|
|
38
42
|
/** Should only be applied to a multiselect */
|
|
39
43
|
export declare const multiselectInputElementStyle: (size: Size, inputValue?: string | undefined) => string;
|
|
40
|
-
export declare const multiselectInputElementPadding: (selection: string | Array<string> | null) => string;
|
|
41
44
|
export declare const clearButtonStyle: string;
|
|
42
45
|
export declare const endIconStyle: (size: Size) => string;
|
|
43
46
|
export declare const errorMessageThemeStyle: Record<Theme, string>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Combobox.styles.d.ts","sourceRoot":"","sources":["../src/Combobox.styles.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Combobox.styles.d.ts","sourceRoot":"","sources":["../src/Combobox.styles.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,YAAY,IAAI,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzE;;GAEG;AACH,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAG7C,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,mBAAmB;;;CAGtB,CAAC;AAEX;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAK5C,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,IAAI,EAAE;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CASlE,CAAC;AAEF,+CAA+C;AAC/C,eAAO,MAAM,aAAa,IAAa,CAAC;AAexC,eAAO,MAAM,aAAa,QAAyC,CAAC;AAEpE,eAAO,MAAM,mBAAmB,SAAU,IAAI,KAAG,MAMhD,CAAC;AAEF,eAAO,MAAM,kBAAkB,QAU9B,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAmBrD,CAAC;AAEF,eAAO,MAAM,kBAAkB,SAAU,IAAI,WAE5C,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAaxD,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAOrD,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAepD,CAAC;AAEF,eAAO,MAAM,iBAAiB;cAIlB,QAAQ;UACZ,IAAI;wBAgDX,CAAC;AAEF,eAAO,MAAM,qBAAqB,QAkBjC,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAWxD,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAoBtD,CAAC;AAEF,eAAO,MAAM,4BAA4B,WAAY,OAAO,WAM3D,CAAC;AAGF,8CAA8C;AAC9C,eAAO,MAAM,4BAA4B,SACjC,IAAI,4CAUX,CAAC;AAEF,eAAO,MAAM,gBAAgB,QAG5B,CAAC;AAEF,eAAO,MAAM,YAAY,SAAU,IAAI,WAItC,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAOxD,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAWtD,CAAC;AACF,eAAO,MAAM,8BAA8B,QAE1C,CAAC"}
|
package/dist/Combobox.types.d.ts
CHANGED
|
@@ -34,9 +34,18 @@ export declare const TrunctationLocation: {
|
|
|
34
34
|
};
|
|
35
35
|
export declare type TrunctationLocation = typeof TrunctationLocation[keyof typeof TrunctationLocation];
|
|
36
36
|
export declare const Overflow: {
|
|
37
|
+
/**
|
|
38
|
+
* Combobox will be set to a fixed width, and will expand its height based on the number of Chips selected
|
|
39
|
+
*/
|
|
37
40
|
readonly expandY: "expand-y";
|
|
38
|
-
|
|
41
|
+
/**
|
|
42
|
+
* Combobox will be set to a fixed height and width (default 100% of container). Chips will be scrollable left-right
|
|
43
|
+
*/
|
|
39
44
|
readonly scrollX: "scroll-x";
|
|
45
|
+
/**
|
|
46
|
+
* @deprecated
|
|
47
|
+
*/
|
|
48
|
+
readonly expandX: "expand-x";
|
|
40
49
|
};
|
|
41
50
|
export declare type Overflow = typeof Overflow[keyof typeof Overflow];
|
|
42
51
|
export declare const State: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Combobox.types.d.ts","sourceRoot":"","sources":["../src/Combobox.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,eAAO,MAAM,KAAK;;;CAGR,CAAC;AAEX,oBAAY,KAAK,GAAG,OAAO,KAAK,CAAC,MAAM,OAAO,KAAK,CAAC,CAAC;AAErD;;GAEG;AAEH,eAAO,MAAM,eAAe;;;;;;;;CAQlB,CAAC;AACX,oBAAY,eAAe,GACzB,OAAO,eAAe,CAAC,MAAM,OAAO,eAAe,CAAC,CAAC;AAEvD;;GAEG;AAEH,eAAO,MAAM,YAAY;;;CAMf,CAAC;AACX,oBAAY,YAAY,GAAG,OAAO,YAAY,CAAC,MAAM,OAAO,YAAY,CAAC,CAAC;AAE1E,eAAO,MAAM,mBAAmB;;;;;CAKtB,CAAC;AACX,oBAAY,mBAAmB,GAC7B,OAAO,mBAAmB,CAAC,MAAM,OAAO,mBAAmB,CAAC,CAAC;AAE/D,eAAO,MAAM,QAAQ
|
|
1
|
+
{"version":3,"file":"Combobox.types.d.ts","sourceRoot":"","sources":["../src/Combobox.types.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import n from"lodash/clone";import e from"lodash/isArray";import r from"lodash/isEqual";import o from"lodash/isNull";import t from"lodash/isString";import i from"lodash/isUndefined";import a,{createContext as l,useContext as c,useCallback as s,useMemo as u,useRef as d,useEffect as p,useState as f}from"react";import{Label as h,Description as g}from"@leafygreen-ui/typography";import{useIdAllocator as b,useForwardedRef as m,useAvailableSpace as v,useDynamicRefs as y,usePrevious as x,useEventListener as w}from"@leafygreen-ui/hooks";import k,{isComponentGlyph as C}from"@leafygreen-ui/icon";import N from"@leafygreen-ui/icon-button";import{css as O,cx as S,keyframes as z}from"@leafygreen-ui/emotion";import{palette as M}from"@leafygreen-ui/palette";import{isComponentType as E,createUniqueClassName as j,keyMap as I,consoleOnce as D}from"@leafygreen-ui/lib";import P from"lodash/escapeRegExp";import{jsx as L}from"@emotion/react";import A from"lodash/kebabCase";import F from"@leafygreen-ui/checkbox";import{typeScales as T,spacing as H,fontFamilies as R,hoverRing as W,focusRing as G}from"@leafygreen-ui/tokens";import{transparentize as K}from"polished";import U from"@leafygreen-ui/inline-definition";import V from"@leafygreen-ui/popover";function B(n,e){var r=Object.keys(n);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(n);e&&(o=o.filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable}))),r.push.apply(r,o)}return r}function X(n){return X="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(n){return typeof n}:function(n){return n&&"function"==typeof Symbol&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},X(n)}function Z(n,e,r){return e in n?Object.defineProperty(n,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):n[e]=r,n}function q(){return q=Object.assign||function(n){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var o in r)Object.prototype.hasOwnProperty.call(r,o)&&(n[o]=r[o])}return n},q.apply(this,arguments)}function Y(n,e){if(null==n)return{};var r,o,t=function(n,e){if(null==n)return{};var r,o,t={},i=Object.keys(n);for(o=0;o<i.length;o++)r=i[o],e.indexOf(r)>=0||(t[r]=n[r]);return t}(n,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(n);for(o=0;o<i.length;o++)r=i[o],e.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(n,r)&&(t[r]=n[r])}return t}function $(n,e){return e||(e=n.slice(0)),Object.freeze(Object.defineProperties(n,{raw:{value:Object.freeze(e)}}))}function J(n,e){return function(n){if(Array.isArray(n))return n}(n)||function(n,e){var r=null==n?null:"undefined"!=typeof Symbol&&n[Symbol.iterator]||n["@@iterator"];if(null==r)return;var o,t,i=[],a=!0,l=!1;try{for(r=r.call(n);!(a=(o=r.next()).done)&&(i.push(o.value),!e||i.length!==e);a=!0);}catch(n){l=!0,t=n}finally{try{a||null==r.return||r.return()}finally{if(l)throw t}}return i}(n,e)||_(n,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Q(n){return function(n){if(Array.isArray(n))return nn(n)}(n)||function(n){if("undefined"!=typeof Symbol&&null!=n[Symbol.iterator]||null!=n["@@iterator"])return Array.from(n)}(n)||_(n)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _(n,e){if(n){if("string"==typeof n)return nn(n,e);var r=Object.prototype.toString.call(n).slice(8,-1);return"Object"===r&&n.constructor&&(r=n.constructor.name),"Map"===r||"Set"===r?Array.from(n):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?nn(n,e):void 0}}function nn(n,e){(null==e||e>n.length)&&(e=n.length);for(var r=0,o=new Array(e);r<e;r++)o[r]=n[r];return o}var en="dark",rn="light",on="Input",tn="ClearButton",an="FirstChip",ln="LastChip",cn="MiddleChip",sn="Combobox",un="Menu",dn="default",pn="large",fn="expand-y",hn="expand-x",gn="scroll-x",bn="error";var mn,vn,yn,xn,wn,kn,Cn,Nn,On,Sn,zn,Mn,En,jn,In,Dn,Pn,Ln,An,Fn,Tn,Hn,Rn,Wn,Gn,Kn,Un,Vn,Bn,Xn,Zn,qn,Yn,$n=function(n,e,r){if(e&&r){var o=P(e),t=new RegExp(o,"gi"),i=n.matchAll(t);if(i){for(var l=n.split(""),c=0,s=Array.from(i);c<s.length;c++){var u,d=s[c],p=null!==(u=d.index)&&void 0!==u?u:-1,f=d[0],h=f.length,g=p+f+h,b=new Array(h).fill("");b[0]=a.createElement(r,{key:g},f),l.splice.apply(l,[p,h].concat(Q(b)))}return L(a.Fragment,null,l)}return L(a.Fragment,null,n)}return L(a.Fragment,null,n)},Jn=function(n){var e,r=n.value,o=n.displayName;return{value:null!=r?r:A(o),displayName:null!==(e=null!=o?o:r)&&void 0!==e?e:""}},Qn=function(n,e){if(n)return e.find((function(e){return e.value===n}))},_n=function(n,e){var r,o;return n?null!==(r=null===(o=Qn(n,e))||void 0===o?void 0:o.displayName)&&void 0!==r?r:n:""},ne=function n(e){return a.Children.toArray(e).reduce((function(e,r){if(E(r,"ComboboxOption")){var o=Jn(r.props),t=o.value,i=o.displayName,a=r.props,l=a.glyph,c=a.disabled;return[].concat(Q(e),[{value:t,displayName:i,isDisabled:!!c,hasGlyph:!!l}])}if(E(r,"ComboboxGroup")){var s=r.props.children;if(s)return[].concat(Q(e),Q(n(s)))}}),[])},ee=l({multiselect:!1,darkMode:!1,size:dn,withIcons:!1,disabled:!1,isOpen:!1,state:"none",searchState:"unset"}),re=function(n){return n?en:rn},oe=(Z(yn={},rn,O(mn||(mn=$(["\n padding-top: 8px;\n "])))),Z(yn,en,O(vn||(vn=$(["\n padding-top: 8px;\n "])))),yn),te=O(xn||(xn=$(["\n cursor: default;\n width: 100%;\n padding: 0 12px 2px;\n outline: none;\n overflow-wrap: anywhere;\n font-size: 12px;\n line-height: 16px;\n font-weight: bold;\n text-transform: uppercase;\n letter-spacing: 0.4px;\n"]))),ie=(Z(Cn={},rn,O(wn||(wn=$(["\n color: ",";\n "])),M.gray.dark1)),Z(Cn,en,O(kn||(kn=$(["\n color: ",";\n "])),M.gray.light1)),Cn);function ae(n){var e=n.label,r=n.className,o=n.children,t=c(ee).darkMode,i=re(t),l=b({prefix:"combobox-group"});return a.Children.count(o)>0?L("div",{className:S(oe[i],r)},L("div",{className:S(te,ie[i]),id:l},e),L("div",{role:"group","aria-labelledby":l},o)):L(a.Fragment,null)}function le(n){throw Error("`ComboboxGroup` must be a child of a `Combobox` instance")}le.displayName="ComboboxGroup";var ce=(Z(Nn={},dn,{x:12,y:8}),Z(Nn,pn,{x:12,y:8}),Nn),se=(Z(On={},dn,T.body1.lineHeight+2*ce[dn].y),Z(On,pn,T.body2.lineHeight+2*ce[pn].y),On),ue=function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:384;return O(Sn||(Sn=$(["\n width: ","px;\n overflow: hidden;\n border-radius: 12px;\n border: 1px solid;\n"])),n)},de=(Z(En={},rn,O(zn||(zn=$(["\n box-shadow: 0px 4px 7px ",";\n border-color: ",";\n "])),K(.85,M.black),M.gray.light2)),Z(En,en,O(Mn||(Mn=$(["\n box-shadow: 0px 4px 7px ",";\n border-color: ",";\n "])),K(.85,M.black),M.gray.dark3)),En),pe=O(jn||(jn=$(["\n position: relative;\n width: 100%;\n margin: 0;\n padding: ","px 0;\n font-family: ",";\n border-radius: inherit;\n overflow-y: auto;\n scroll-behavior: smooth;\n"])),H[2],R.default),fe=(Z(Pn={},rn,O(In||(In=$(["\n color: ",";\n background-color: ",";\n "])),M.black,M.white)),Z(Pn,en,O(Dn||(Dn=$(["\n color: ",";\n background-color: ",";\n "])),M.gray.light1,M.gray.dark3)),Pn);Z(Fn={},dn,O(Ln||(Ln=$(["\n min-height: ","px;\n "])),se[dn])),Z(Fn,pn,O(An||(An=$(["\n min-height: ","px;\n "])),se[pn]));var he=O(Tn||(Tn=$(["\n position: relative;\n margin: 0;\n padding: 0;\n"]))),ge=O(Hn||(Hn=$(["\n font-family: inherit;\n display: inline-flex;\n align-items: center;\n gap: 8px;\n"]))),be=(Z(Gn={},rn,O(Rn||(Rn=$(["\n color: ",";\n "])),M.gray.dark3)),Z(Gn,en,O(Wn||(Wn=$(["\n color: ",";\n "])),M.gray.light3)),Gn),me=(Z(Vn={},dn,O(Kn||(Kn=$(["\n font-size: ","px;\n line-height: ","px;\n padding: ","px\n ","px;\n "])),T.body1.fontSize,T.body1.lineHeight,ce[dn].y,ce[dn].x)),Z(Vn,pn,O(Un||(Un=$(["\n font-size: ","px;\n line-height: ","px;\n padding: ","px\n ","px;\n "])),T.body2.fontSize,T.body2.lineHeight,ce[pn].y,ce[pn].x)),Vn);Z(Zn={},dn,O(Bn||(Bn=$(["\n height: ","px;\n width: ","px;\n "])),T.body1.fontSize,T.body1.fontSize)),Z(Zn,pn,O(Xn||(Xn=$(["\n height: ","px;\n width: ","px;\n "])),T.body2.fontSize,T.body2.fontSize));var ve,ye,xe,we,ke,Ce,Ne,Oe,Se,ze,Me,Ee,je,Ie,De,Pe,Le,Ae,Fe,Te,He,Re,We,Ge,Ke,Ue,Ve,Be,Xe,Ze,qe,Ye,$e,Je,Qe,_e,nr,er,rr,or,tr,ir,ar,lr,cr,sr,ur,dr,pr,fr,hr,gr,br,mr,vr,yr,xr,wr,kr,Cr,Nr,Or,Sr,zr,Mr,Er,jr=z(qn||(qn=$(["\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n"]))),Ir=O(Yn||(Yn=$(["\n animation: "," 1.5s linear infinite;\n"])),jr),Dr=O(ve||(ve=$(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: space-between;\n list-style: none;\n color: inherit;\n cursor: pointer;\n overflow: hidden;\n font-family: ",";\n\n // Left wedge\n &:before {\n content: '';\n position: absolute;\n left: 0;\n width: 4px;\n height: calc(100% - 14px);\n background-color: rgba(255, 255, 255, 0);\n border-radius: 0 6px 6px 0;\n transform: scale3d(0, 0.3, 0);\n transition: 200ms ease-in-out;\n transition-property: transform, background-color;\n }\n"])),R.default),Pr=(Z(we={},rn,O(ye||(ye=$(["\n &:hover {\n outline: none;\n background-color: ",";\n }\n "])),M.gray.light2)),Z(we,en,O(xe||(xe=$(["\n &:hover {\n outline: none;\n background-color: ",";\n }\n "])),M.gray.dark4)),we),Lr=(Z(Ne={},dn,O(ke||(ke=$(["\n font-size: ","px;\n line-height: ","px;\n min-height: ","px;\n padding: ","px\n ","px;\n gap: ","px;\n\n &:before {\n max-height: ","px;\n }\n "])),T.body1.fontSize,T.body1.lineHeight,se[dn],ce[dn].y,ce[dn].x,H[1],se[dn])),Z(Ne,pn,O(Ce||(Ce=$(["\n font-size: ","px;\n line-height: ","px;\n min-height: ","px;\n padding: ","px\n ","px;\n gap: ","px;\n\n &:before {\n max-height: ","px;\n }\n "])),T.body2.fontSize,T.body2.lineHeight,se[pn],ce[pn].y,ce[pn].x,H[2],se[pn])),Ne),Ar=O(Oe||(Oe=$(["\n outline: none;\n\n &:before {\n transform: scaleY(1);\n }\n"]))),Fr=(Z(Me={},rn,O(Se||(Se=$(["\n ",";\n background-color: ",";\n\n &:before {\n background-color: ",";\n }\n "])),Ar,M.blue.light3,M.blue.base)),Z(Me,en,O(ze||(ze=$(["\n ",";\n background-color: ",";\n\n &:before {\n background-color: ",";\n }\n "])),Ar,M.blue.dark3,M.blue.light1)),Me),Tr=O(Ee||(Ee=$(["\n cursor: not-allowed;\n\n &:hover {\n background-color: inherit;\n }\n\n &:before {\n content: unset;\n }\n"]))),Hr=(Z(De={},rn,O(je||(je=$(["\n ",";\n color: ",";\n "])),Tr,M.gray.light1)),Z(De,en,O(Ie||(Ie=$(["\n ",";\n color: ",";\n "])),Tr,M.gray.dark1)),De),Rr=(Z(Ae={},dn,O(Pe||(Pe=$(["\n min-width: ","px;\n "])),H[3])),Z(Ae,pn,O(Le||(Le=$(["\n min-width: ","px;\n "])),H[4])),Ae),Wr=O(Fe||(Fe=$(["\n display: inline-flex;\n gap: 8px;\n justify-content: start;\n align-items: inherit;\n overflow-wrap: anywhere;\n"]))),Gr=O(Te||(Te=$(["\n pointer-events: none;\n"]))),Kr=function(n){return O(He||(He=$(["\n font-weight: ",";\n"])),n?"bold":"normal")},Ur=a.forwardRef((function(n,e){var r,o=n.displayName,t=n.glyph,i=n.isSelected,l=n.isFocused,d=n.disabled,p=n.setSelected,f=n.className,h=c(ee),g=h.multiselect,v=h.darkMode,y=h.withIcons,x=h.inputValue,w=h.size,N=re(v),z=b({prefix:"combobox-option-text"}),j=m(e,null),I=s((function(n){n.stopPropagation(),d||n.target!==j.current&&"INPUT"!==n.target.tagName||p()}),[d,j,p]),D=u((function(){if(t){if(C(t)||E(t,"Icon"))return t;console.error("`ComboboxOption` instance did not render icon because it is not a known glyph element.",t)}}),[t]),P=u((function(){if(g){var n=L(F,{"aria-labelledby":z,checked:i,tabIndex:-1,disabled:d,darkMode:v,className:O(Re||(Re=$(["\n // TODO: Remove when this is resolved:\n // https://jira.mongodb.org/browse/PD-2171\n & > label > div {\n margin-top: 0;\n }\n "])))});return L(a.Fragment,null,L("span",{className:S(Wr,Gr)},y?D:n,L("span",{id:z,className:Kr(i)},$n(o,x,"strong"))),y&&n)}return L(a.Fragment,null,L("span",{className:S(Wr,Gr)},D,L("span",{className:Kr(i)},$n(o,x,"strong"))),i&&L(k,{glyph:"Checkmark",className:Rr[w],color:v?M.blue.light1:M.blue.base}))}),[g,D,i,o,x,w,v,z,d,y]);return L("li",{ref:j,role:"option","aria-selected":l,"aria-label":o,tabIndex:-1,className:S(Dr,Lr[w],Pr[N],(r={},Z(r,Fr[N],l),Z(r,Hr[N],d),r),f),onClick:I,onKeyDown:I},P)}));function Vr(n){throw Error("`ComboboxOption` must be a child of a `Combobox` instance")}Ur.displayName="ComboboxOption",Vr.displayName="ComboboxOption";var Br,Xr,Zr,qr,Yr,$r,Jr,Qr,_r,no,eo,ro,oo,to,io,ao,lo,co,so,uo,po,fo=(Z(We={},dn,T.body1.fontSize),Z(We,pn,T.body2.fontSize),We),ho=(Z(Ge={},dn,2),Z(Ge,pn,4),Ge),go=(Z(Ke={},dn,T.body1.lineHeight+2*ho[dn]),Z(Ke,pn,T.body2.lineHeight+2*ho[pn]),Ke),bo=(Z(Ue={},dn,{y:(36-go[dn]-2)/2,x:H[2]-1}),Z(Ue,pn,{y:(48-go[pn]-2)/2,x:H[2]-1}),Ue),mo=H[3],vo=(Z(Ve={},dn,fo[dn]+2*bo[dn].x+mo+2),Z(Ve,pn,fo[pn]+2*bo[pn].x+mo+2),Ve),yo=j("combobox-chip"),xo=function(n,e){return S(O(Be||(Be=$(["\n font-family: ",";\n width: 100%;\n min-width: ","px;\n "])),R.default,vo[n]),Z({},O(Xe||(Xe=$(["\n width: unset;\n "]))),e===hn))},wo=O(Ze||(Ze=$(["\n display: flex;\n flex-wrap: nowrap;\n align-items: center;\n cursor: text;\n transition: 150ms ease-in-out;\n transition-property: background-color, box-shadow, border-color;\n border: 1px solid;\n width: inherit;\n border-radius: 6px;\n"]))),ko=(Z($e={},rn,O(qe||(qe=$(["\n color: ",";\n background-color: ",";\n border-color: ",";\n\n &:hover {\n box-shadow: ",";\n }\n "])),M.gray.dark3,M.white,M.gray.base,W[rn].gray)),Z($e,en,O(Ye||(Ye=$(["\n color: ",";\n background-color: ",";\n border-color: ",";\n\n &:hover {\n box-shadow: ",";\n }\n "])),M.gray.light2,M.gray.dark4,M.gray.base,W[en].gray)),$e),Co=function(n){return O(Je||(Je=$(["\n padding: ","px ","px;\n"])),bo[n].y,bo[n].x)},No=(Z(nr={},rn,O(Qe||(Qe=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n border-color: ",";\n "])),M.gray.dark1,M.gray.light2,M.gray.light1)),Z(nr,en,O(_e||(_e=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n border-color: ",";\n "])),M.gray.dark1,M.gray.dark3,M.gray.dark2)),nr),Oo=(Z(or={},rn,O(er||(er=$(["\n border-color: ",";\n "])),M.red.base)),Z(or,en,O(rr||(rr=$(["\n border-color: ",";\n "])),M.red.light1)),or),So=(Z(ar={},rn,O(tr||(tr=$(["\n &:focus-within {\n border-color: transparent;\n background-color: ",";\n box-shadow: ",";\n }\n "])),M.white,G[rn].input)),Z(ar,en,O(ir||(ir=$(["\n &:focus-within {\n border-color: transparent;\n background-color: ",";\n box-shadow: ",";\n }\n "])),M.gray.dark4,G[en].input)),ar),zo=function(n){var e=n.overflow,r=n.size,o=O(lr||(lr=$(["\n flex-grow: 1;\n width: inherit;\n "])));switch(e){case gn:return O(cr||(cr=$(["\n ","\n display: block;\n height: ","px;\n padding-left: ","px;\n white-space: nowrap;\n overflow-x: scroll;\n scroll-behavior: smooth;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n & > ."," {\n margin-inline: 2px;\n\n &:first-child {\n margin-inline-start: 0;\n }\n\n &:last-child {\n margin-inline-end: 0;\n }\n }\n "])),o,go[r],bo[r].x,yo);case hn:return O(sr||(sr=$(["\n ","\n display: flex;\n gap: 4px;\n flex-wrap: nowrap;\n white-space: nowrap;\n height: ","px;\n "])),o,go[r]);case fn:return O(ur||(ur=$(["\n ","\n display: flex;\n flex-wrap: wrap;\n gap: 4px;\n overflow-x: visible;\n min-height: ","px;\n "])),o,go[r])}},Mo=O(dr||(dr=$(["\n font-family: ",";\n width: 100%;\n border: none;\n cursor: inherit;\n background-color: inherit;\n color: inherit;\n box-sizing: content-box;\n padding: 0;\n margin: 0;\n text-overflow: ellipsis;\n\n &:placeholder-shown {\n min-width: 100%;\n }\n &:focus {\n outline: none;\n }\n"])),R.default),Eo=(Z(hr={},rn,O(pr||(pr=$(["\n &::placeholder {\n color: ",";\n }\n "])),M.gray.dark1)),Z(hr,en,O(fr||(fr=$(["\n &::placeholder {\n color: ",";\n }\n "])),M.gray.light1)),hr),jo=(Z(mr={},dn,O(gr||(gr=$(["\n height: ","px;\n font-size: ","px;\n line-height: ","px;\n min-width: ","px;\n padding-left: 4px;\n "])),go[dn],T.body1.fontSize,T.body1.lineHeight,fo[dn])),Z(mr,pn,O(br||(br=$(["\n height: ","px;\n font-size: ","px;\n line-height: ","px;\n min-width: ","px;\n padding-left: 6px;\n "])),go[pn],T.body2.fontSize,T.body2.lineHeight,fo[pn])),mr),Io=function(n,e){return S(Z({},O(vr||(vr=$(["\n /*\n * Immediate transition in, slow transition out. \n * '-in' transition is handled by `scroll-behavior` \n */\n transition: width ease-in-out ",";\n "],["\n /*\n * Immediate transition in, slow transition out. \n * '-in' transition is handled by \\`scroll-behavior\\` \n */\n transition: width ease-in-out ",";\n "])),n?"0s":"100ms"),e!==hn))},Do=function(n,e){var r,o=null!==(r=null==e?void 0:e.length)&&void 0!==r?r:0;return O(yr||(yr=$(["\n max-width: 100%;\n width: ","px;\n // TODO: This doesn't quite work. Fix this\n max-width: calc(100% - ","px);\n "])),o*fo[n],2*mo)},Po=function(n){return"object"===X(n)&&!o(n)&&n.length>0?O(xr||(xr=$(["\n padding-left: 0px;\n "]))):""},Lo=O(wr||(wr=$(["\n // Add a negative margin so the button takes up the same space as the regular icons\n margin-block: calc(","px - 100%);\n"])),mo/2),Ao=function(n){return O(kr||(kr=$(["\n height: ","px;\n width: ","px;\n margin-inline-end: calc(","px / 2);\n"])),mo,mo,bo[n].x)},Fo=(Z(Or={},rn,O(Cr||(Cr=$(["\n color: ",";\n "])),M.red.base)),Z(Or,en,O(Nr||(Nr=$(["\n color: ",";\n "])),M.red.light1)),Or),To=(Z(Mr={},dn,O(Sr||(Sr=$(["\n font-size: ","px;\n line-height: ","px;\n padding-top: ","px;\n "])),T.body1.fontSize,T.body1.lineHeight,bo[dn].y)),Z(Mr,pn,O(zr||(zr=$(["\n font-size: ","px;\n line-height: ","px;\n padding-top: ","px;\n "])),T.body2.fontSize,T.body2.lineHeight,bo[pn].y)),Mr),Ho=O(Er||(Er=$(["\n margin-bottom: 2px;\n"]))),Ro=O(Br||(Br=$(["\n display: inline-flex;\n align-items: center;\n overflow: hidden;\n white-space: nowrap;\n box-sizing: border-box;\n"]))),Wo=(Z(qr={},dn,O(Xr||(Xr=$(["\n font-size: ","px;\n line-height: ","px;\n border-radius: 4px;\n "])),T.body1.fontSize,T.body1.lineHeight)),Z(qr,pn,O(Zr||(Zr=$(["\n font-size: ","px;\n line-height: ","px;\n border-radius: 4px;\n "])),T.body2.fontSize,T.body2.lineHeight)),qr),Go=(Z(Jr={},rn,O(Yr||(Yr=$(["\n color: ",";\n background-color: ",";\n\n // TODO: - refine these styles with Design\n &:focus-within {\n background-color: ",";\n }\n "])),M.black,M.gray.light2,M.blue.light2)),Z(Jr,en,O($r||($r=$(["\n color: ",";\n background-color: ",";\n\n &:focus-within {\n background-color: ",";\n }\n "])),M.gray.light2,M.gray.dark2,M.blue.dark2)),Jr),Ko=(Z(no={},rn,O(Qr||(Qr=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n "])),M.gray.base,M.gray.light3)),Z(no,en,O(_r||(_r=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n box-shadow: inset 0 0 1px 1px ","; ;\n "])),M.gray.dark2,M.gray.dark4,M.gray.dark2)),no),Uo=(Z(oo={},dn,O(eo||(eo=$(["\n padding-inline: 6px;\n padding-block: ","px;\n "])),ho[dn])),Z(oo,pn,O(ro||(ro=$(["\n padding-inline: 10px;\n padding-block: ","px;\n "])),ho[pn])),oo),Vo=O(to||(to=$(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 100%;\n width: 100%;\n outline: none;\n border: none;\n background-color: transparent;\n cursor: pointer;\n transition: background-color 100ms ease-in-out;\n"]))),Bo=(Z(lo={},rn,O(io||(io=$(["\n color: ",";\n\n &:hover {\n color: ",";\n background-color: ",";\n }\n "])),M.gray.dark2,M.black,M.gray.light1)),Z(lo,en,O(ao||(ao=$(["\n color: ",";\n\n &:hover {\n color: ",";\n background-color: ",";\n }\n "])),M.gray.light1,M.gray.light3,M.gray.dark1)),lo),Xo=(Z(uo={},rn,O(co||(co=$(["\n cursor: not-allowed;\n color: ",";\n &:hover {\n color: inherit;\n background-color: unset;\n }\n "])),M.gray.dark2)),Z(uo,en,O(so||(so=$(["\n cursor: not-allowed;\n color: ",";\n &:hover {\n color: inherit;\n background-color: unset;\n }\n "])),M.gray.dark2)),uo),Zo=a.forwardRef((function(n,e){var r=n.displayName,o=n.isFocused,t=n.onRemove,i=n.onFocus,a=c(ee),l=a.darkMode,s=a.size,f=a.disabled,h=a.chipTruncationLocation,g=void 0===h?"end":h,b=a.chipCharacterLimit,m=void 0===b?12:b,v=re(l),y=!!m&&!!g&&"none"!==g&&r.length>m,x=d(null),w=u((function(){if(y){var n=m-3;switch(g){case"start":return"…"+r.substring(r.length-n).trim();case"middle":return r.substring(0,n/2).trim()+"…"+r.substring(r.length-n/2).trim();case"end":return r.substring(0,n).trim()+"…";default:return r}}return!1}),[m,g,r,y]);p((function(){var n;o&&!f&&(null==x||null===(n=x.current)||void 0===n||n.focus())}),[f,e,o]);return L("span",{role:"option","aria-selected":o,"data-testid":"lg-combobox-chip",ref:e,className:S(yo,Ro,Go[v],Wo[s],Z({},Ko[v],f)),onClick:function(n){var e;null!==(e=x.current)&&void 0!==e&&e.contains(n.target)||i()},onKeyDown:function(n){f||n.keyCode!==I.Delete&&n.keyCode!==I.Backspace&&n.keyCode!==I.Enter&&n.keyCode!==I.Space||t()},tabIndex:-1},L("span",{className:S(Uo[s])},w?L(U,{darkMode:l,definition:r,align:"bottom"},w):r),L("button",{"aria-label":"Deselect ".concat(r),"aria-disabled":f,disabled:f,ref:x,className:S(Vo,Bo[v],Z({},Xo[v],f)),onClick:function(){f||t()}},L(k,{glyph:"X"})))}));Zo.displayName="Chip";var qo=["children","id","refEl","labelId","menuWidth","searchLoadingMessage","searchErrorMessage","searchEmptyMessage"],Yo=a.forwardRef((function(n,e){var r=n.children,o=n.id,t=n.refEl,a=n.labelId,l=n.menuWidth,s=n.searchLoadingMessage,d=n.searchErrorMessage,p=n.searchEmptyMessage,f=Y(n,qo),h=c(ee),g=h.disabled,b=h.darkMode,y=h.size,x=h.isOpen,w=h.searchState,C=m(e,null),N=re(b),z=v(t),E=i(z)?"unset":"".concat(Math.min(z,256),"px"),j=u((function(){var n=S(ge,be[N],me[y]);switch(w){case"loading":return L("span",{className:n},L(k,{glyph:"Refresh",color:b?M.blue.light1:M.blue.base,className:Ir}),s);case"error":return L("span",{className:n},L(k,{glyph:"Warning",color:b?M.red.light1:M.red.base}),d);default:return r&&"object"===X(r)&&"length"in r&&r.length>0?L("ul",{className:he},r):L("span",{className:n},p)}}),[N,y,w,b,s,d,r,p]);return L(V,q({active:x&&!g,spacing:4,align:"bottom",justify:"middle",refEl:t,adjustOnMutation:!0,className:S(ue(l),de[N])},f),L("div",{ref:C,id:o,role:"listbox","aria-labelledby":a,"aria-expanded":x,className:S(pe,fe[N],O(po||(po=$(["\n max-height: ",";\n "])),E)),onMouseDownCapture:function(n){return n.preventDefault()}},j))}));Yo.displayName="ComboboxMenu";var $o=["children","label","description","placeholder","aria-label","disabled","size","darkMode","state","errorMessage","searchState","searchEmptyMessage","searchErrorMessage","searchLoadingMessage","filteredOptions","onFilter","clearable","onClear","overflow","multiselect","initialValue","onChange","value","chipTruncationLocation","chipCharacterLimit","className","usePortal","portalClassName","portalContainer","scrollContainer","popoverZIndex"];function Jo(l){var c,m,v=l.children,C=l.label,O=l.description,z=l.placeholder,j=void 0===z?"Select":z,P=l["aria-label"],A=l.disabled,F=void 0!==A&&A,T=l.size,H=void 0===T?dn:T,R=l.darkMode,W=void 0!==R&&R,G=l.state,K=void 0===G?"none":G,U=l.errorMessage,V=l.searchState,$=void 0===V?"unset":V,Q=l.searchEmptyMessage,_=void 0===Q?"No results found":Q,nn=l.searchErrorMessage,en=void 0===nn?"Could not get results!":nn,rn=l.searchLoadingMessage,pn=void 0===rn?"Loading results...":rn,fn=l.filteredOptions,hn=l.onFilter,gn=l.clearable,mn=void 0===gn||gn,vn=l.onClear,yn=l.overflow,xn=void 0===yn?"expand-y":yn,wn=l.multiselect,kn=void 0!==wn&&wn,Cn=l.initialValue,Nn=l.onChange,On=l.value,Sn=l.chipTruncationLocation,zn=l.chipCharacterLimit,Mn=void 0===zn?12:zn,En=l.className,jn=l.usePortal,In=void 0===jn||jn,Dn=l.portalClassName,Pn=l.portalContainer,Ln=l.scrollContainer,An=l.popoverZIndex,Fn=Y(l,$o),Tn=re(W),Hn=y({prefix:"option"}),Rn=y({prefix:"chip"}),Wn=b({prefix:"combobox-input"}),Gn=b({prefix:"combobox-label"}),Kn=b({prefix:"combobox-menu"}),Un=d(null),Vn=d(null),Bn=d(null),Xn=d(null),Zn=d(null),qn=J(f(!1),2),Yn=qn[0],$n=qn[1],oe=x(Yn),te=J(f(null),2),ie=te[0],le=te[1],ce=J(f(null),2),se=ce[0],ue=ce[1],de=x(se),pe=J(f(""),2),fe=pe[0],he=pe[1],ge=x(fe),be=J(f(null),2),me=be[0],ve=be[1],ye=!o(se)&&(e(se)&&se.length>0||t(se)),xe=kn&&e(se)&&se.length>0?void 0:j,we=function(){return $n(!1)},ke=function(){return $n(!0)},Ce=u((function(){return ne(v)}),[v]),Ne=s((function(n){return!kn||"string"!=typeof n&&"number"!=typeof n?!kn&&e(n)&&D.error("Error in Combobox: multiselect is set to `false`, but recieved an Array value"):D.error("Error in Combobox: multiselect is set to `true`, but recieved a ".concat(X(n),' value: "').concat(n,'"')),kn&&e(n)}),[kn]),Oe=s((function(n){!F&&Xn&&Xn.current&&(Xn.current.focus(),i(n)||Xn.current.setSelectionRange(n,n))}),[F]),Se=s((function(e){if(Ne(se)){var r=n(se);o(e)?r.length=0:se.includes(e)?r.splice(r.indexOf(e),1):(r.push(e),he("")),ue(r),null==Nn||Nn(r)}else{var t=e;ue(t),null==Nn||Nn(t)}}),[Ne,Nn,se]),ze=s((function(n){return Ne(se)?se.includes(n):n===se}),[Ne,se]),Me=s((function(n){var e,r,o,t,i=(r=Ce,(e=n)?null!==(o=null===(t=r.find((function(n){return n.displayName===e})))||void 0===t?void 0:t.value)&&void 0!==o?o:e:"");return ze(i)}),[Ce,ze]),Ee=s((function(n){var e="string"==typeof n?n:n.value;return fn&&fn.length>0?fn.includes(e):!!Me(fe)||("string"==typeof n?_n(e,Ce):n.displayName).toLowerCase().includes(fe.toLowerCase())}),[fn,Me,fe,Ce]),je=u((function(){return Ce.filter(Ee)}),[Ce,Ee]),Ie=s((function(n){return!!n&&!!Ce.find((function(e){return e.value===n}))}),[Ce]),De=s((function(n){return je?je.findIndex((function(e){return e.value===n})):-1}),[je]),Pe=s((function(n){if(je&&je.length>=n){var e=je[n];return e?e.value:void 0}}),[je]),Le=s((function(){return Ne(se)?se.findIndex((function(n){var e,r;return null===(e=Rn(n))||void 0===e||null===(r=e.current)||void 0===r?void 0:r.contains(document.activeElement)})):-1}),[Rn,Ne,se]),Ae=J(f(),2),Fe=Ae[0],Te=Ae[1],He=s((function(n){var e,r=null!==(e=null==je?void 0:je.length)&&void 0!==e?e:0,o=r-1>0?r-1:0,t=De(ie);switch(n&&Yn&&(ve(null),Oe()),n){case"next":var i=Pe(t+1<r?t+1:0);le(null!=i?i:null);break;case"prev":var a=Pe(t-1>=0?t-1:o);le(null!=a?a:null);break;case"last":var l=Pe(o);le(null!=l?l:null);break;default:var c=Pe(0);le(null!=c?c:null)}}),[ie,De,Pe,Yn,Oe,null==je?void 0:je.length]),Re=s((function(n,e){if(Ne(se))switch(n){case"next":var r=null!=e?e:Le(),o=r+1<se.length?r+1:se.length-1,t=se[o];ve(t);break;case"prev":var i=null!=e?e:Le(),a=i>0?i-1:i<0?se.length-1:0,l=se[a];ve(l);break;case"first":var c=se[0];ve(c);break;case"last":var s=se[se.length-1];ve(s);break;default:ve(null)}}),[Le,Ne,se]),We=s((function(n,e){switch(n&&le(null),n){case"right":switch(Fe){case on:var r,o,t;if((null===(r=Xn.current)||void 0===r?void 0:r.selectionEnd)===(null===(o=Xn.current)||void 0===o?void 0:o.value.length))null===(t=Vn.current)||void 0===t||t.focus();break;case an:case cn:case ln:if(Fe===ln||1===(null==se?void 0:se.length)){Oe(0),Re(null),e.preventDefault();break}Re("next")}break;case"left":switch(Fe){case tn:var i;e.preventDefault(),Oe(null==Xn||null===(i=Xn.current)||void 0===i?void 0:i.value.length);break;case on:case cn:case ln:if(Ne(se)){var a;if(Fe===on&&0!==(null===(a=Xn.current)||void 0===a?void 0:a.selectionStart))break;Re("prev")}}break;default:Re(null)}}),[Fe,Ne,se,Oe,Re]);p((function(){fe!==ge&&He("first")}),[fe,Yn,ge,He]),p((function(){if(ie){var n=Hn(ie);if(n&&n.current&&Zn.current){var e=n.current.offsetTop,r=Zn.current,o=r.scrollTop;(e>r.offsetHeight||e<o)&&(Zn.current.scrollTop=e)}}}),[ie,Hn]);var Ge=s((function(n){if(E(n,"ComboboxOption")){var e=Jn(n.props),r=e.value,o=e.displayName;if(Ee(r)){var t=n.props,i=t.className,l=t.glyph,c=t.disabled,s=Ce.findIndex((function(n){return n.value===r})),u=ie===r,d=Ne(se)?se.includes(r):se===r,p=Hn(r);return L(Ur,{value:r,displayName:o,isFocused:u,isSelected:d,disabled:c,setSelected:function(){le(r),Se(r),Oe(),r===se&&we()},glyph:l,className:i,index:s,ref:p})}}else if(E(n,"ComboboxGroup")){var f=a.Children.map(n.props.children,Ge);if(f&&(null==f?void 0:f.length)>0)return L(ae,{label:n.props.label,className:n.props.className},a.Children.map(f,Ge))}}),[Ce,Hn,ie,Ne,se,Oe,Ee,Se]),Ke=u((function(){return a.Children.map(v,Ge)}),[v,Ge]),Ue=u((function(){if(Ne(se))return se.filter(Ie).map((function(n,e){var r=_n(n,Ce),o=me===n,t=Rn(n),i=e>=se.length-1;return L(Zo,{key:n,displayName:r,isFocused:o,onRemove:function(){i?(Oe(),Re(null)):Re("next",e),Se(n)},onFocus:function(){ve(n)},ref:t})}))}),[Ne,se,Ie,Ce,me,Rn,Se,Oe,Re]),Ve=u((function(){return L(a.Fragment,null,mn&&ye&&L(N,{"aria-label":"Clear selection","aria-disabled":F,disabled:F,ref:Vn,onClick:function(n){F||(Se(null),null==vn||vn(n),null==hn||hn(""),Yn||ke())},onFocus:Je,className:S(Lo),darkMode:W},L(k,{glyph:"XWithCircle"})),L(k,"error"===K?{glyph:"Warning",color:W?M.red.light1:M.red.base,className:Ao(H)}:{glyph:"CaretDown",className:Ao(H)}))}),[mn,ye,F,K,W,H,Se,vn,hn,Yn]),Be=u((function(){return Ce.some((function(n){return n.hasGlyph}))}),[Ce]),Xe=s((function(){if(!Ne(se)&&se===de){var n=je.find((function(n){return n.displayName===fe||n.value===fe}));if(n&&!On)ue(n.value);else{var e,r=null!==(e=_n(se,Ce))&&void 0!==e?e:"";he(r)}}}),[Ce,fe,Ne,de,se,On,je]),Ze=s((function(){if(ye){if(Ne(se))er();else if(!Ne(se)){var n,e=null!==(n=_n(se,Ce))&&void 0!==n?n:"";he(e),we()}}else he("")}),[ye,Ce,Ne,se]);p((function(){if(Cn)if(e(Cn)){var n,r=null!==(n=Cn.filter((function(n){return Ie(n)})))&&void 0!==n?n:[];ue(r)}else Ie(Cn)&&ue(Cn);else ue(function(n){return n?[]:null}(kn))}),[]),p((function(){if(!i(On)&&On!==ge)if(o(On))ue(null);else if(Ne(On)){var n=On.filter(Ie);ue(n)}else ue(Ie(On)?On:null)}),[Ne,Ie,ge,On]),p((function(){r(se,de)||Ze()}),[Ze,de,se]),p((function(){!Yn&&oe&&Xe()}),[Yn,oe,Xe]);var qe=J(f(0),2),Ye=qe[0],$e=qe[1];p((function(){var n,e;$e(null!==(n=null===(e=Un.current)||void 0===e?void 0:e.clientWidth)&&void 0!==n?n:0)}),[Un,Yn,ie,se]);var Je=function(){le(null)};w("mousedown",(function(n){nr(n)||(n.preventDefault(),n.stopPropagation())}),{enabled:Yn}),w("click",(function(n){nr(n)||(n.stopPropagation(),we())}),{options:{capture:!0},enabled:Yn});var Qe,_e=function(n){for(var e=1;e<arguments.length;e++){var r=null!=arguments[e]?arguments[e]:{};e%2?B(Object(r),!0).forEach((function(e){Z(n,e,r[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(n,Object.getOwnPropertyDescriptors(r)):B(Object(r)).forEach((function(e){Object.defineProperty(n,e,Object.getOwnPropertyDescriptor(r,e))}))}return n}({popoverZIndex:An},In?{usePortal:In,portalClassName:Dn,portalContainer:Pn,scrollContainer:Ln}:{usePortal:In});return L(ee.Provider,{value:{multiselect:kn,darkMode:W,size:H,withIcons:Be,disabled:F,isOpen:Yn,state:K,searchState:$,chipTruncationLocation:Sn,chipCharacterLimit:Mn,inputValue:fe}},L("div",q({className:S(xo(H,xn),En)},Fn),L("div",{className:Ho},C&&L(h,{id:Gn,htmlFor:Wn,darkMode:W},C),O&&L(g,{darkMode:W},O)),L("div",{ref:Un,role:"combobox","aria-expanded":Yn,"aria-controls":Kn,"aria-owns":Kn,tabIndex:-1,onMouseDown:function(n){F&&n.preventDefault()},onClick:function(n){if(n.target!==Xn.current){var e=0;if(Xn.current)e=n.nativeEvent.offsetX>Xn.current.offsetLeft+Xn.current.clientWidth?fe.length:0;Oe(e)}},onFocus:function(n){er(),ke(),Te(function(n){var e,r,o,t;if(!n)return;if(null!==(e=Xn.current)&&void 0!==e&&e.contains(n))return on;if(null!==(r=Vn.current)&&void 0!==r&&r.contains(n))return tn;var i=Ne(se)?se.findIndex((function(e){var r,o;return null===(r=Rn(e))||void 0===r||null===(o=r.current)||void 0===o?void 0:o.contains(n)})):-1;if(Ne(se)){if(0===i)return an;if(i===se.length-1)return ln;if(i>0)return cn}if(null!==(o=Zn.current)&&void 0!==o&&o.contains(n))return un;if(null!==(t=Un.current)&&void 0!==t&&t.contains(n))return sn}(n.target))},onKeyDown:function(n){var e,r,t=null===(e=Zn.current)||void 0===e?void 0:e.contains(document.activeElement);if((null===(r=Un.current)||void 0===r?void 0:r.contains(document.activeElement))||t){if(n.ctrlKey||n.shiftKey||n.altKey)return;switch(n.keyCode){case I.Tab:switch(Fe){case"Input":ye||(we(),He("first"),Re(null));break;case"LastChip":Re(null)}break;case I.Escape:we(),He("first");break;case I.Enter:!Yn||Fe!==on||o(ie)||function(n){if("string"==typeof n){var e=Qn(n,Ce);return!(null==e||!e.isDisabled)}return!!n.isDisabled}(ie)?Fe===tn&&(Se(null),Oe()):Se(ie);break;case I.Backspace:var i;if(Ne(se))"Input"===Fe&&0===(null===(i=Xn.current)||void 0===i?void 0:i.selectionStart)&&Re("last");ke();break;case I.ArrowDown:Yn?(n.preventDefault(),He("next")):ke();break;case I.ArrowUp:Yn?(n.preventDefault(),He("prev")):ke();break;case I.ArrowRight:We("right",n);break;case I.ArrowLeft:We("left",n);break;default:Yn||ke()}}},onTransitionEnd:function(){var n,e;$e(null!==(n=null===(e=Un.current)||void 0===e?void 0:e.clientWidth)&&void 0!==n?n:0)},className:S(wo,ko[Tn],Co(H),(c={},Z(c,No[Tn],F),Z(c,Oo[Tn],K===bn),Z(c,So[Tn],(Qe=on,Qe===Fe)),c))},L("div",{ref:Bn,className:zo({size:H,overflow:xn})},Ue,L("input",{"aria-label":null!=P?P:C,"aria-autocomplete":"list","aria-controls":Kn,"aria-labelledby":Gn,ref:Xn,id:Wn,className:S(Mo,jo[H],Eo[Tn],Io(Yn,xn),(m={},Z(m,Do(H,fe),Ne(se)),Z(m,Po(se),Ne(se)),m)),placeholder:xe,disabled:null!=F?F:void 0,onChange:function(n){var e=n.target.value;he(e),null==hn||hn(e)},value:fe,autoComplete:"off"})),Ve),"error"===K&&U&&L("div",{className:S(Fo[Tn],To[H])},U),L(Yo,q({id:Kn,labelId:Gn,refEl:Un,ref:Zn,menuWidth:Ye,searchLoadingMessage:pn,searchErrorMessage:en,searchEmptyMessage:_},_e),Ke)));function nr(n){var e,r,o=n.target;return(null===(e=Zn.current)||void 0===e?void 0:e.contains(o))||(null===(r=Un.current)||void 0===r?void 0:r.contains(o))||!1}function er(){Bn&&Bn.current&&(Bn.current.scrollLeft=Bn.current.scrollWidth)}}export{Jo as Combobox,le as ComboboxGroup,Vr as ComboboxOption};
|
|
1
|
+
import n from"lodash/clone";import e from"lodash/isArray";import r from"lodash/isEqual";import o from"lodash/isNull";import t from"lodash/isString";import i from"lodash/isUndefined";import a,{createContext as l,useContext as c,useCallback as s,useMemo as u,useRef as d,useEffect as f,useState as p}from"react";import{Label as h,Description as b}from"@leafygreen-ui/typography";import{useIdAllocator as g,useForwardedRef as m,useAvailableSpace as v,useDynamicRefs as y,usePrevious as x,useEventListener as w}from"@leafygreen-ui/hooks";import k,{isComponentGlyph as C}from"@leafygreen-ui/icon";import N from"@leafygreen-ui/icon-button";import{css as O,cx as S,keyframes as z}from"@leafygreen-ui/emotion";import{palette as M}from"@leafygreen-ui/palette";import{isComponentType as E,createUniqueClassName as j,keyMap as I,consoleOnce as D}from"@leafygreen-ui/lib";import P from"lodash/escapeRegExp";import{jsx as L}from"@emotion/react";import A from"lodash/kebabCase";import F from"@leafygreen-ui/checkbox";import{typeScales as T,spacing as H,fontFamilies as R,hoverRing as W,focusRing as G}from"@leafygreen-ui/tokens";import{transparentize as K}from"polished";import U from"@leafygreen-ui/inline-definition";import V from"@leafygreen-ui/popover";function B(n,e){var r=Object.keys(n);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(n);e&&(o=o.filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable}))),r.push.apply(r,o)}return r}function X(n){return X="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(n){return typeof n}:function(n){return n&&"function"==typeof Symbol&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n},X(n)}function Z(n,e,r){return e in n?Object.defineProperty(n,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):n[e]=r,n}function q(){return q=Object.assign||function(n){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var o in r)Object.prototype.hasOwnProperty.call(r,o)&&(n[o]=r[o])}return n},q.apply(this,arguments)}function Y(n,e){if(null==n)return{};var r,o,t=function(n,e){if(null==n)return{};var r,o,t={},i=Object.keys(n);for(o=0;o<i.length;o++)r=i[o],e.indexOf(r)>=0||(t[r]=n[r]);return t}(n,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(n);for(o=0;o<i.length;o++)r=i[o],e.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(n,r)&&(t[r]=n[r])}return t}function $(n,e){return e||(e=n.slice(0)),Object.freeze(Object.defineProperties(n,{raw:{value:Object.freeze(e)}}))}function J(n,e){return function(n){if(Array.isArray(n))return n}(n)||function(n,e){var r=null==n?null:"undefined"!=typeof Symbol&&n[Symbol.iterator]||n["@@iterator"];if(null==r)return;var o,t,i=[],a=!0,l=!1;try{for(r=r.call(n);!(a=(o=r.next()).done)&&(i.push(o.value),!e||i.length!==e);a=!0);}catch(n){l=!0,t=n}finally{try{a||null==r.return||r.return()}finally{if(l)throw t}}return i}(n,e)||_(n,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Q(n){return function(n){if(Array.isArray(n))return nn(n)}(n)||function(n){if("undefined"!=typeof Symbol&&null!=n[Symbol.iterator]||null!=n["@@iterator"])return Array.from(n)}(n)||_(n)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function _(n,e){if(n){if("string"==typeof n)return nn(n,e);var r=Object.prototype.toString.call(n).slice(8,-1);return"Object"===r&&n.constructor&&(r=n.constructor.name),"Map"===r||"Set"===r?Array.from(n):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?nn(n,e):void 0}}function nn(n,e){(null==e||e>n.length)&&(e=n.length);for(var r=0,o=new Array(e);r<e;r++)o[r]=n[r];return o}var en="dark",rn="light",on="Input",tn="ClearButton",an="FirstChip",ln="LastChip",cn="MiddleChip",sn="Combobox",un="Menu",dn="default",fn="large",pn="expand-y",hn="scroll-x",bn="error";var gn,mn,vn,yn,xn,wn,kn,Cn,Nn,On,Sn,zn,Mn,En,jn,In,Dn,Pn,Ln,An,Fn,Tn,Hn,Rn,Wn,Gn,Kn,Un,Vn,Bn,Xn,Zn,qn,Yn=function(n,e,r){if(e&&r){var o=P(e),t=new RegExp(o,"gi"),i=n.matchAll(t);if(i){for(var l=n.split(""),c=0,s=Array.from(i);c<s.length;c++){var u,d=s[c],f=null!==(u=d.index)&&void 0!==u?u:-1,p=d[0],h=p.length,b=f+p+h,g=new Array(h).fill("");g[0]=a.createElement(r,{key:b},p),l.splice.apply(l,[f,h].concat(Q(g)))}return L(a.Fragment,null,l)}return L(a.Fragment,null,n)}return L(a.Fragment,null,n)},$n=function(n){var e,r=n.value,o=n.displayName;return{value:null!=r?r:A(o),displayName:null!==(e=null!=o?o:r)&&void 0!==e?e:""}},Jn=function(n,e){if(n)return e.find((function(e){return e.value===n}))},Qn=function(n,e){var r,o;return n?null!==(r=null===(o=Jn(n,e))||void 0===o?void 0:o.displayName)&&void 0!==r?r:n:""},_n=function n(e){return a.Children.toArray(e).reduce((function(e,r){if(E(r,"ComboboxOption")){var o=$n(r.props),t=o.value,i=o.displayName,a=r.props,l=a.glyph,c=a.disabled;return[].concat(Q(e),[{value:t,displayName:i,isDisabled:!!c,hasGlyph:!!l}])}if(E(r,"ComboboxGroup")){var s=r.props.children;if(s)return[].concat(Q(e),Q(n(s)))}}),[])},ne=l({multiselect:!1,darkMode:!1,size:dn,withIcons:!1,disabled:!1,isOpen:!1,state:"none",searchState:"unset"}),ee=function(n){return n?en:rn},re=(Z(vn={},rn,O(gn||(gn=$(["\n padding-top: 8px;\n "])))),Z(vn,en,O(mn||(mn=$(["\n padding-top: 8px;\n "])))),vn),oe=O(yn||(yn=$(["\n cursor: default;\n width: 100%;\n padding: 0 12px 2px;\n outline: none;\n overflow-wrap: anywhere;\n font-size: 12px;\n line-height: 16px;\n font-weight: bold;\n text-transform: uppercase;\n letter-spacing: 0.4px;\n"]))),te=(Z(kn={},rn,O(xn||(xn=$(["\n color: ",";\n "])),M.gray.dark1)),Z(kn,en,O(wn||(wn=$(["\n color: ",";\n "])),M.gray.light1)),kn);function ie(n){var e=n.label,r=n.className,o=n.children,t=c(ne).darkMode,i=ee(t),l=g({prefix:"combobox-group"});return a.Children.count(o)>0?L("div",{className:S(re[i],r)},L("div",{className:S(oe,te[i]),id:l},e),L("div",{role:"group","aria-labelledby":l},o)):L(a.Fragment,null)}function ae(n){throw Error("`ComboboxGroup` must be a child of a `Combobox` instance")}ae.displayName="ComboboxGroup";var le=(Z(Cn={},dn,{x:12,y:8}),Z(Cn,fn,{x:12,y:8}),Cn),ce=(Z(Nn={},dn,T.body1.lineHeight+2*le[dn].y),Z(Nn,fn,T.body2.lineHeight+2*le[fn].y),Nn),se=function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:384;return O(On||(On=$(["\n width: ","px;\n overflow: hidden;\n border-radius: 12px;\n border: 1px solid;\n"])),n)},ue=(Z(Mn={},rn,O(Sn||(Sn=$(["\n box-shadow: 0px 4px 7px ",";\n border-color: ",";\n "])),K(.85,M.black),M.gray.light2)),Z(Mn,en,O(zn||(zn=$(["\n box-shadow: 0px 4px 7px ",";\n border-color: ",";\n "])),K(.85,M.black),M.gray.dark3)),Mn),de=O(En||(En=$(["\n position: relative;\n width: 100%;\n margin: 0;\n padding: ","px 0;\n font-family: ",";\n border-radius: inherit;\n overflow-y: auto;\n scroll-behavior: smooth;\n"])),H[2],R.default),fe=(Z(Dn={},rn,O(jn||(jn=$(["\n color: ",";\n background-color: ",";\n "])),M.black,M.white)),Z(Dn,en,O(In||(In=$(["\n color: ",";\n background-color: ",";\n "])),M.gray.light1,M.gray.dark3)),Dn);Z(An={},dn,O(Pn||(Pn=$(["\n min-height: ","px;\n "])),ce[dn])),Z(An,fn,O(Ln||(Ln=$(["\n min-height: ","px;\n "])),ce[fn]));var pe=O(Fn||(Fn=$(["\n position: relative;\n margin: 0;\n padding: 0;\n"]))),he=O(Tn||(Tn=$(["\n font-family: inherit;\n display: inline-flex;\n align-items: center;\n gap: 8px;\n"]))),be=(Z(Wn={},rn,O(Hn||(Hn=$(["\n color: ",";\n "])),M.gray.dark3)),Z(Wn,en,O(Rn||(Rn=$(["\n color: ",";\n "])),M.gray.light3)),Wn),ge=(Z(Un={},dn,O(Gn||(Gn=$(["\n font-size: ","px;\n line-height: ","px;\n padding: ","px\n ","px;\n "])),T.body1.fontSize,T.body1.lineHeight,le[dn].y,le[dn].x)),Z(Un,fn,O(Kn||(Kn=$(["\n font-size: ","px;\n line-height: ","px;\n padding: ","px\n ","px;\n "])),T.body2.fontSize,T.body2.lineHeight,le[fn].y,le[fn].x)),Un);Z(Xn={},dn,O(Vn||(Vn=$(["\n height: ","px;\n width: ","px;\n "])),T.body1.fontSize,T.body1.fontSize)),Z(Xn,fn,O(Bn||(Bn=$(["\n height: ","px;\n width: ","px;\n "])),T.body2.fontSize,T.body2.fontSize));var me,ve,ye,xe,we,ke,Ce,Ne,Oe,Se,ze,Me,Ee,je,Ie,De,Pe,Le,Ae,Fe,Te,He,Re,We,Ge,Ke,Ue,Ve,Be,Xe,Ze,qe,Ye,$e,Je,Qe,_e,nr,er,rr,or,tr,ir,ar,lr,cr,sr,ur,dr,fr,pr,hr,br,gr,mr,vr,yr,xr,wr,kr,Cr,Nr,Or,Sr=z(Zn||(Zn=$(["\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n"]))),zr=O(qn||(qn=$(["\n animation: "," 1.5s linear infinite;\n"])),Sr),Mr=O(me||(me=$(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: space-between;\n list-style: none;\n color: inherit;\n cursor: pointer;\n overflow: hidden;\n font-family: ",";\n\n // Left wedge\n &:before {\n content: '';\n position: absolute;\n left: 0;\n width: 4px;\n height: calc(100% - 14px);\n background-color: rgba(255, 255, 255, 0);\n border-radius: 0 6px 6px 0;\n transform: scale3d(0, 0.3, 0);\n transition: 200ms ease-in-out;\n transition-property: transform, background-color;\n }\n"])),R.default),Er=(Z(xe={},rn,O(ve||(ve=$(["\n &:hover {\n outline: none;\n background-color: ",";\n }\n "])),M.gray.light2)),Z(xe,en,O(ye||(ye=$(["\n &:hover {\n outline: none;\n background-color: ",";\n }\n "])),M.gray.dark4)),xe),jr=(Z(Ce={},dn,O(we||(we=$(["\n font-size: ","px;\n line-height: ","px;\n min-height: ","px;\n padding: ","px\n ","px;\n gap: ","px;\n\n &:before {\n max-height: ","px;\n }\n "])),T.body1.fontSize,T.body1.lineHeight,ce[dn],le[dn].y,le[dn].x,H[1],ce[dn])),Z(Ce,fn,O(ke||(ke=$(["\n font-size: ","px;\n line-height: ","px;\n min-height: ","px;\n padding: ","px\n ","px;\n gap: ","px;\n\n &:before {\n max-height: ","px;\n }\n "])),T.body2.fontSize,T.body2.lineHeight,ce[fn],le[fn].y,le[fn].x,H[2],ce[fn])),Ce),Ir=O(Ne||(Ne=$(["\n outline: none;\n\n &:before {\n transform: scaleY(1);\n }\n"]))),Dr=(Z(ze={},rn,O(Oe||(Oe=$(["\n ",";\n background-color: ",";\n\n &:before {\n background-color: ",";\n }\n "])),Ir,M.blue.light3,M.blue.base)),Z(ze,en,O(Se||(Se=$(["\n ",";\n background-color: ",";\n\n &:before {\n background-color: ",";\n }\n "])),Ir,M.blue.dark3,M.blue.light1)),ze),Pr=O(Me||(Me=$(["\n cursor: not-allowed;\n\n &:hover {\n background-color: inherit;\n }\n\n &:before {\n content: unset;\n }\n"]))),Lr=(Z(Ie={},rn,O(Ee||(Ee=$(["\n ",";\n color: ",";\n "])),Pr,M.gray.light1)),Z(Ie,en,O(je||(je=$(["\n ",";\n color: ",";\n "])),Pr,M.gray.dark1)),Ie),Ar=(Z(Le={},dn,O(De||(De=$(["\n min-width: ","px;\n "])),H[3])),Z(Le,fn,O(Pe||(Pe=$(["\n min-width: ","px;\n "])),H[4])),Le),Fr=O(Ae||(Ae=$(["\n display: inline-flex;\n gap: 8px;\n justify-content: start;\n align-items: inherit;\n overflow-wrap: anywhere;\n"]))),Tr=O(Fe||(Fe=$(["\n pointer-events: none;\n"]))),Hr=function(n){return O(Te||(Te=$(["\n font-weight: ",";\n"])),n?"bold":"normal")},Rr=a.forwardRef((function(n,e){var r,o=n.displayName,t=n.glyph,i=n.isSelected,l=n.isFocused,d=n.disabled,f=n.setSelected,p=n.className,h=c(ne),b=h.multiselect,v=h.darkMode,y=h.withIcons,x=h.inputValue,w=h.size,N=ee(v),z=g({prefix:"combobox-option-text"}),j=m(e,null),I=s((function(n){n.stopPropagation(),d||n.target!==j.current&&"INPUT"!==n.target.tagName||f()}),[d,j,f]),D=u((function(){if(t){if(C(t)||E(t,"Icon"))return t;console.error("`ComboboxOption` instance did not render icon because it is not a known glyph element.",t)}}),[t]),P=u((function(){if(b){var n=L(F,{"aria-labelledby":z,checked:i,tabIndex:-1,disabled:d,darkMode:v,className:O(He||(He=$(["\n // TODO: Remove when this is resolved:\n // https://jira.mongodb.org/browse/PD-2171\n & > label > div {\n margin-top: 0;\n }\n "])))});return L(a.Fragment,null,L("span",{className:S(Fr,Tr)},y?D:n,L("span",{id:z,className:Hr(i)},Yn(o,x,"strong"))),y&&n)}return L(a.Fragment,null,L("span",{className:S(Fr,Tr)},D,L("span",{className:Hr(i)},Yn(o,x,"strong"))),i&&L(k,{glyph:"Checkmark",className:Ar[w],color:v?M.blue.light1:M.blue.base}))}),[b,D,i,o,x,w,v,z,d,y]);return L("li",{ref:j,role:"option","aria-selected":l,"aria-label":o,tabIndex:-1,className:S(Mr,jr[w],Er[N],(r={},Z(r,Dr[N],l),Z(r,Lr[N],d),r),p),onClick:I,onKeyDown:I},P)}));function Wr(n){throw Error("`ComboboxOption` must be a child of a `Combobox` instance")}Rr.displayName="ComboboxOption",Wr.displayName="ComboboxOption";var Gr,Kr,Ur,Vr,Br,Xr,Zr,qr,Yr,$r,Jr,Qr,_r,no,eo,ro,oo,to,io,ao,lo,co,so,uo,fo=(Z(Re={},dn,T.body1.fontSize),Z(Re,fn,T.body2.fontSize),Re),po=(Z(We={},dn,2),Z(We,fn,4),We),ho=(Z(Ge={},dn,T.body1.lineHeight+2*po[dn]),Z(Ge,fn,T.body2.lineHeight+2*po[fn]),Ge),bo=(Z(Ke={},dn,{y:(36-ho[dn]-2)/2,x:H[2]-1}),Z(Ke,fn,{y:(48-ho[fn]-2)/2,x:H[2]-1}),Ke),go=H[3],mo=(Z(Ue={},dn,fo[dn]+2*bo[dn].x+go+2),Z(Ue,fn,fo[fn]+2*bo[fn].x+go+2),Ue),vo=j("combobox-chip"),yo=function(n){return O(Ve||(Ve=$(["\n font-family: ",";\n width: 100%;\n min-width: ","px;\n "])),R.default,mo[n])},xo=O(Be||(Be=$(["\n display: flex;\n flex-wrap: nowrap;\n align-items: center;\n cursor: text;\n transition: 150ms ease-in-out;\n transition-property: background-color, box-shadow, border-color;\n border: 1px solid;\n width: inherit;\n border-radius: 6px;\n"]))),wo=(Z(qe={},rn,O(Xe||(Xe=$(["\n color: ",";\n background-color: ",";\n border-color: ",";\n\n &:hover {\n box-shadow: ",";\n }\n "])),M.gray.dark3,M.white,M.gray.base,W[rn].gray)),Z(qe,en,O(Ze||(Ze=$(["\n color: ",";\n background-color: ",";\n border-color: ",";\n\n &:hover {\n box-shadow: ",";\n }\n "])),M.gray.light2,M.gray.dark4,M.gray.base,W[en].gray)),qe),ko=function(n){return O(Ye||(Ye=$(["\n padding: ","px ","px;\n"])),bo[n].y,bo[n].x)},Co=(Z(Qe={},rn,O($e||($e=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n border-color: ",";\n "])),M.gray.dark1,M.gray.light2,M.gray.light1)),Z(Qe,en,O(Je||(Je=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n border-color: ",";\n "])),M.gray.dark1,M.gray.dark3,M.gray.dark2)),Qe),No=(Z(er={},rn,O(_e||(_e=$(["\n border-color: ",";\n "])),M.red.base)),Z(er,en,O(nr||(nr=$(["\n border-color: ",";\n "])),M.red.light1)),er),Oo=(Z(tr={},rn,O(rr||(rr=$(["\n &:focus-within {\n border-color: transparent;\n background-color: ",";\n box-shadow: ",";\n }\n "])),M.white,G[rn].input)),Z(tr,en,O(or||(or=$(["\n &:focus-within {\n border-color: transparent;\n background-color: ",";\n box-shadow: ",";\n }\n "])),M.gray.dark4,G[en].input)),tr),So=function(n){var e=n.overflow,r=n.size,o=O(ir||(ir=$(["\n flex-grow: 1;\n width: inherit;\n "])));switch(e){case hn:return O(ar||(ar=$(["\n ","\n display: block;\n height: ","px;\n white-space: nowrap;\n overflow-x: scroll;\n scroll-behavior: smooth;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n & > ."," {\n margin-inline: 2px;\n\n &:first-child {\n margin-inline-start: 0;\n }\n\n &:last-child {\n margin-inline-end: 0;\n }\n }\n "])),o,ho[r],vo);case pn:return O(lr||(lr=$(["\n ","\n display: flex;\n flex-wrap: wrap;\n gap: 4px;\n overflow-x: visible;\n min-height: ","px;\n "])),o,ho[r])}},zo=O(cr||(cr=$(["\n font-family: ",";\n width: 100%;\n border: none;\n cursor: inherit;\n background-color: inherit;\n color: inherit;\n box-sizing: content-box;\n padding: 0;\n margin: 0;\n text-overflow: ellipsis;\n\n &:placeholder-shown {\n min-width: 100%;\n }\n &:focus {\n outline: none;\n }\n"])),R.default),Mo=(Z(dr={},rn,O(sr||(sr=$(["\n &::placeholder {\n color: ",";\n }\n "])),M.gray.dark1)),Z(dr,en,O(ur||(ur=$(["\n &::placeholder {\n color: ",";\n }\n "])),M.gray.light1)),dr),Eo=(Z(hr={},dn,O(fr||(fr=$(["\n height: ","px;\n font-size: ","px;\n line-height: ","px;\n min-width: ","px;\n // Only add padding if there are chips\n &:not(:first-child) {\n padding-left: 4px;\n }\n "])),ho[dn],T.body1.fontSize,T.body1.lineHeight,fo[dn])),Z(hr,fn,O(pr||(pr=$(["\n height: ","px;\n font-size: ","px;\n line-height: ","px;\n min-width: ","px;\n &:not(:first-child) {\n padding-left: 6px;\n }\n "])),ho[fn],T.body2.fontSize,T.body2.lineHeight,fo[fn])),hr),jo=function(n){return O(br||(br=$(["\n /*\n * Immediate transition in, slow transition out. \n * '-in' transition is handled by `scroll-behavior` \n */\n transition: width ease-in-out ",";\n"],["\n /*\n * Immediate transition in, slow transition out. \n * '-in' transition is handled by \\`scroll-behavior\\` \n */\n transition: width ease-in-out ",";\n"])),n?"0s":"100ms")},Io=function(n,e){var r,o=null!==(r=null==e?void 0:e.length)&&void 0!==r?r:0;return O(gr||(gr=$(["\n max-width: 100%;\n width: ","px;\n // TODO: This doesn't quite work. Fix this\n max-width: calc(100% - ","px);\n "])),o*fo[n],2*go)},Do=O(mr||(mr=$(["\n // Add a negative margin so the button takes up the same space as the regular icons\n margin-block: calc(","px - 100%);\n"])),go/2),Po=function(n){return O(vr||(vr=$(["\n height: ","px;\n width: ","px;\n margin-inline-end: calc(","px / 2);\n"])),go,go,bo[n].x)},Lo=(Z(wr={},rn,O(yr||(yr=$(["\n color: ",";\n "])),M.red.base)),Z(wr,en,O(xr||(xr=$(["\n color: ",";\n "])),M.red.light1)),wr),Ao=(Z(Nr={},dn,O(kr||(kr=$(["\n font-size: ","px;\n line-height: ","px;\n padding-top: ","px;\n "])),T.body1.fontSize,T.body1.lineHeight,bo[dn].y)),Z(Nr,fn,O(Cr||(Cr=$(["\n font-size: ","px;\n line-height: ","px;\n padding-top: ","px;\n "])),T.body2.fontSize,T.body2.lineHeight,bo[fn].y)),Nr),Fo=O(Or||(Or=$(["\n margin-bottom: 2px;\n"]))),To=O(Gr||(Gr=$(["\n display: inline-flex;\n align-items: center;\n overflow: hidden;\n white-space: nowrap;\n box-sizing: border-box;\n"]))),Ho=(Z(Vr={},dn,O(Kr||(Kr=$(["\n font-size: ","px;\n line-height: ","px;\n border-radius: 4px;\n "])),T.body1.fontSize,T.body1.lineHeight)),Z(Vr,fn,O(Ur||(Ur=$(["\n font-size: ","px;\n line-height: ","px;\n border-radius: 4px;\n "])),T.body2.fontSize,T.body2.lineHeight)),Vr),Ro=(Z(Zr={},rn,O(Br||(Br=$(["\n color: ",";\n background-color: ",";\n\n // TODO: - refine these styles with Design\n &:focus-within {\n background-color: ",";\n }\n "])),M.black,M.gray.light2,M.blue.light2)),Z(Zr,en,O(Xr||(Xr=$(["\n color: ",";\n background-color: ",";\n\n &:focus-within {\n background-color: ",";\n }\n "])),M.gray.light2,M.gray.dark2,M.blue.dark2)),Zr),Wo=(Z($r={},rn,O(qr||(qr=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n "])),M.gray.base,M.gray.light3)),Z($r,en,O(Yr||(Yr=$(["\n cursor: not-allowed;\n color: ",";\n background-color: ",";\n box-shadow: inset 0 0 1px 1px ","; ;\n "])),M.gray.dark2,M.gray.dark4,M.gray.dark2)),$r),Go=(Z(_r={},dn,O(Jr||(Jr=$(["\n padding-inline: 6px;\n padding-block: ","px;\n "])),po[dn])),Z(_r,fn,O(Qr||(Qr=$(["\n padding-inline: 10px;\n padding-block: ","px;\n "])),po[fn])),_r),Ko=O(no||(no=$(["\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n outline: none;\n border: none;\n background-color: transparent;\n cursor: pointer;\n transition: background-color 100ms ease-in-out;\n"]))),Uo=(Z(oo={},dn,O(eo||(eo=$(["\n height: ","px;\n "])),ho[dn])),Z(oo,fn,O(ro||(ro=$(["\n height: ","px;\n "])),ho[fn])),oo),Vo=(Z(ao={},rn,O(to||(to=$(["\n color: ",";\n\n &:hover {\n color: ",";\n background-color: ",";\n }\n "])),M.gray.dark2,M.black,M.gray.light1)),Z(ao,en,O(io||(io=$(["\n color: ",";\n\n &:hover {\n color: ",";\n background-color: ",";\n }\n "])),M.gray.light1,M.gray.light3,M.gray.dark1)),ao),Bo=(Z(so={},rn,O(lo||(lo=$(["\n cursor: not-allowed;\n color: ",";\n &:hover {\n color: inherit;\n background-color: unset;\n }\n "])),M.gray.dark2)),Z(so,en,O(co||(co=$(["\n cursor: not-allowed;\n color: ",";\n &:hover {\n color: inherit;\n background-color: unset;\n }\n "])),M.gray.dark2)),so),Xo=a.forwardRef((function(n,e){var r=n.displayName,o=n.isFocused,t=n.onRemove,i=n.onFocus,a=c(ne),l=a.darkMode,s=a.size,p=a.disabled,h=a.chipTruncationLocation,b=void 0===h?"end":h,g=a.chipCharacterLimit,m=void 0===g?12:g,v=ee(l),y=!!m&&!!b&&"none"!==b&&r.length>m,x=d(null),w=u((function(){if(y){var n=m-3;switch(b){case"start":return"…"+r.substring(r.length-n).trim();case"middle":return r.substring(0,n/2).trim()+"…"+r.substring(r.length-n/2).trim();case"end":return r.substring(0,n).trim()+"…";default:return r}}return!1}),[m,b,r,y]);f((function(){var n;o&&!p&&(null==x||null===(n=x.current)||void 0===n||n.focus())}),[p,e,o]);return L("span",{role:"option","aria-selected":o,"data-testid":"lg-combobox-chip",ref:e,className:S(vo,To,Ro[v],Ho[s],Z({},Wo[v],p)),onClick:function(n){var e;null!==(e=x.current)&&void 0!==e&&e.contains(n.target)||i()},onKeyDown:function(n){p||n.keyCode!==I.Delete&&n.keyCode!==I.Backspace&&n.keyCode!==I.Enter&&n.keyCode!==I.Space||t()},tabIndex:-1},L("span",{className:S(Go[s])},w?L(U,{darkMode:l,definition:r,align:"bottom"},w):r),L("button",{"aria-label":"Deselect ".concat(r),"aria-disabled":p,disabled:p,ref:x,className:S(Ko,Vo[v],Uo[s],Z({},Bo[v],p)),onClick:function(){p||t()}},L(k,{glyph:"X"})))}));Xo.displayName="Chip";var Zo=["children","id","refEl","labelId","menuWidth","searchLoadingMessage","searchErrorMessage","searchEmptyMessage"],qo=a.forwardRef((function(n,e){var r=n.children,o=n.id,t=n.refEl,a=n.labelId,l=n.menuWidth,s=n.searchLoadingMessage,d=n.searchErrorMessage,f=n.searchEmptyMessage,p=Y(n,Zo),h=c(ne),b=h.disabled,g=h.darkMode,y=h.size,x=h.isOpen,w=h.searchState,C=m(e,null),N=ee(g),z=v(t),E=i(z)?"unset":"".concat(Math.min(z,256),"px"),j=u((function(){var n=S(he,be[N],ge[y]);switch(w){case"loading":return L("span",{className:n},L(k,{glyph:"Refresh",color:g?M.blue.light1:M.blue.base,className:zr}),s);case"error":return L("span",{className:n},L(k,{glyph:"Warning",color:g?M.red.light1:M.red.base}),d);default:return r&&"object"===X(r)&&"length"in r&&r.length>0?L("ul",{className:pe},r):L("span",{className:n},f)}}),[N,y,w,g,s,d,r,f]);return L(V,q({active:x&&!b,spacing:4,align:"bottom",justify:"middle",refEl:t,adjustOnMutation:!0,className:S(se(l),ue[N])},p),L("div",{ref:C,id:o,role:"listbox","aria-labelledby":a,"aria-expanded":x,className:S(de,fe[N],O(uo||(uo=$(["\n max-height: ",";\n "])),E)),onMouseDownCapture:function(n){return n.preventDefault()}},j))}));qo.displayName="ComboboxMenu";var Yo=["children","label","description","placeholder","aria-label","disabled","size","darkMode","state","errorMessage","searchState","searchEmptyMessage","searchErrorMessage","searchLoadingMessage","filteredOptions","onFilter","clearable","onClear","overflow","multiselect","initialValue","onChange","value","chipTruncationLocation","chipCharacterLimit","className","usePortal","portalClassName","portalContainer","scrollContainer","popoverZIndex"];function $o(l){var c,m=l.children,v=l.label,C=l.description,O=l.placeholder,z=void 0===O?"Select":O,j=l["aria-label"],P=l.disabled,A=void 0!==P&&P,F=l.size,T=void 0===F?dn:F,H=l.darkMode,R=void 0!==H&&H,W=l.state,G=void 0===W?"none":W,K=l.errorMessage,U=l.searchState,V=void 0===U?"unset":U,$=l.searchEmptyMessage,Q=void 0===$?"No results found":$,_=l.searchErrorMessage,nn=void 0===_?"Could not get results!":_,en=l.searchLoadingMessage,rn=void 0===en?"Loading results...":en,fn=l.filteredOptions,pn=l.onFilter,hn=l.clearable,gn=void 0===hn||hn,mn=l.onClear,vn=l.overflow,yn=void 0===vn?"expand-y":vn,xn=l.multiselect,wn=void 0!==xn&&xn,kn=l.initialValue,Cn=l.onChange,Nn=l.value,On=l.chipTruncationLocation,Sn=l.chipCharacterLimit,zn=void 0===Sn?12:Sn,Mn=l.className,En=l.usePortal,jn=void 0===En||En,In=l.portalClassName,Dn=l.portalContainer,Pn=l.scrollContainer,Ln=l.popoverZIndex,An=Y(l,Yo),Fn=ee(R),Tn=y({prefix:"option"}),Hn=y({prefix:"chip"}),Rn=g({prefix:"combobox-input"}),Wn=g({prefix:"combobox-label"}),Gn=g({prefix:"combobox-menu"}),Kn=d(null),Un=d(null),Vn=d(null),Bn=d(null),Xn=d(null),Zn=J(p(!1),2),qn=Zn[0],Yn=Zn[1],re=x(qn),oe=J(p(null),2),te=oe[0],ae=oe[1],le=J(p(null),2),ce=le[0],se=le[1],ue=x(ce),de=J(p(""),2),fe=de[0],pe=de[1],he=x(fe),be=J(p(null),2),ge=be[0],me=be[1],ve=!o(ce)&&(e(ce)&&ce.length>0||t(ce)),ye=wn&&e(ce)&&ce.length>0?void 0:z,xe=function(){return Yn(!1)},we=function(){return Yn(!0)},ke=u((function(){return _n(m)}),[m]),Ce=s((function(n){return!wn||"string"!=typeof n&&"number"!=typeof n?!wn&&e(n)&&D.error("Error in Combobox: multiselect is set to `false`, but recieved an Array value"):D.error("Error in Combobox: multiselect is set to `true`, but recieved a ".concat(X(n),' value: "').concat(n,'"')),wn&&e(n)}),[wn]),Ne=s((function(n){!A&&Bn&&Bn.current&&(Bn.current.focus(),i(n)||Bn.current.setSelectionRange(n,n))}),[A]),Oe=s((function(e){if(Ce(ce)){var r=n(ce);o(e)?r.length=0:ce.includes(e)?r.splice(r.indexOf(e),1):(r.push(e),pe("")),se(r),null==Cn||Cn(r)}else{var t=e;se(t),null==Cn||Cn(t)}}),[Ce,Cn,ce]),Se=s((function(n){return Ce(ce)?ce.includes(n):n===ce}),[Ce,ce]),ze=s((function(n){var e,r,o,t,i=(r=ke,(e=n)?null!==(o=null===(t=r.find((function(n){return n.displayName===e})))||void 0===t?void 0:t.value)&&void 0!==o?o:e:"");return Se(i)}),[ke,Se]),Me=s((function(n){var e="string"==typeof n?n:n.value;return fn&&fn.length>0?fn.includes(e):!!ze(fe)||("string"==typeof n?Qn(e,ke):n.displayName).toLowerCase().includes(fe.toLowerCase())}),[fn,ze,fe,ke]),Ee=u((function(){return ke.filter(Me)}),[ke,Me]),je=s((function(n){return!!n&&!!ke.find((function(e){return e.value===n}))}),[ke]),Ie=s((function(n){return Ee?Ee.findIndex((function(e){return e.value===n})):-1}),[Ee]),De=s((function(n){if(Ee&&Ee.length>=n){var e=Ee[n];return e?e.value:void 0}}),[Ee]),Pe=s((function(){return Ce(ce)?ce.findIndex((function(n){var e,r;return null===(e=Hn(n))||void 0===e||null===(r=e.current)||void 0===r?void 0:r.contains(document.activeElement)})):-1}),[Hn,Ce,ce]),Le=J(p(),2),Ae=Le[0],Fe=Le[1],Te=s((function(n){var e,r=null!==(e=null==Ee?void 0:Ee.length)&&void 0!==e?e:0,o=r-1>0?r-1:0,t=Ie(te);switch(n&&qn&&(me(null),Ne()),n){case"next":var i=De(t+1<r?t+1:0);ae(null!=i?i:null);break;case"prev":var a=De(t-1>=0?t-1:o);ae(null!=a?a:null);break;case"last":var l=De(o);ae(null!=l?l:null);break;default:var c=De(0);ae(null!=c?c:null)}}),[te,Ie,De,qn,Ne,null==Ee?void 0:Ee.length]),He=s((function(n,e){if(Ce(ce))switch(n){case"next":var r=null!=e?e:Pe(),o=r+1<ce.length?r+1:ce.length-1,t=ce[o];me(t);break;case"prev":var i=null!=e?e:Pe(),a=i>0?i-1:i<0?ce.length-1:0,l=ce[a];me(l);break;case"first":var c=ce[0];me(c);break;case"last":var s=ce[ce.length-1];me(s);break;default:me(null)}}),[Pe,Ce,ce]),Re=s((function(n,e){switch(n&&ae(null),n){case"right":switch(Ae){case on:var r,o,t;if((null===(r=Bn.current)||void 0===r?void 0:r.selectionEnd)===(null===(o=Bn.current)||void 0===o?void 0:o.value.length))null===(t=Un.current)||void 0===t||t.focus();break;case an:case cn:case ln:if(Ae===ln||1===(null==ce?void 0:ce.length)){Ne(0),He(null),e.preventDefault();break}He("next")}break;case"left":switch(Ae){case tn:var i;e.preventDefault(),Ne(null==Bn||null===(i=Bn.current)||void 0===i?void 0:i.value.length);break;case on:case cn:case ln:if(Ce(ce)){var a;if(Ae===on&&0!==(null===(a=Bn.current)||void 0===a?void 0:a.selectionStart))break;He("prev")}}break;default:He(null)}}),[Ae,Ce,ce,Ne,He]);f((function(){fe!==he&&Te("first")}),[fe,qn,he,Te]),f((function(){if(te){var n=Tn(te);if(n&&n.current&&Xn.current){var e=n.current.offsetTop,r=Xn.current,o=r.scrollTop;(e>r.offsetHeight||e<o)&&(Xn.current.scrollTop=e)}}}),[te,Tn]);var We=s((function(n){if(E(n,"ComboboxOption")){var e=$n(n.props),r=e.value,o=e.displayName;if(Me(r)){var t=n.props,i=t.className,l=t.glyph,c=t.disabled,s=ke.findIndex((function(n){return n.value===r})),u=te===r,d=Ce(ce)?ce.includes(r):ce===r,f=Tn(r);return L(Rr,{value:r,displayName:o,isFocused:u,isSelected:d,disabled:c,setSelected:function(){ae(r),Oe(r),Ne(),r===ce&&xe()},glyph:l,className:i,index:s,ref:f})}}else if(E(n,"ComboboxGroup")){var p=a.Children.map(n.props.children,We);if(p&&(null==p?void 0:p.length)>0)return L(ie,{label:n.props.label,className:n.props.className},a.Children.map(p,We))}}),[ke,Tn,te,Ce,ce,Ne,Me,Oe]),Ge=u((function(){return a.Children.map(m,We)}),[m,We]),Ke=u((function(){if(Ce(ce))return ce.filter(je).map((function(n,e){var r=Qn(n,ke),o=ge===n,t=Hn(n),i=e>=ce.length-1;return L(Xo,{key:n,displayName:r,isFocused:o,onRemove:function(){i?(Ne(),He(null)):He("next",e),Oe(n)},onFocus:function(){me(n)},ref:t})}))}),[Ce,ce,je,ke,ge,Hn,Oe,Ne,He]),Ue=u((function(){return L(a.Fragment,null,gn&&ve&&L(N,{"aria-label":"Clear selection","aria-disabled":A,disabled:A,ref:Un,onClick:function(n){A||(Oe(null),null==mn||mn(n),null==pn||pn(""),qn||we())},onFocus:$e,className:S(Do),darkMode:R},L(k,{glyph:"XWithCircle"})),L(k,"error"===G?{glyph:"Warning",color:R?M.red.light1:M.red.base,className:Po(T)}:{glyph:"CaretDown",className:Po(T)}))}),[gn,ve,A,G,R,T,Oe,mn,pn,qn]),Ve=u((function(){return ke.some((function(n){return n.hasGlyph}))}),[ke]),Be=s((function(){if(!Ce(ce)&&ce===ue){var n=Ee.find((function(n){return n.displayName===fe||n.value===fe}));if(n&&!Nn)se(n.value);else{var e,r=null!==(e=Qn(ce,ke))&&void 0!==e?e:"";pe(r)}}}),[ke,fe,Ce,ue,ce,Nn,Ee]),Xe=s((function(){if(ve){if(Ce(ce))nr();else if(!Ce(ce)){var n,e=null!==(n=Qn(ce,ke))&&void 0!==n?n:"";pe(e),xe()}}else pe("")}),[ve,ke,Ce,ce]);f((function(){if(kn)if(e(kn)){var n,r=null!==(n=kn.filter((function(n){return je(n)})))&&void 0!==n?n:[];se(r)}else je(kn)&&se(kn);else se(function(n){return n?[]:null}(wn))}),[]),f((function(){if(!i(Nn)&&Nn!==he)if(o(Nn))se(null);else if(Ce(Nn)){var n=Nn.filter(je);se(n)}else se(je(Nn)?Nn:null)}),[Ce,je,he,Nn]),f((function(){r(ce,ue)||Xe()}),[Xe,ue,ce]),f((function(){!qn&&re&&Be()}),[qn,re,Be]);var Ze=J(p(0),2),qe=Ze[0],Ye=Ze[1];f((function(){var n,e;Ye(null!==(n=null===(e=Kn.current)||void 0===e?void 0:e.clientWidth)&&void 0!==n?n:0)}),[Kn,qn,te,ce]);var $e=function(){ae(null)};w("mousedown",(function(n){_e(n)||(n.preventDefault(),n.stopPropagation())}),{enabled:qn}),w("click",(function(n){_e(n)||(n.stopPropagation(),xe())}),{options:{capture:!0},enabled:qn});var Je,Qe=function(n){for(var e=1;e<arguments.length;e++){var r=null!=arguments[e]?arguments[e]:{};e%2?B(Object(r),!0).forEach((function(e){Z(n,e,r[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(n,Object.getOwnPropertyDescriptors(r)):B(Object(r)).forEach((function(e){Object.defineProperty(n,e,Object.getOwnPropertyDescriptor(r,e))}))}return n}({popoverZIndex:Ln},jn?{usePortal:jn,portalClassName:In,portalContainer:Dn,scrollContainer:Pn}:{usePortal:jn});return L(ne.Provider,{value:{multiselect:wn,darkMode:R,size:T,withIcons:Ve,disabled:A,isOpen:qn,state:G,searchState:V,chipTruncationLocation:On,chipCharacterLimit:zn,inputValue:fe}},L("div",q({className:S(yo(T),Mn)},An),L("div",{className:Fo},v&&L(h,{id:Wn,htmlFor:Rn,darkMode:R},v),C&&L(b,{darkMode:R},C)),L("div",{ref:Kn,role:"combobox","aria-expanded":qn,"aria-controls":Gn,"aria-owns":Gn,tabIndex:-1,onMouseDown:function(n){A&&n.preventDefault()},onClick:function(n){if(n.target!==Bn.current){var e=0;if(Bn.current)e=n.nativeEvent.offsetX>Bn.current.offsetLeft+Bn.current.clientWidth?fe.length:0;Ne(e)}},onFocus:function(n){nr(),we(),Fe(function(n){var e,r,o,t;if(!n)return;if(null!==(e=Bn.current)&&void 0!==e&&e.contains(n))return on;if(null!==(r=Un.current)&&void 0!==r&&r.contains(n))return tn;var i=Ce(ce)?ce.findIndex((function(e){var r,o;return null===(r=Hn(e))||void 0===r||null===(o=r.current)||void 0===o?void 0:o.contains(n)})):-1;if(Ce(ce)){if(0===i)return an;if(i===ce.length-1)return ln;if(i>0)return cn}if(null!==(o=Xn.current)&&void 0!==o&&o.contains(n))return un;if(null!==(t=Kn.current)&&void 0!==t&&t.contains(n))return sn}(n.target))},onKeyDown:function(n){var e,r,t=null===(e=Xn.current)||void 0===e?void 0:e.contains(document.activeElement);if((null===(r=Kn.current)||void 0===r?void 0:r.contains(document.activeElement))||t){if(n.ctrlKey||n.shiftKey||n.altKey)return;switch(n.keyCode){case I.Tab:switch(Ae){case"Input":ve||(xe(),Te("first"),He(null));break;case"LastChip":He(null)}break;case I.Escape:xe(),Te("first");break;case I.Enter:!qn||Ae!==on||o(te)||function(n){if("string"==typeof n){var e=Jn(n,ke);return!(null==e||!e.isDisabled)}return!!n.isDisabled}(te)?Ae===tn&&(Oe(null),Ne()):Oe(te);break;case I.Backspace:var i;if(Ce(ce))"Input"===Ae&&0===(null===(i=Bn.current)||void 0===i?void 0:i.selectionStart)&&He("last");we();break;case I.ArrowDown:qn?(n.preventDefault(),Te("next")):we();break;case I.ArrowUp:qn?(n.preventDefault(),Te("prev")):we();break;case I.ArrowRight:Re("right",n);break;case I.ArrowLeft:Re("left",n);break;default:qn||we()}}},onTransitionEnd:function(){var n,e;Ye(null!==(n=null===(e=Kn.current)||void 0===e?void 0:e.clientWidth)&&void 0!==n?n:0)},className:S(xo,wo[Fn],ko(T),(c={},Z(c,Co[Fn],A),Z(c,No[Fn],G===bn),Z(c,Oo[Fn],(Je=on,Je===Ae)),c))},L("div",{ref:Vn,className:So({size:T,overflow:yn})},Ke,L("input",{"aria-label":null!=j?j:v,"aria-autocomplete":"list","aria-controls":Gn,"aria-labelledby":Wn,ref:Bn,id:Rn,className:S(zo,Eo[T],Mo[Fn],jo(qn),Z({},Io(T,fe),Ce(ce))),placeholder:ye,disabled:null!=A?A:void 0,onChange:function(n){var e=n.target.value;pe(e),null==pn||pn(e)},value:fe,autoComplete:"off"})),Ue),"error"===G&&K&&L("div",{className:S(Lo[Fn],Ao[T])},K),L(qo,q({id:Gn,labelId:Wn,refEl:Kn,ref:Xn,menuWidth:qe,searchLoadingMessage:rn,searchErrorMessage:nn,searchEmptyMessage:Q},Qe),Ge)));function _e(n){var e,r,o=n.target;return(null===(e=Xn.current)||void 0===e?void 0:e.contains(o))||(null===(r=Kn.current)||void 0===r?void 0:r.contains(o))||!1}function nr(){Vn&&Vn.current&&(Vn.current.scrollLeft=Vn.current.scrollWidth)}}export{$o as Combobox,ae as ComboboxGroup,Wr as ComboboxOption};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|