@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.
- package/CHANGELOG.md +7 -1
- package/dist/browser.esm.js +721 -654
- package/dist/browser.esm.js.map +1 -1
- package/dist/browser.umd.js +411 -344
- package/dist/browser.umd.js.map +1 -1
- package/lib/FilteredActionList/FilteredActionList.d.ts +3 -2
- package/lib/FilteredActionList/FilteredActionList.js +3 -1
- package/lib/SelectMenu/SelectMenu.d.ts +7 -2
- package/lib/SelectPanel/SelectPanel.d.ts +1 -1
- package/lib/SelectPanel/SelectPanel.js +9 -11
- package/lib/TextInput.d.ts +5 -3
- package/lib/TextInput.js +8 -10
- package/lib/TextInputWithTokens.d.ts +326 -0
- package/lib/TextInputWithTokens.js +244 -0
- package/lib/Token/IssueLabelToken.d.ts +14 -0
- package/lib/Token/IssueLabelToken.js +144 -0
- package/lib/Token/ProfileToken.d.ts +7 -0
- package/lib/Token/ProfileToken.js +53 -0
- package/lib/Token/Token.d.ts +15 -0
- package/lib/Token/Token.js +94 -0
- package/lib/Token/TokenBase.d.ts +17 -0
- package/lib/Token/TokenBase.js +108 -0
- package/lib/Token/_RemoveTokenButton.d.ts +12 -0
- package/lib/Token/_RemoveTokenButton.js +77 -0
- package/lib/Token/_TokenTextContainer.d.ts +3 -0
- package/lib/Token/_TokenTextContainer.js +34 -0
- package/lib/Token/index.d.ts +3 -0
- package/lib/Token/index.js +31 -0
- package/lib/_UnstyledTextInput.d.ts +2 -0
- package/lib/_UnstyledTextInput.js +20 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +28 -0
- package/lib-esm/FilteredActionList/FilteredActionList.d.ts +3 -2
- package/lib-esm/FilteredActionList/FilteredActionList.js +3 -1
- package/lib-esm/SelectMenu/SelectMenu.d.ts +7 -2
- package/lib-esm/SelectPanel/SelectPanel.d.ts +1 -1
- package/lib-esm/SelectPanel/SelectPanel.js +9 -8
- package/lib-esm/TextInput.d.ts +5 -3
- package/lib-esm/TextInput.js +7 -9
- package/lib-esm/TextInputWithTokens.d.ts +326 -0
- package/lib-esm/TextInputWithTokens.js +217 -0
- package/lib-esm/Token/IssueLabelToken.d.ts +14 -0
- package/lib-esm/Token/IssueLabelToken.js +124 -0
- package/lib-esm/Token/ProfileToken.d.ts +7 -0
- package/lib-esm/Token/ProfileToken.js +33 -0
- package/lib-esm/Token/Token.d.ts +15 -0
- package/lib-esm/Token/Token.js +73 -0
- package/lib-esm/Token/TokenBase.d.ts +17 -0
- package/lib-esm/Token/TokenBase.js +87 -0
- package/lib-esm/Token/_RemoveTokenButton.d.ts +12 -0
- package/lib-esm/Token/_RemoveTokenButton.js +60 -0
- package/lib-esm/Token/_TokenTextContainer.d.ts +3 -0
- package/lib-esm/Token/_TokenTextContainer.js +21 -0
- package/lib-esm/Token/index.d.ts +3 -0
- package/lib-esm/Token/index.js +3 -0
- package/lib-esm/_UnstyledTextInput.d.ts +2 -0
- package/lib-esm/_UnstyledTextInput.js +7 -0
- package/lib-esm/index.d.ts +2 -0
- package/lib-esm/index.js +2 -0
- 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,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,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,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
|
-
|
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"
|
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';
|
package/lib-esm/TextInput.d.ts
CHANGED
@@ -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
|
-
|
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
|
20
|
-
declare const TextInput:
|
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;
|
package/lib-esm/TextInput.js
CHANGED
@@ -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-
|
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);
|
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(
|
69
|
+
}), /*#__PURE__*/React.createElement(UnstyledTextInput, _extends({
|
72
70
|
ref: ref,
|
73
71
|
disabled: disabled
|
74
72
|
}, inputProps)));
|