@primer/components 0.0.0-202196214225 → 0.0.0-20219715822

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/CHANGELOG.md +7 -1
  2. package/dist/browser.esm.js +721 -654
  3. package/dist/browser.esm.js.map +1 -1
  4. package/dist/browser.umd.js +411 -344
  5. package/dist/browser.umd.js.map +1 -1
  6. package/lib/FilteredActionList/FilteredActionList.d.ts +3 -2
  7. package/lib/FilteredActionList/FilteredActionList.js +3 -1
  8. package/lib/SelectMenu/SelectMenu.d.ts +7 -2
  9. package/lib/SelectPanel/SelectPanel.d.ts +1 -1
  10. package/lib/SelectPanel/SelectPanel.js +9 -11
  11. package/lib/TextInput.d.ts +5 -3
  12. package/lib/TextInput.js +8 -10
  13. package/lib/TextInputWithTokens.d.ts +326 -0
  14. package/lib/TextInputWithTokens.js +244 -0
  15. package/lib/Token/IssueLabelToken.d.ts +14 -0
  16. package/lib/Token/IssueLabelToken.js +144 -0
  17. package/lib/Token/ProfileToken.d.ts +7 -0
  18. package/lib/Token/ProfileToken.js +53 -0
  19. package/lib/Token/Token.d.ts +15 -0
  20. package/lib/Token/Token.js +94 -0
  21. package/lib/Token/TokenBase.d.ts +17 -0
  22. package/lib/Token/TokenBase.js +108 -0
  23. package/lib/Token/_RemoveTokenButton.d.ts +12 -0
  24. package/lib/Token/_RemoveTokenButton.js +77 -0
  25. package/lib/Token/_TokenTextContainer.d.ts +3 -0
  26. package/lib/Token/_TokenTextContainer.js +34 -0
  27. package/lib/Token/index.d.ts +3 -0
  28. package/lib/Token/index.js +31 -0
  29. package/lib/_UnstyledTextInput.d.ts +2 -0
  30. package/lib/_UnstyledTextInput.js +20 -0
  31. package/lib/index.d.ts +2 -0
  32. package/lib/index.js +28 -0
  33. package/lib-esm/FilteredActionList/FilteredActionList.d.ts +3 -2
  34. package/lib-esm/FilteredActionList/FilteredActionList.js +3 -1
  35. package/lib-esm/SelectMenu/SelectMenu.d.ts +7 -2
  36. package/lib-esm/SelectPanel/SelectPanel.d.ts +1 -1
  37. package/lib-esm/SelectPanel/SelectPanel.js +9 -8
  38. package/lib-esm/TextInput.d.ts +5 -3
  39. package/lib-esm/TextInput.js +7 -9
  40. package/lib-esm/TextInputWithTokens.d.ts +326 -0
  41. package/lib-esm/TextInputWithTokens.js +217 -0
  42. package/lib-esm/Token/IssueLabelToken.d.ts +14 -0
  43. package/lib-esm/Token/IssueLabelToken.js +124 -0
  44. package/lib-esm/Token/ProfileToken.d.ts +7 -0
  45. package/lib-esm/Token/ProfileToken.js +33 -0
  46. package/lib-esm/Token/Token.d.ts +15 -0
  47. package/lib-esm/Token/Token.js +73 -0
  48. package/lib-esm/Token/TokenBase.d.ts +17 -0
  49. package/lib-esm/Token/TokenBase.js +87 -0
  50. package/lib-esm/Token/_RemoveTokenButton.d.ts +12 -0
  51. package/lib-esm/Token/_RemoveTokenButton.js +60 -0
  52. package/lib-esm/Token/_TokenTextContainer.d.ts +3 -0
  53. package/lib-esm/Token/_TokenTextContainer.js +21 -0
  54. package/lib-esm/Token/index.d.ts +3 -0
  55. package/lib-esm/Token/index.js +3 -0
  56. package/lib-esm/_UnstyledTextInput.d.ts +2 -0
  57. package/lib-esm/_UnstyledTextInput.js +7 -0
  58. package/lib-esm/index.d.ts +2 -0
  59. package/lib-esm/index.js +2 -0
  60. package/package.json +2 -1
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.isTokenInteractive = exports.defaultTokenSize = exports.tokenSizes = void 0;
7
+
8
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
9
+
10
+ var _styledSystem = require("styled-system");
11
+
12
+ var _constants = require("../constants");
13
+
14
+ var _sx = _interopRequireDefault(require("../sx"));
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ const tokenSizes = {
19
+ small: '16px',
20
+ medium: '20px',
21
+ large: '24px',
22
+ xlarge: '32px'
23
+ };
24
+ exports.tokenSizes = tokenSizes;
25
+ const defaultTokenSize = 'medium';
26
+ exports.defaultTokenSize = defaultTokenSize;
27
+
28
+ const isTokenInteractive = ({
29
+ as = 'span',
30
+ onClick,
31
+ onFocus,
32
+ tabIndex = -1
33
+ }) => Boolean(onFocus || onClick || tabIndex > -1 || ['a', 'button'].includes(as));
34
+
35
+ exports.isTokenInteractive = isTokenInteractive;
36
+ const variants = (0, _styledSystem.variant)({
37
+ prop: 'size',
38
+ variants: {
39
+ small: {
40
+ fontSize: 0,
41
+ gap: 1,
42
+ height: tokenSizes.small,
43
+ // without setting lineHeight to match height, the "x" appears vertically mis-aligned
44
+ lineHeight: tokenSizes.small,
45
+ paddingLeft: 1,
46
+ paddingRight: 1,
47
+ // need to explicitly set padding top and bottom to "0" to override default `<button>` element styles
48
+ // without setting these, the "x" appears vertically mis-aligned
49
+ paddingTop: 0,
50
+ paddingBottom: 0
51
+ },
52
+ medium: {
53
+ fontSize: 0,
54
+ gap: 1,
55
+ height: tokenSizes.medium,
56
+ lineHeight: tokenSizes.medium,
57
+ paddingLeft: 2,
58
+ paddingRight: 2,
59
+ paddingTop: 0,
60
+ paddingBottom: 0
61
+ },
62
+ large: {
63
+ fontSize: 0,
64
+ gap: 2,
65
+ height: tokenSizes.large,
66
+ lineHeight: tokenSizes.large,
67
+ paddingLeft: 2,
68
+ paddingRight: 2,
69
+ paddingTop: 0,
70
+ paddingBottom: 0
71
+ },
72
+ xlarge: {
73
+ fontSize: 1,
74
+ gap: 2,
75
+ height: tokenSizes.xlarge,
76
+ lineHeight: tokenSizes.xlarge,
77
+ paddingLeft: 3,
78
+ paddingRight: 3,
79
+ paddingTop: 0,
80
+ paddingBottom: 0
81
+ }
82
+ }
83
+ });
84
+
85
+ const TokenBase = _styledComponents.default.span.attrs(({
86
+ text,
87
+ onRemove,
88
+ onKeyDown
89
+ }) => ({
90
+ onKeyDown: event => {
91
+ onKeyDown && onKeyDown(event);
92
+
93
+ if ((event.key === 'Backspace' || event.key === 'Delete') && onRemove) {
94
+ onRemove();
95
+ }
96
+ },
97
+ 'aria-label': onRemove ? `${text}, press backspace or delete to remove` : undefined
98
+ })).withConfig({
99
+ displayName: "TokenBase",
100
+ componentId: "opajvp-0"
101
+ })(["align-items:center;border-radius:999px;cursor:", ";display:inline-flex;font-weight:", ";text-decoration:none;white-space:nowrap;", " ", ""], props => isTokenInteractive(props) ? 'pointer' : 'auto', (0, _constants.get)('fontWeights.bold'), variants, _sx.default);
102
+
103
+ TokenBase.defaultProps = {
104
+ as: 'span',
105
+ size: defaultTokenSize
106
+ };
107
+ var _default = TokenBase;
108
+ exports.default = _default;
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import { SxProp } from '../sx';
3
+ import { ComponentProps } from '../utils/types';
4
+ import { TokenSizeKeys } from './TokenBase';
5
+ interface TokenButtonProps {
6
+ borderOffset?: number;
7
+ size?: TokenSizeKeys;
8
+ isParentInteractive?: boolean;
9
+ }
10
+ declare const StyledTokenButton: import("styled-components").StyledComponent<"span", any, TokenButtonProps & SxProp, never>;
11
+ declare const RemoveTokenButton: React.FC<ComponentProps<typeof StyledTokenButton>>;
12
+ export default RemoveTokenButton;
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _octiconsReact = require("@primer/octicons-react");
11
+
12
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
+
14
+ var _styledSystem = require("styled-system");
15
+
16
+ var _constants = require("../constants");
17
+
18
+ var _sx = _interopRequireDefault(require("../sx"));
19
+
20
+ var _TokenBase = require("./TokenBase");
21
+
22
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
+
24
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
25
+
26
+ const variants = (0, _styledSystem.variant)({
27
+ prop: 'size',
28
+ variants: {
29
+ small: {
30
+ height: _TokenBase.tokenSizes.small,
31
+ width: _TokenBase.tokenSizes.small
32
+ },
33
+ medium: {
34
+ height: _TokenBase.tokenSizes.medium,
35
+ width: _TokenBase.tokenSizes.medium
36
+ },
37
+ large: {
38
+ height: _TokenBase.tokenSizes.large,
39
+ width: _TokenBase.tokenSizes.large
40
+ },
41
+ xlarge: {
42
+ height: _TokenBase.tokenSizes.xlarge,
43
+ width: _TokenBase.tokenSizes.xlarge
44
+ }
45
+ }
46
+ });
47
+
48
+ const getTokenButtonIconSize = size => parseInt(_TokenBase.tokenSizes[size || _TokenBase.defaultTokenSize], 10) * 0.75;
49
+
50
+ const StyledTokenButton = _styledComponents.default.span.withConfig({
51
+ displayName: "_RemoveTokenButton__StyledTokenButton",
52
+ componentId: "sc-14lvcw1-0"
53
+ })(["background-color:transparent;font-family:inherit;color:currentColor;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;user-select:none;appearance:none;text-decoration:none;padding:0;transform:", ";align-self:baseline;border:0;border-radius:999px;&:hover,&:focus{background-color:", ";}&:active{background-color:", ";}", " ", ""], props => `translate(${props.borderOffset}px, -${props.borderOffset}px)`, (0, _constants.get)('colors.fade.fg10'), (0, _constants.get)('colors.fade.fg15'), variants, _sx.default);
54
+
55
+ const RemoveTokenButton = ({
56
+ 'aria-label': ariaLabel,
57
+ isParentInteractive,
58
+ size,
59
+ ...rest
60
+ }) => {
61
+ delete rest.children;
62
+ return /*#__PURE__*/_react.default.createElement(StyledTokenButton, _extends({
63
+ as: isParentInteractive ? 'span' : 'button',
64
+ tabIndex: isParentInteractive ? -1 : undefined,
65
+ "aria-label": !isParentInteractive ? 'Remove token' : ariaLabel,
66
+ size: size
67
+ }, rest), /*#__PURE__*/_react.default.createElement(_octiconsReact.XIcon, {
68
+ size: getTokenButtonIconSize(size)
69
+ }));
70
+ };
71
+
72
+ RemoveTokenButton.displayName = "RemoveTokenButton";
73
+ RemoveTokenButton.defaultProps = {
74
+ size: _TokenBase.defaultTokenSize
75
+ };
76
+ var _default = RemoveTokenButton;
77
+ exports.default = _default;
@@ -0,0 +1,3 @@
1
+ import { TokenBaseProps } from './TokenBase';
2
+ declare const TokenTextContainer: import("styled-components").StyledComponent<"span", any, Partial<TokenBaseProps>, never>;
3
+ export default TokenTextContainer;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
9
+
10
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
11
+
12
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
13
+
14
+ const TokenTextContainer = (0, _styledComponents.default)('span').withConfig({
15
+ displayName: "_TokenTextContainer__TokenTextContainer",
16
+ componentId: "sc-4t2bev-0"
17
+ })(["flex-grow:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;", ""], props => {
18
+ if (props.as === 'a') {
19
+ return (0, _styledComponents.css)(["color:currentColor;text-decoration:none;"]);
20
+ }
21
+
22
+ if (props.as === 'button') {
23
+ // reset button styles, make the cursor a pointer, and add line-height
24
+ return (0, _styledComponents.css)(["background:transparent;border:none;color:inherit;font:inherit;margin:0;overflow:visible;padding:0;width:auto;-webkit-font-smoothing:inherit;-moz-osx-font-smoothing:inherit;-webkit-appearance:none;cursor:pointer;line-height:1;"]);
25
+ } // position psuedo-element above text content
26
+ // so it gets the click
27
+
28
+
29
+ if (props.as !== 'span') {
30
+ return (0, _styledComponents.css)(["&:after{content:'';position:absolute;left:0;top:0;right:0;bottom:0;}"]);
31
+ }
32
+ });
33
+ var _default = TokenTextContainer;
34
+ exports.default = _default;
@@ -0,0 +1,3 @@
1
+ export { default } from './Token';
2
+ export { default as IssueLabelToken } from './IssueLabelToken';
3
+ export { default as ProfileToken } from './ProfileToken';
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "default", {
7
+ enumerable: true,
8
+ get: function () {
9
+ return _Token.default;
10
+ }
11
+ });
12
+ Object.defineProperty(exports, "IssueLabelToken", {
13
+ enumerable: true,
14
+ get: function () {
15
+ return _IssueLabelToken.default;
16
+ }
17
+ });
18
+ Object.defineProperty(exports, "ProfileToken", {
19
+ enumerable: true,
20
+ get: function () {
21
+ return _ProfileToken.default;
22
+ }
23
+ });
24
+
25
+ var _Token = _interopRequireDefault(require("./Token"));
26
+
27
+ var _IssueLabelToken = _interopRequireDefault(require("./IssueLabelToken"));
28
+
29
+ var _ProfileToken = _interopRequireDefault(require("./ProfileToken"));
30
+
31
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -0,0 +1,2 @@
1
+ declare const UnstyledTextInput: import("styled-components").StyledComponent<"input", any, import("./sx").SxProp, never>;
2
+ export default UnstyledTextInput;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
9
+
10
+ var _sx = _interopRequireDefault(require("./sx"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ const UnstyledTextInput = _styledComponents.default.input.withConfig({
15
+ displayName: "_UnstyledTextInput__UnstyledTextInput",
16
+ componentId: "sc-1jgl33s-0"
17
+ })(["border:0;font-size:inherit;font-family:inherit;background-color:transparent;-webkit-appearance:none;color:inherit;width:100%;&:focus{outline:0;}", ";"], _sx.default);
18
+
19
+ var _default = UnstyledTextInput;
20
+ exports.default = _default;
package/lib/index.d.ts CHANGED
@@ -98,10 +98,12 @@ export { default as TabNav } from './TabNav';
98
98
  export type { TabNavProps, TabNavLinkProps } from './TabNav';
99
99
  export { default as TextInput } from './TextInput';
100
100
  export type { TextInputProps } from './TextInput';
101
+ export { default as TextInputWithTokens } from './TextInputWithTokens';
101
102
  export { default as Text } from './Text';
102
103
  export type { TextProps } from './Text';
103
104
  export { default as Timeline } from './Timeline';
104
105
  export type { TimelineProps, TimelineBadgeProps, TimelineBodyProps, TimelineBreakProps, TimelineItemsProps } from './Timeline';
106
+ export { default as Token, IssueLabelToken, ProfileToken } from './Token';
105
107
  export { default as Tooltip } from './Tooltip';
106
108
  export type { TooltipProps } from './Tooltip';
107
109
  export { default as Truncate } from './Truncate';
package/lib/index.js CHANGED
@@ -429,6 +429,12 @@ Object.defineProperty(exports, "TextInput", {
429
429
  return _TextInput.default;
430
430
  }
431
431
  });
432
+ Object.defineProperty(exports, "TextInputWithTokens", {
433
+ enumerable: true,
434
+ get: function () {
435
+ return _TextInputWithTokens.default;
436
+ }
437
+ });
432
438
  Object.defineProperty(exports, "Text", {
433
439
  enumerable: true,
434
440
  get: function () {
@@ -441,6 +447,24 @@ Object.defineProperty(exports, "Timeline", {
441
447
  return _Timeline.default;
442
448
  }
443
449
  });
450
+ Object.defineProperty(exports, "Token", {
451
+ enumerable: true,
452
+ get: function () {
453
+ return _Token.default;
454
+ }
455
+ });
456
+ Object.defineProperty(exports, "IssueLabelToken", {
457
+ enumerable: true,
458
+ get: function () {
459
+ return _Token.IssueLabelToken;
460
+ }
461
+ });
462
+ Object.defineProperty(exports, "ProfileToken", {
463
+ enumerable: true,
464
+ get: function () {
465
+ return _Token.ProfileToken;
466
+ }
467
+ });
444
468
  Object.defineProperty(exports, "Tooltip", {
445
469
  enumerable: true,
446
470
  get: function () {
@@ -582,10 +606,14 @@ var _TabNav = _interopRequireDefault(require("./TabNav"));
582
606
 
583
607
  var _TextInput = _interopRequireDefault(require("./TextInput"));
584
608
 
609
+ var _TextInputWithTokens = _interopRequireDefault(require("./TextInputWithTokens"));
610
+
585
611
  var _Text = _interopRequireDefault(require("./Text"));
586
612
 
587
613
  var _Timeline = _interopRequireDefault(require("./Timeline"));
588
614
 
615
+ var _Token = _interopRequireWildcard(require("./Token"));
616
+
589
617
  var _Tooltip = _interopRequireDefault(require("./Tooltip"));
590
618
 
591
619
  var _Truncate = _interopRequireDefault(require("./Truncate"));
@@ -1,7 +1,8 @@
1
1
  import React from 'react';
2
2
  import { GroupedListProps, ListPropsBase } from '../ActionList/List';
3
3
  import { TextInputProps } from '../TextInput';
4
- export interface FilteredActionListProps extends Partial<Omit<GroupedListProps, keyof ListPropsBase>>, ListPropsBase {
4
+ import { SxProp } from '../sx';
5
+ export interface FilteredActionListProps extends Partial<Omit<GroupedListProps, keyof ListPropsBase>>, ListPropsBase, SxProp {
5
6
  loading?: boolean;
6
7
  placeholderText: string;
7
8
  filterValue?: string;
@@ -9,7 +10,7 @@ export interface FilteredActionListProps extends Partial<Omit<GroupedListProps,
9
10
  textInputProps?: Partial<Omit<TextInputProps, 'onChange'>>;
10
11
  inputRef?: React.RefObject<HTMLInputElement>;
11
12
  }
12
- export declare function FilteredActionList({ loading, placeholderText, filterValue: externalFilterValue, onFilterChange, items, textInputProps, inputRef: providedInputRef, ...listProps }: FilteredActionListProps): JSX.Element;
13
+ export declare function FilteredActionList({ loading, placeholderText, filterValue: externalFilterValue, onFilterChange, items, textInputProps, inputRef: providedInputRef, sx, ...listProps }: FilteredActionListProps): JSX.Element;
13
14
  export declare namespace FilteredActionList {
14
15
  var displayName: string;
15
16
  }
@@ -53,6 +53,7 @@ export function FilteredActionList({
53
53
  items,
54
54
  textInputProps,
55
55
  inputRef: providedInputRef,
56
+ sx,
56
57
  ...listProps
57
58
  }) {
58
59
  const [filterValue, setInternalFilterValue] = useProvidedStateOrCreate(externalFilterValue, undefined, '');
@@ -101,7 +102,8 @@ export function FilteredActionList({
101
102
  return /*#__PURE__*/React.createElement(Box, {
102
103
  display: "flex",
103
104
  flexDirection: "column",
104
- overflow: "hidden"
105
+ overflow: "hidden",
106
+ sx: sx
105
107
  }, /*#__PURE__*/React.createElement(StyledHeader, null, /*#__PURE__*/React.createElement(TextInput, _extends({
106
108
  ref: inputRef,
107
109
  block: true,
@@ -32,11 +32,14 @@ declare const _default: React.ForwardRefExoticComponent<Pick<SelectMenuInternalP
32
32
  Divider: import("styled-components").StyledComponent<"div", any, SystemCommonProps & SxProp, never>;
33
33
  Filter: React.ForwardRefExoticComponent<Pick<{
34
34
  value?: string | undefined;
35
- } & Pick<{
35
+ } & Omit<Pick<React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "key" | keyof React.InputHTMLAttributes<HTMLInputElement>> & {
36
+ ref?: ((instance: HTMLInputElement | null) => void) | React.RefObject<HTMLInputElement> | null | undefined;
37
+ }, string | number | symbol> & {
36
38
  className?: string | undefined;
37
39
  icon?: React.ComponentType<{
38
40
  className?: string | undefined;
39
41
  }> | undefined;
42
+ wrapperRef?: React.RefObject<HTMLSpanElement> | undefined;
40
43
  } & Pick<{
41
44
  color?: string | undefined;
42
45
  maxWidth?: import("styled-system").ResponsiveValue<import("csstype").Property.MaxWidth<import("styled-system").TLengthStyledSystem>, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
@@ -315,7 +318,9 @@ declare const _default: React.ForwardRefExoticComponent<Pick<SelectMenuInternalP
315
318
  } & {
316
319
  as?: string | React.ComponentType<any> | undefined;
317
320
  forwardedAs?: string | React.ComponentType<any> | undefined;
318
- }, string | number | symbol>, "maxWidth" | "minWidth" | "width" | "theme" | "className" | "block" | "icon" | "sx" | "disabled" | "variant" | "contrast">, string | number | symbol> & React.RefAttributes<HTMLInputElement>, string | number | symbol> & React.RefAttributes<HTMLInputElement>>;
321
+ }, string | number | symbol>, "maxWidth" | "minWidth" | "width" | "theme" | "className" | "block" | "icon" | "sx" | "disabled" | "variant" | "contrast" | "wrapperRef"> & {
322
+ as?: "input" | undefined;
323
+ }, string | number | symbol> & React.RefAttributes<HTMLInputElement>>;
319
324
  Footer: import("styled-components").StyledComponent<"footer", any, SystemCommonProps & SxProp, never>;
320
325
  Item: React.ForwardRefExoticComponent<Pick<{
321
326
  as?: React.ElementType<any> | undefined;
@@ -18,7 +18,7 @@ interface SelectPanelBaseProps {
18
18
  overlayProps?: Partial<OverlayProps>;
19
19
  }
20
20
  export declare type SelectPanelProps = SelectPanelBaseProps & Omit<FilteredActionListProps, 'selectionVariant'> & Pick<AnchoredOverlayProps, 'open'> & AnchoredOverlayWrapperAnchorProps & (SelectPanelSingleSelection | SelectPanelMultiSelection);
21
- export declare function SelectPanel({ open, onOpenChange, renderAnchor, anchorRef: externalAnchorRef, placeholder, selected, onSelectedChange, filterValue: externalFilterValue, onFilterChange: externalOnFilterChange, items, textInputProps, overlayProps, ...listProps }: SelectPanelProps): JSX.Element;
21
+ export declare function SelectPanel({ open, onOpenChange, renderAnchor, anchorRef: externalAnchorRef, placeholder, selected, onSelectedChange, filterValue: externalFilterValue, onFilterChange: externalOnFilterChange, items, textInputProps, overlayProps, sx, ...listProps }: SelectPanelProps): JSX.Element;
22
22
  export declare namespace SelectPanel {
23
23
  var displayName: string;
24
24
  }
@@ -4,7 +4,6 @@ import React, { useCallback, useMemo } from 'react';
4
4
  import { FilteredActionList } from '../FilteredActionList';
5
5
  import { DropdownButton } from '../DropdownMenu';
6
6
  import { AnchoredOverlay } from '../AnchoredOverlay';
7
- import Box from '../Box';
8
7
  import { useProvidedStateOrCreate } from '../hooks/useProvidedStateOrCreate';
9
8
  import { useProvidedRefOrCreate } from '../hooks';
10
9
 
@@ -29,6 +28,7 @@ export function SelectPanel({
29
28
  items,
30
29
  textInputProps,
31
30
  overlayProps,
31
+ sx,
32
32
  ...listProps
33
33
  }) {
34
34
  const [filterValue, setInternalFilterValue] = useProvidedStateOrCreate(externalFilterValue, undefined, '');
@@ -106,11 +106,6 @@ export function SelectPanel({
106
106
  overlayProps: overlayProps,
107
107
  focusTrapSettings: focusTrapSettings,
108
108
  focusZoneSettings: focusZoneSettings
109
- }, /*#__PURE__*/React.createElement(Box, {
110
- display: "flex",
111
- flexDirection: "column",
112
- width: "100%",
113
- height: "100%"
114
109
  }, /*#__PURE__*/React.createElement(FilteredActionList, _extends({
115
110
  filterValue: filterValue,
116
111
  onFilterChange: onFilterChange
@@ -119,8 +114,14 @@ export function SelectPanel({
119
114
  items: itemsToRender,
120
115
  selectionVariant: isMultiSelectVariant(selected) ? 'multiple' : 'single',
121
116
  textInputProps: extendedTextInputProps,
122
- inputRef: inputRef
123
- }))));
117
+ inputRef: inputRef // inheriting height and maxHeight ensures that the FilteredActionList is never taller
118
+ // than the Overlay (which would break scrolling the items)
119
+ ,
120
+ sx: { ...sx,
121
+ height: 'inherit',
122
+ maxHeight: 'inherit'
123
+ }
124
+ })));
124
125
  }
125
126
  SelectPanel.displayName = "SelectPanel";
126
127
  SelectPanel.displayName = 'SelectPanel';
@@ -1,8 +1,9 @@
1
1
  import React from 'react';
2
2
  import { MaxWidthProps, MinWidthProps, WidthProps } from 'styled-system';
3
+ import { ForwardRefComponent as PolymorphicForwardRefComponent } from '@radix-ui/react-polymorphic';
3
4
  import { SxProp } from './sx';
4
5
  import { ComponentProps } from './utils/types';
5
- declare const Input: import("styled-components").StyledComponent<"input", any, {}, never>;
6
+ import UnstyledTextInput from './_UnstyledTextInput';
6
7
  declare const Wrapper: import("styled-components").StyledComponent<"span", any, {
7
8
  disabled?: boolean | undefined;
8
9
  hasIcon?: boolean | undefined;
@@ -15,8 +16,9 @@ declare type NonPassthroughProps = {
15
16
  icon?: React.ComponentType<{
16
17
  className?: string;
17
18
  }>;
19
+ wrapperRef?: React.RefObject<HTMLSpanElement>;
18
20
  } & Pick<ComponentProps<typeof Wrapper>, 'block' | 'contrast' | 'disabled' | 'sx' | 'theme' | 'width' | 'maxWidth' | 'minWidth' | 'variant'>;
19
- declare type TextInputInternalProps = NonPassthroughProps & Omit<React.ComponentPropsWithoutRef<typeof Input>, keyof NonPassthroughProps>;
20
- declare const TextInput: React.ForwardRefExoticComponent<Pick<TextInputInternalProps, string | number | symbol> & React.RefAttributes<HTMLInputElement>>;
21
+ declare type TextInputInternalProps = NonPassthroughProps & Omit<React.ComponentPropsWithoutRef<typeof UnstyledTextInput>, keyof NonPassthroughProps>;
22
+ declare const TextInput: PolymorphicForwardRefComponent<"input", TextInputInternalProps>;
21
23
  export declare type TextInputProps = ComponentProps<typeof TextInput>;
22
24
  export default TextInput;
@@ -6,6 +6,7 @@ import styled, { css } from 'styled-components';
6
6
  import { maxWidth, minWidth, variant, width } from 'styled-system';
7
7
  import { get } from './constants';
8
8
  import sx from './sx';
9
+ import UnstyledTextInput from './_UnstyledTextInput';
9
10
  const sizeVariants = variant({
10
11
  variants: {
11
12
  small: {
@@ -22,21 +23,16 @@ const sizeVariants = variant({
22
23
  }
23
24
  }
24
25
  });
25
- const Input = styled.input.withConfig({
26
- displayName: "TextInput__Input",
27
- componentId: "sc-1apmpmt-0"
28
- })(["border:0;font-size:inherit;font-family:inherit;background-color:transparent;-webkit-appearance:none;color:inherit;width:100%;&:focus{outline:0;}"]);
29
26
  const Wrapper = styled.span.withConfig({
30
27
  displayName: "TextInput__Wrapper",
31
- componentId: "sc-1apmpmt-1"
28
+ componentId: "sc-1apmpmt-0"
32
29
  })(["display:inline-flex;align-items:stretch;min-height:34px;font-size:", ";line-height:20px;color:", ";vertical-align:middle;background-repeat:no-repeat;background-position:right 8px center;border:1px solid ", ";border-radius:", ";outline:none;box-shadow:", ";", " .TextInput-icon{align-self:center;color:", ";margin:0 ", ";flex-shrink:0;}&:focus-within{border-color:", ";box-shadow:", ";}", " ", " ", " @media (min-width:", "){font-size:", ";}", " ", " ", " ", " ", ";"], get('fontSizes.1'), get('colors.fg.default'), get('colors.border.default'), get('radii.2'), get('shadows.primer.shadow.inset'), props => {
33
30
  if (props.hasIcon) {
34
31
  return css(["padding:0;"]);
35
32
  } else {
36
33
  return css(["padding:6px 12px;"]);
37
34
  }
38
- }, get('colors.fg.muted'), get('space.2'), get('colors.accent.emphasis'), get('shadows.primer.shadow.focus'), props => props.contrast && css(["background-color:", ";"], get('colors.canvas.inset')), props => props.disabled && css(["color:", ";background-color:", ";border-color:", ";"], get('colors.fg.muted'), get('colors.input.disabledBg'), get('colors.border.default')), props => props.block && css(["display:block;width:100%;"]), get('breakpoints.1'), get('fontSizes.1'), width, minWidth, maxWidth, sizeVariants, sx); // Props that are not passed through to Input:
39
-
35
+ }, get('colors.fg.muted'), get('space.2'), get('colors.accent.emphasis'), get('shadows.primer.shadow.focus'), props => props.contrast && css(["background-color:", ";"], get('colors.canvas.inset')), props => props.disabled && css(["color:", ";background-color:", ";border-color:", ";"], get('colors.fg.muted'), get('colors.input.disabledBg'), get('colors.border.default')), props => props.block && css(["display:block;width:100%;"]), get('breakpoints.1'), get('fontSizes.1'), width, minWidth, maxWidth, sizeVariants, sx);
40
36
  // using forwardRef is important so that other components (ex. SelectMenu) can autofocus the input
41
37
  const TextInput = /*#__PURE__*/React.forwardRef(({
42
38
  icon: IconComponent,
@@ -50,6 +46,7 @@ const TextInput = /*#__PURE__*/React.forwardRef(({
50
46
  minWidth: minWidthProp,
51
47
  maxWidth: maxWidthProp,
52
48
  variant: variantProp,
49
+ wrapperRef,
53
50
  ...inputProps
54
51
  }, ref) => {
55
52
  // this class is necessary to style FilterSearch, plz no touchy!
@@ -65,10 +62,11 @@ const TextInput = /*#__PURE__*/React.forwardRef(({
65
62
  width: widthProp,
66
63
  minWidth: minWidthProp,
67
64
  maxWidth: maxWidthProp,
68
- variant: variantProp
65
+ variant: variantProp,
66
+ ref: wrapperRef
69
67
  }, IconComponent && /*#__PURE__*/React.createElement(IconComponent, {
70
68
  className: "TextInput-icon"
71
- }), /*#__PURE__*/React.createElement(Input, _extends({
69
+ }), /*#__PURE__*/React.createElement(UnstyledTextInput, _extends({
72
70
  ref: ref,
73
71
  disabled: disabled
74
72
  }, inputProps)));