@primer/components 32.1.1-rc.b4502a34 → 33.0.0-rc.b3e4ccee

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 (75) hide show
  1. package/CHANGELOG.md +11 -1
  2. package/contributor-docs/CONTRIBUTING.md +14 -58
  3. package/dist/browser.esm.js +104 -108
  4. package/dist/browser.esm.js.map +1 -1
  5. package/dist/browser.umd.js +104 -108
  6. package/dist/browser.umd.js.map +1 -1
  7. package/docs/content/BranchName.md +6 -5
  8. package/docs/content/Details.md +4 -8
  9. package/docs/content/Heading.md +5 -10
  10. package/docs/content/Label.md +6 -7
  11. package/docs/content/ProgressBar.mdx +7 -6
  12. package/docs/content/Text.md +0 -6
  13. package/docs/content/status.mdx +1 -1
  14. package/docs/content/system-props.mdx +1 -1
  15. package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +1 -1
  16. package/lib/Avatar.d.ts +1 -2
  17. package/lib/Avatar.js +1 -1
  18. package/lib/BranchName.d.ts +1 -2
  19. package/lib/BranchName.js +1 -1
  20. package/lib/Details.d.ts +1 -2
  21. package/lib/Details.js +1 -3
  22. package/lib/Dropdown.d.ts +2 -66
  23. package/lib/Heading.d.ts +1 -2
  24. package/lib/Heading.js +1 -6
  25. package/lib/ProgressBar.d.ts +16 -11
  26. package/lib/ProgressBar.js +6 -10
  27. package/lib/Spinner.d.ts +1 -2
  28. package/lib/Spinner.js +1 -3
  29. package/lib/__tests__/Avatar.test.js +4 -2
  30. package/lib/__tests__/Avatar.types.test.d.ts +3 -0
  31. package/lib/__tests__/Avatar.types.test.js +31 -0
  32. package/lib/__tests__/BranchName.types.test.d.ts +3 -0
  33. package/lib/__tests__/BranchName.types.test.js +28 -0
  34. package/lib/__tests__/Details.types.test.d.ts +3 -0
  35. package/lib/__tests__/Details.types.test.js +28 -0
  36. package/lib/__tests__/Heading.test.js +63 -30
  37. package/lib/__tests__/Heading.types.test.d.ts +3 -0
  38. package/lib/__tests__/Heading.types.test.js +28 -0
  39. package/lib-esm/Avatar.d.ts +1 -2
  40. package/lib-esm/Avatar.js +2 -2
  41. package/lib-esm/BranchName.d.ts +1 -2
  42. package/lib-esm/BranchName.js +2 -2
  43. package/lib-esm/Details.d.ts +1 -2
  44. package/lib-esm/Details.js +1 -2
  45. package/lib-esm/Dropdown.d.ts +2 -66
  46. package/lib-esm/Heading.d.ts +1 -2
  47. package/lib-esm/Heading.js +2 -6
  48. package/lib-esm/ProgressBar.d.ts +16 -11
  49. package/lib-esm/ProgressBar.js +7 -11
  50. package/lib-esm/Spinner.d.ts +1 -2
  51. package/lib-esm/Spinner.js +1 -2
  52. package/lib-esm/__tests__/Avatar.test.js +4 -2
  53. package/lib-esm/__tests__/Avatar.types.test.d.ts +3 -0
  54. package/lib-esm/__tests__/Avatar.types.test.js +16 -0
  55. package/lib-esm/__tests__/BranchName.types.test.d.ts +3 -0
  56. package/lib-esm/__tests__/BranchName.types.test.js +13 -0
  57. package/lib-esm/__tests__/Details.types.test.d.ts +3 -0
  58. package/lib-esm/__tests__/Details.types.test.js +13 -0
  59. package/lib-esm/__tests__/Heading.test.js +62 -30
  60. package/lib-esm/__tests__/Heading.types.test.d.ts +3 -0
  61. package/lib-esm/__tests__/Heading.types.test.js +13 -0
  62. package/package.json +1 -1
  63. package/src/Avatar.tsx +2 -4
  64. package/src/BranchName.tsx +3 -3
  65. package/src/Details.tsx +1 -5
  66. package/src/Heading.tsx +2 -9
  67. package/src/ProgressBar.tsx +11 -10
  68. package/src/Spinner.tsx +1 -3
  69. package/src/__tests__/Avatar.test.tsx +1 -1
  70. package/src/__tests__/Avatar.types.test.tsx +11 -0
  71. package/src/__tests__/BranchName.types.test.tsx +11 -0
  72. package/src/__tests__/Details.types.test.tsx +11 -0
  73. package/src/__tests__/Heading.test.tsx +71 -25
  74. package/src/__tests__/Heading.types.test.tsx +11 -0
  75. package/stats.html +1 -1
@@ -12,6 +12,8 @@ var _jestAxe = require("jest-axe");
12
12
 
13
13
  require("babel-polyfill");
14
14
 
15
+ var _ThemeProvider = _interopRequireDefault(require("../ThemeProvider"));
16
+
15
17
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
18
 
17
19
  expect.extend(_jestAxe.toHaveNoViolations);
@@ -56,54 +58,85 @@ describe('Heading', () => {
56
58
  (0, _react2.cleanup)();
57
59
  });
58
60
  it('respects fontWeight', () => {
59
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
60
- fontWeight: "bold",
61
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
61
62
  theme: theme
62
- }))).toHaveStyleRule('font-weight', theme.fontWeights.bold);
63
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
64
- fontWeight: "normal",
63
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
64
+ sx: {
65
+ fontWeight: 'bold'
66
+ }
67
+ })))).toHaveStyleRule('font-weight', theme.fontWeights.bold);
68
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
65
69
  theme: theme
66
- }))).toHaveStyleRule('font-weight', theme.fontWeights.normal);
67
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
68
- fontWeight: "semibold",
70
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
71
+ sx: {
72
+ fontWeight: 'normal'
73
+ }
74
+ })))).toHaveStyleRule('font-weight', theme.fontWeights.normal);
75
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
69
76
  theme: theme
70
- }))).toHaveStyleRule('font-weight', theme.fontWeights.semibold);
71
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
72
- fontWeight: "light",
77
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
78
+ sx: {
79
+ fontWeight: 'semibold'
80
+ }
81
+ })))).toHaveStyleRule('font-weight', theme.fontWeights.semibold);
82
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
73
83
  theme: theme
74
- }))).toHaveStyleRule('font-weight', theme.fontWeights.light);
84
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
85
+ sx: {
86
+ fontWeight: 'light'
87
+ }
88
+ })))).toHaveStyleRule('font-weight', theme.fontWeights.light);
75
89
  });
76
90
  it('respects lineHeight', () => {
77
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
78
- lineHeight: "normal",
91
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
79
92
  theme: theme
80
- }))).toHaveStyleRule('line-height', String(theme.lineHeights.normal));
81
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
82
- lineHeight: "condensed",
93
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
94
+ sx: {
95
+ lineHeight: 'normal'
96
+ }
97
+ })))).toHaveStyleRule('line-height', String(theme.lineHeights.normal));
98
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
83
99
  theme: theme
84
- }))).toHaveStyleRule('line-height', String(theme.lineHeights.condensed));
85
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
86
- lineHeight: "condensedUltra",
100
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
101
+ sx: {
102
+ lineHeight: 'condensed'
103
+ }
104
+ })))).toHaveStyleRule('line-height', String(theme.lineHeights.condensed));
105
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
87
106
  theme: theme
88
- }))).toHaveStyleRule('line-height', String(theme.lineHeights.condensedUltra));
107
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
108
+ sx: {
109
+ lineHeight: 'condensedUltra'
110
+ }
111
+ })))).toHaveStyleRule('line-height', String(theme.lineHeights.condensedUltra));
89
112
  });
90
113
  it('respects fontFamily="mono"', () => {
91
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
92
- fontFamily: "mono",
114
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
93
115
  theme: theme
94
- }))).toHaveStyleRule('font-family', theme.fonts.mono);
116
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
117
+ sx: {
118
+ fontFamily: 'mono'
119
+ }
120
+ })))).toHaveStyleRule('font-family', theme.fonts.mono);
95
121
  });
96
122
  it('renders fontSize', () => {
97
123
  for (const fontSize of theme.fontSizes) {
98
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
99
- fontSize: fontSize,
124
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
100
125
  theme: theme
101
- }))).toHaveStyleRule('font-size', `${fontSize}`);
126
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
127
+ sx: {
128
+ fontSize
129
+ }
130
+ })))).toHaveStyleRule('font-size', `${fontSize}`);
102
131
  }
103
132
  });
104
133
  it('respects the "fontStyle" prop', () => {
105
- expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_.Heading, {
106
- fontStyle: "italic"
107
- }))).toHaveStyleRule('font-style', 'italic');
134
+ expect((0, _testing.render)( /*#__PURE__*/_react.default.createElement(_ThemeProvider.default, {
135
+ theme: theme
136
+ }, /*#__PURE__*/_react.default.createElement(_.Heading, {
137
+ sx: {
138
+ fontStyle: 'italic'
139
+ }
140
+ })))).toHaveStyleRule('font-style', 'italic');
108
141
  });
109
142
  });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ export declare function shouldAcceptCallWithNoProps(): JSX.Element;
3
+ export declare function shouldNotAcceptSystemProps(): JSX.Element;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.shouldAcceptCallWithNoProps = shouldAcceptCallWithNoProps;
7
+ exports.shouldNotAcceptSystemProps = shouldNotAcceptSystemProps;
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _Heading = _interopRequireDefault(require("../Heading"));
12
+
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+
15
+ function shouldAcceptCallWithNoProps() {
16
+ return /*#__PURE__*/_react.default.createElement(_Heading.default, null);
17
+ }
18
+
19
+ shouldAcceptCallWithNoProps.displayName = "shouldAcceptCallWithNoProps";
20
+
21
+ function shouldNotAcceptSystemProps() {
22
+ // @ts-expect-error system props should not be accepted
23
+ return /*#__PURE__*/_react.default.createElement(_Heading.default, {
24
+ backgroundColor: "thistle"
25
+ });
26
+ }
27
+
28
+ shouldNotAcceptSystemProps.displayName = "shouldNotAcceptSystemProps";
@@ -1,4 +1,3 @@
1
- import { SystemCommonProps } from './constants';
2
1
  import { SxProp } from './sx';
3
2
  import { ComponentProps } from './utils/types';
4
3
  declare const Avatar: import("styled-components").StyledComponent<"img", any, {
@@ -10,6 +9,6 @@ declare const Avatar: import("styled-components").StyledComponent<"img", any, {
10
9
  src: string;
11
10
  /** Provide alt text when the Avatar is used without the user's name next to it. */
12
11
  alt?: string | undefined;
13
- } & SystemCommonProps & SxProp, never>;
12
+ } & SxProp, never>;
14
13
  export declare type AvatarProps = ComponentProps<typeof Avatar>;
15
14
  export default Avatar;
package/lib-esm/Avatar.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import styled from 'styled-components';
2
- import { COMMON, get } from './constants';
2
+ import { get } from './constants';
3
3
  import sx from './sx';
4
4
 
5
5
  function getBorderRadius({
@@ -19,7 +19,7 @@ const Avatar = styled.img.attrs(props => ({
19
19
  })).withConfig({
20
20
  displayName: "Avatar",
21
21
  componentId: "sc-1waaaky-0"
22
- })(["display:inline-block;overflow:hidden;line-height:", ";vertical-align:middle;border-radius:", ";", ";", ""], get('lineHeights.condensedUltra'), props => getBorderRadius(props), COMMON, sx);
22
+ })(["display:inline-block;overflow:hidden;line-height:", ";vertical-align:middle;border-radius:", ";", ""], get('lineHeights.condensedUltra'), props => getBorderRadius(props), sx);
23
23
  Avatar.defaultProps = {
24
24
  size: 20,
25
25
  alt: '',
@@ -1,6 +1,5 @@
1
- import { SystemCommonProps } from './constants';
2
1
  import { SxProp } from './sx';
3
2
  import { ComponentProps } from './utils/types';
4
- declare const BranchName: import("styled-components").StyledComponent<"a", any, SystemCommonProps & SxProp, never>;
3
+ declare const BranchName: import("styled-components").StyledComponent<"a", any, SxProp, never>;
5
4
  export declare type BranchNameProps = ComponentProps<typeof BranchName>;
6
5
  export default BranchName;
@@ -1,8 +1,8 @@
1
1
  import styled from 'styled-components';
2
- import { COMMON, get } from './constants';
2
+ import { get } from './constants';
3
3
  import sx from './sx';
4
4
  const BranchName = styled.a.withConfig({
5
5
  displayName: "BranchName",
6
6
  componentId: "sc-167ouzm-0"
7
- })(["display:inline-block;padding:2px 6px;font-size:", ";font-family:", ";color:", ";background-color:", ";border-radius:", ";", ";", ";"], get('fontSizes.0'), get('fonts.mono'), get('colors.fg.muted'), get('colors.accent.subtle'), get('radii.2'), COMMON, sx);
7
+ })(["display:inline-block;padding:2px 6px;font-size:", ";font-family:", ";color:", ";background-color:", ";border-radius:", ";", ";"], get('fontSizes.0'), get('fonts.mono'), get('colors.fg.muted'), get('colors.accent.subtle'), get('radii.2'), sx);
8
8
  export default BranchName;
@@ -1,6 +1,5 @@
1
- import { SystemCommonProps } from './constants';
2
1
  import { SxProp } from './sx';
3
2
  import { ComponentProps } from './utils/types';
4
- declare const Details: import("styled-components").StyledComponent<"details", any, SystemCommonProps & SxProp, never>;
3
+ declare const Details: import("styled-components").StyledComponent<"details", any, SxProp, never>;
5
4
  export declare type DetailsProps = ComponentProps<typeof Details>;
6
5
  export default Details;
@@ -1,9 +1,8 @@
1
1
  import styled from 'styled-components';
2
- import { COMMON } from './constants';
3
2
  import sx from './sx';
4
3
  const Details = styled.details.withConfig({
5
4
  displayName: "Details",
6
5
  componentId: "ssy9qz-0"
7
- })(["& > summary{list-style:none;}& > summary::-webkit-details-marker{display:none;}", " ", ";"], COMMON, sx);
6
+ })(["& > summary{list-style:none;}& > summary::-webkit-details-marker{display:none;}", ";"], sx);
8
7
  Details.displayName = 'Details';
9
8
  export default Details;
@@ -15,46 +15,14 @@ export declare type DropdownMenuProps = ComponentProps<typeof DropdownMenu>;
15
15
  export declare type DropdownItemProps = ComponentProps<typeof DropdownItem>;
16
16
  declare const _default: {
17
17
  ({ children, className, ...rest }: {
18
- backgroundColor?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
19
- color?: (string & import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>>) | undefined;
20
- display?: import("styled-system").ResponsiveValue<import("csstype").Property.Display, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
21
- marginBottom?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
22
- marginLeft?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
23
- marginRight?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
24
- marginTop?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
25
- opacity?: import("styled-system").ResponsiveValue<import("csstype").Property.Opacity, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
26
- paddingBottom?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
27
- paddingLeft?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
28
- paddingRight?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
29
- paddingTop?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
18
+ color?: string | undefined;
30
19
  translate?: "yes" | "no" | undefined;
31
- margin?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
32
- padding?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
33
20
  hidden?: boolean | undefined;
34
21
  children?: React.ReactNode;
35
22
  ref?: ((instance: HTMLElement | null) => void) | React.RefObject<HTMLElement> | null | undefined;
36
- p?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
37
23
  slot?: string | undefined;
38
24
  style?: React.CSSProperties | undefined;
39
25
  title?: string | undefined;
40
- bg?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
41
- m?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
42
- mt?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
43
- mr?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
44
- mb?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
45
- ml?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
46
- mx?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
47
- marginX?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
48
- my?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
49
- marginY?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
50
- pt?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
51
- pr?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
52
- pb?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
53
- pl?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
54
- px?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
55
- paddingX?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
56
- py?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
57
- paddingY?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
58
26
  open?: boolean | undefined;
59
27
  role?: React.AriaRole | undefined;
60
28
  sx?: import("./sx").BetterSystemStyleObject | undefined;
@@ -313,46 +281,14 @@ declare const _default: {
313
281
  theme?: any;
314
282
  }): JSX.Element;
315
283
  defaultProps: Partial<{
316
- backgroundColor?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
317
- color?: (string & import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>>) | undefined;
318
- display?: import("styled-system").ResponsiveValue<import("csstype").Property.Display, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
319
- marginBottom?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
320
- marginLeft?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
321
- marginRight?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
322
- marginTop?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
323
- opacity?: import("styled-system").ResponsiveValue<import("csstype").Property.Opacity, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
324
- paddingBottom?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
325
- paddingLeft?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
326
- paddingRight?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
327
- paddingTop?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
284
+ color?: string | undefined;
328
285
  translate?: "yes" | "no" | undefined;
329
- margin?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
330
- padding?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
331
286
  hidden?: boolean | undefined;
332
287
  children?: React.ReactNode;
333
288
  ref?: ((instance: HTMLElement | null) => void) | React.RefObject<HTMLElement> | null | undefined;
334
- p?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
335
289
  slot?: string | undefined;
336
290
  style?: React.CSSProperties | undefined;
337
291
  title?: string | undefined;
338
- bg?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
339
- m?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
340
- mt?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
341
- mr?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
342
- mb?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
343
- ml?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
344
- mx?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
345
- marginX?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
346
- my?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
347
- marginY?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
348
- pt?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
349
- pr?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
350
- pb?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
351
- pl?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
352
- px?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
353
- paddingX?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
354
- py?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
355
- paddingY?: import("styled-system").ResponsiveValue<string | number | symbol, Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>> | undefined;
356
292
  open?: boolean | undefined;
357
293
  role?: React.AriaRole | undefined;
358
294
  sx?: import("./sx").BetterSystemStyleObject | undefined;
@@ -1,6 +1,5 @@
1
- import { SystemCommonProps, SystemTypographyProps } from './constants';
2
1
  import { SxProp } from './sx';
3
2
  import { ComponentProps } from './utils/types';
4
- declare const Heading: import("styled-components").StyledComponent<"h2", any, SystemTypographyProps & SystemCommonProps & SxProp, never>;
3
+ declare const Heading: import("styled-components").StyledComponent<"h2", any, SxProp, never>;
5
4
  export declare type HeadingProps = ComponentProps<typeof Heading>;
6
5
  export default Heading;
@@ -1,12 +1,8 @@
1
1
  import styled from 'styled-components';
2
- import { COMMON, get, TYPOGRAPHY } from './constants';
2
+ import { get } from './constants';
3
3
  import sx from './sx';
4
- import theme from './theme';
5
4
  const Heading = styled.h2.withConfig({
6
5
  displayName: "Heading",
7
6
  componentId: "sc-1cjoo9h-0"
8
- })(["font-weight:", ";font-size:", ";margin:0;", ";", ";", ";"], get('fontWeights.bold'), get('fontSizes.5'), TYPOGRAPHY, COMMON, sx);
9
- Heading.defaultProps = {
10
- theme
11
- };
7
+ })(["font-weight:", ";font-size:", ";margin:0;", ";"], get('fontWeights.bold'), get('fontSizes.5'), sx);
12
8
  export default Heading;
@@ -1,17 +1,22 @@
1
1
  /// <reference types="react" />
2
2
  import { WidthProps } from 'styled-system';
3
- import { SystemCommonProps } from './constants';
4
3
  import { SxProp } from './sx';
5
- import { ComponentProps } from './utils/types';
6
- declare const Bar: import("styled-components").StyledComponent<"span", any, {
7
- progress?: string | number | undefined;
8
- } & SystemCommonProps, never>;
9
- declare const ProgressContainer: import("styled-components").StyledComponent<"span", any, {
10
- inline?: boolean | undefined;
11
- barSize?: "small" | "default" | "large" | undefined;
12
- } & WidthProps<Required<import("styled-system").Theme<import("styled-system").TLengthStyledSystem>>, import("csstype").Property.Width<import("styled-system").TLengthStyledSystem>> & SystemCommonProps & SxProp, never>;
13
- export declare type ProgressBarProps = ComponentProps<typeof ProgressContainer> & ComponentProps<typeof Bar>;
14
- declare function ProgressBar({ progress, bg, theme, ...rest }: ProgressBarProps): JSX.Element;
4
+ declare type ProgressProp = {
5
+ progress?: string | number;
6
+ };
7
+ declare const sizeMap: {
8
+ small: string;
9
+ large: string;
10
+ default: string;
11
+ };
12
+ declare type StyledProgressContainerProps = {
13
+ inline?: boolean;
14
+ barSize?: keyof typeof sizeMap;
15
+ } & WidthProps & SxProp;
16
+ export declare type ProgressBarProps = {
17
+ bg: string;
18
+ } & StyledProgressContainerProps & ProgressProp;
19
+ declare function ProgressBar({ progress, bg, ...rest }: ProgressBarProps): JSX.Element;
15
20
  declare namespace ProgressBar {
16
21
  var defaultProps: {
17
22
  bg: string;
@@ -1,14 +1,12 @@
1
- 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); }
2
-
3
1
  import React from 'react';
4
2
  import styled from 'styled-components';
5
3
  import { width } from 'styled-system';
6
- import { COMMON, get } from './constants';
4
+ import { get } from './constants';
7
5
  import sx from './sx';
8
6
  const Bar = styled.span.withConfig({
9
7
  displayName: "ProgressBar__Bar",
10
8
  componentId: "sc-1tiva13-0"
11
- })(["width:", ";", ""], props => props.progress ? `${props.progress}%` : 0, COMMON);
9
+ })(["width:", ";", ";"], props => props.progress ? `${props.progress}%` : 0, sx);
12
10
  const sizeMap = {
13
11
  small: '5px',
14
12
  large: '10px',
@@ -17,20 +15,18 @@ const sizeMap = {
17
15
  const ProgressContainer = styled.span.withConfig({
18
16
  displayName: "ProgressBar__ProgressContainer",
19
17
  componentId: "sc-1tiva13-1"
20
- })(["display:", ";overflow:hidden;background-color:", ";border-radius:", ";height:", ";", " ", " ", ";"], props => props.inline ? 'inline-flex' : 'flex', get('colors.border.default'), get('radii.1'), props => sizeMap[props.barSize || 'default'], COMMON, width, sx);
18
+ })(["display:", ";overflow:hidden;background-color:", ";border-radius:", ";height:", ";", " ", ";"], props => props.inline ? 'inline-flex' : 'flex', get('colors.border.default'), get('radii.1'), props => sizeMap[props.barSize || 'default'], width, sx);
21
19
 
22
20
  function ProgressBar({
23
21
  progress,
24
22
  bg,
25
- theme,
26
23
  ...rest
27
24
  }) {
28
- return /*#__PURE__*/React.createElement(ProgressContainer, _extends({
29
- theme: theme
30
- }, rest), /*#__PURE__*/React.createElement(Bar, {
25
+ return /*#__PURE__*/React.createElement(ProgressContainer, rest, /*#__PURE__*/React.createElement(Bar, {
31
26
  progress: progress,
32
- bg: bg,
33
- theme: theme
27
+ sx: {
28
+ bg
29
+ }
34
30
  }));
35
31
  }
36
32
 
@@ -1,5 +1,4 @@
1
1
  /// <reference types="react" />
2
- import { SystemCommonProps } from './constants';
3
2
  import { SxProp } from './sx';
4
3
  import { ComponentProps } from './utils/types';
5
4
  declare const sizeMap: {
@@ -12,6 +11,6 @@ export interface SpinnerInternalProps {
12
11
  size?: keyof typeof sizeMap;
13
12
  }
14
13
  declare function Spinner({ size: sizeKey, ...props }: SpinnerInternalProps): JSX.Element;
15
- declare const StyledSpinner: import("styled-components").StyledComponent<typeof Spinner, any, SystemCommonProps & SxProp, never>;
14
+ declare const StyledSpinner: import("styled-components").StyledComponent<typeof Spinner, any, SxProp, never>;
16
15
  export declare type SpinnerProps = ComponentProps<typeof StyledSpinner>;
17
16
  export default StyledSpinner;
@@ -2,7 +2,6 @@ function _extends() { _extends = Object.assign || function (target) { for (var i
2
2
 
3
3
  import React from 'react';
4
4
  import styled from 'styled-components';
5
- import { COMMON } from './constants';
6
5
  import sx from './sx';
7
6
  const sizeMap = {
8
7
  small: '16px',
@@ -41,6 +40,6 @@ Spinner.displayName = "Spinner";
41
40
  const StyledSpinner = styled(Spinner).withConfig({
42
41
  displayName: "Spinner__StyledSpinner",
43
42
  componentId: "sc-14tspit-0"
44
- })(["@keyframes rotate-keyframes{100%{transform:rotate(360deg);}}animation:rotate-keyframes 1s linear infinite;", " ", ""], COMMON, sx);
43
+ })(["@keyframes rotate-keyframes{100%{transform:rotate(360deg);}}animation:rotate-keyframes 1s linear infinite;", ""], sx);
45
44
  StyledSpinner.displayName = 'Spinner';
46
45
  export default StyledSpinner;
@@ -48,9 +48,11 @@ describe('Avatar', () => {
48
48
  });
49
49
  it('respects margin props', () => {
50
50
  expect(render( /*#__PURE__*/React.createElement(Avatar, {
51
- m: 2,
52
51
  src: "primer.png",
53
- alt: ""
52
+ alt: "",
53
+ sx: {
54
+ m: 2
55
+ }
54
56
  }))).toHaveStyleRule('margin', px(theme.space[2]));
55
57
  });
56
58
  });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ export declare function shouldAcceptCallWithNoProps(): JSX.Element;
3
+ export declare function shouldNotAcceptSystemProps(): JSX.Element;
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import Avatar from '../Avatar';
3
+ export function shouldAcceptCallWithNoProps() {
4
+ return /*#__PURE__*/React.createElement(Avatar, {
5
+ src: "https://avatars.githubusercontent.com/primer"
6
+ });
7
+ }
8
+ shouldAcceptCallWithNoProps.displayName = "shouldAcceptCallWithNoProps";
9
+ export function shouldNotAcceptSystemProps() {
10
+ // @ts-expect-error system props should not be accepted
11
+ return /*#__PURE__*/React.createElement(Avatar, {
12
+ src: "https://avatars.githubusercontent.com/primer",
13
+ backgroundColor: "thistle"
14
+ });
15
+ }
16
+ shouldNotAcceptSystemProps.displayName = "shouldNotAcceptSystemProps";
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ export declare function shouldAcceptCallWithNoProps(): JSX.Element;
3
+ export declare function shouldNotAcceptSystemProps(): JSX.Element;
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import BranchName from '../BranchName';
3
+ export function shouldAcceptCallWithNoProps() {
4
+ return /*#__PURE__*/React.createElement(BranchName, null);
5
+ }
6
+ shouldAcceptCallWithNoProps.displayName = "shouldAcceptCallWithNoProps";
7
+ export function shouldNotAcceptSystemProps() {
8
+ // @ts-expect-error system props should not be accepted
9
+ return /*#__PURE__*/React.createElement(BranchName, {
10
+ backgroundColor: "thistle"
11
+ });
12
+ }
13
+ shouldNotAcceptSystemProps.displayName = "shouldNotAcceptSystemProps";
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ export declare function shouldAcceptCallWithNoProps(): JSX.Element;
3
+ export declare function shouldNotAcceptSystemProps(): JSX.Element;
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import Details from '../Details';
3
+ export function shouldAcceptCallWithNoProps() {
4
+ return /*#__PURE__*/React.createElement(Details, null);
5
+ }
6
+ shouldAcceptCallWithNoProps.displayName = "shouldAcceptCallWithNoProps";
7
+ export function shouldNotAcceptSystemProps() {
8
+ // @ts-expect-error system props should not be accepted
9
+ return /*#__PURE__*/React.createElement(Details, {
10
+ backgroundColor: "thistle"
11
+ });
12
+ }
13
+ shouldNotAcceptSystemProps.displayName = "shouldNotAcceptSystemProps";