@workday/canvas-kit-preview-react 14.0.0-alpha.1219-next.0 → 14.0.0-alpha.1224-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/dist/commonjs/avatar/lib/Avatar.js +12 -12
  2. package/dist/commonjs/avatar/lib/AvatarImage.js +1 -1
  3. package/dist/commonjs/avatar/lib/AvatarName.js +1 -1
  4. package/dist/commonjs/avatar/lib/BaseAvatar.js +12 -12
  5. package/dist/commonjs/color-picker/lib/ColorPicker.js +1 -1
  6. package/dist/commonjs/color-picker/lib/parts/ColorReset.js +1 -1
  7. package/dist/commonjs/color-picker/lib/parts/SwatchBook.js +1 -1
  8. package/dist/commonjs/divider/lib/Divider.js +1 -1
  9. package/dist/commonjs/index.d.ts +3 -0
  10. package/dist/commonjs/index.d.ts.map +1 -1
  11. package/dist/commonjs/index.js +5 -0
  12. package/dist/commonjs/information-highlight/lib/InformationHighlight.js +7 -7
  13. package/dist/commonjs/information-highlight/lib/parts/Body.js +1 -1
  14. package/dist/commonjs/information-highlight/lib/parts/Heading.js +1 -1
  15. package/dist/commonjs/information-highlight/lib/parts/Link.js +1 -1
  16. package/dist/commonjs/loading-sparkles/lib/LoadingSparkles.js +2 -2
  17. package/dist/commonjs/multi-select/lib/MultiSelectInput.js +3 -3
  18. package/dist/commonjs/pill/index.d.ts +1 -1
  19. package/dist/commonjs/pill/index.d.ts.map +1 -1
  20. package/dist/commonjs/pill/index.js +1 -3
  21. package/dist/commonjs/pill/lib/Pill.d.ts +44 -143
  22. package/dist/commonjs/pill/lib/Pill.d.ts.map +1 -1
  23. package/dist/commonjs/pill/lib/Pill.js +18 -23
  24. package/dist/commonjs/pill/lib/PillAvatar.js +1 -1
  25. package/dist/commonjs/pill/lib/PillCount.js +1 -1
  26. package/dist/commonjs/pill/lib/PillIcon.js +1 -1
  27. package/dist/commonjs/pill/lib/PillIconButton.d.ts.map +1 -1
  28. package/dist/commonjs/pill/lib/PillIconButton.js +1 -1
  29. package/dist/commonjs/pill/lib/PillLabel.js +1 -1
  30. package/dist/commonjs/radio/lib/RadioGroup.js +3 -3
  31. package/dist/commonjs/radio/lib/RadioLabel.js +1 -1
  32. package/dist/commonjs/radio/lib/RadioText.js +4 -4
  33. package/dist/commonjs/radio/lib/StyledRadioButton.js +5 -5
  34. package/dist/commonjs/segmented-control/lib/SegmentedControlItem.js +16 -16
  35. package/dist/commonjs/segmented-control/lib/SegmentedControlList.js +4 -4
  36. package/dist/commonjs/side-panel/lib/SidePanel.js +7 -7
  37. package/dist/commonjs/side-panel/lib/SidePanelToggleButton.js +11 -11
  38. package/dist/commonjs/status-indicator/lib/StatusIndicator.js +15 -15
  39. package/dist/commonjs/status-indicator/lib/StatusIndicatorLabel.js +1 -1
  40. package/dist/commonjs/text-input/lib/TextInputField.js +3 -3
  41. package/dist/commonjs/version.d.ts +2 -0
  42. package/dist/commonjs/version.d.ts.map +1 -0
  43. package/dist/commonjs/version.js +4 -0
  44. package/dist/es6/avatar/lib/Avatar.js +12 -12
  45. package/dist/es6/avatar/lib/AvatarImage.js +1 -1
  46. package/dist/es6/avatar/lib/AvatarName.js +1 -1
  47. package/dist/es6/avatar/lib/BaseAvatar.js +12 -12
  48. package/dist/es6/color-picker/lib/ColorPicker.js +1 -1
  49. package/dist/es6/color-picker/lib/parts/ColorReset.js +1 -1
  50. package/dist/es6/color-picker/lib/parts/SwatchBook.js +1 -1
  51. package/dist/es6/divider/lib/Divider.js +1 -1
  52. package/dist/es6/index.d.ts +3 -0
  53. package/dist/es6/index.d.ts.map +1 -1
  54. package/dist/es6/index.js +3 -0
  55. package/dist/es6/information-highlight/lib/InformationHighlight.js +7 -7
  56. package/dist/es6/information-highlight/lib/parts/Body.js +1 -1
  57. package/dist/es6/information-highlight/lib/parts/Heading.js +1 -1
  58. package/dist/es6/information-highlight/lib/parts/Link.js +1 -1
  59. package/dist/es6/loading-sparkles/lib/LoadingSparkles.js +2 -2
  60. package/dist/es6/multi-select/lib/MultiSelectInput.js +3 -3
  61. package/dist/es6/pill/index.d.ts +1 -1
  62. package/dist/es6/pill/index.d.ts.map +1 -1
  63. package/dist/es6/pill/index.js +1 -1
  64. package/dist/es6/pill/lib/Pill.d.ts +44 -143
  65. package/dist/es6/pill/lib/Pill.d.ts.map +1 -1
  66. package/dist/es6/pill/lib/Pill.js +18 -23
  67. package/dist/es6/pill/lib/PillAvatar.js +1 -1
  68. package/dist/es6/pill/lib/PillCount.js +1 -1
  69. package/dist/es6/pill/lib/PillIcon.js +1 -1
  70. package/dist/es6/pill/lib/PillIconButton.d.ts.map +1 -1
  71. package/dist/es6/pill/lib/PillIconButton.js +1 -1
  72. package/dist/es6/pill/lib/PillLabel.js +1 -1
  73. package/dist/es6/radio/lib/RadioGroup.js +3 -3
  74. package/dist/es6/radio/lib/RadioLabel.js +1 -1
  75. package/dist/es6/radio/lib/RadioText.js +4 -4
  76. package/dist/es6/radio/lib/StyledRadioButton.js +5 -5
  77. package/dist/es6/segmented-control/lib/SegmentedControlItem.js +16 -16
  78. package/dist/es6/segmented-control/lib/SegmentedControlList.js +4 -4
  79. package/dist/es6/side-panel/lib/SidePanel.js +7 -7
  80. package/dist/es6/side-panel/lib/SidePanelToggleButton.js +11 -11
  81. package/dist/es6/status-indicator/lib/StatusIndicator.js +15 -15
  82. package/dist/es6/status-indicator/lib/StatusIndicatorLabel.js +1 -1
  83. package/dist/es6/text-input/lib/TextInputField.js +3 -3
  84. package/dist/es6/version.d.ts +2 -0
  85. package/dist/es6/version.d.ts.map +1 -0
  86. package/dist/es6/version.js +1 -0
  87. package/index.ts +3 -0
  88. package/package.json +7 -5
  89. package/pill/index.ts +1 -1
  90. package/pill/lib/Pill.tsx +97 -115
  91. package/pill/lib/PillIconButton.tsx +9 -2
  92. package/version.ts +1 -0
package/pill/lib/Pill.tsx CHANGED
@@ -18,7 +18,7 @@ export interface PillProps extends BoxProps {
18
18
  * Defines what kind of pill to render stylistically and its interaction states
19
19
  * @default 'default'
20
20
  */
21
- variant?: 'default' | 'readOnly' | 'removable';
21
+ variant?: 'readOnly' | 'removable';
22
22
  /**
23
23
  * Determines the max width of the pill. If the pill text is longer than the max width,
24
24
  * text will be truncated and a tooltip will show the rest of the content when hovered over
@@ -48,25 +48,42 @@ export const pillStencil = createStencil({
48
48
  height: system.space.x6,
49
49
  position: 'relative',
50
50
  gap: system.space.x1,
51
- maxWidth: maxWidth,
52
- [buttonStencil.vars.background]: system.color.bg.alt.default,
53
- [buttonStencil.vars.border]: system.color.border.input.default,
54
- [buttonStencil.vars.label]: system.color.text.strong,
55
- [systemIconStencil.vars.color]: system.color.icon.default,
56
- [pillCountStencil.vars.borderColor]: 'transparent',
51
+ maxWidth,
57
52
  whiteSpace: 'nowrap',
58
53
  textOverflow: 'ellipsis',
59
54
  overflow: 'hidden',
55
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
56
+ [buttonStencil.vars.border]: system.color.border.input.default,
57
+ [buttonStencil.vars.label]: system.color.fg.strong,
58
+ [systemIconStencil.vars.color]: 'currentColor',
59
+ [pillCountStencil.vars.borderColor]: 'transparent',
60
+
60
61
  '&:has(span)': {
61
62
  display: 'flex',
62
63
  lineHeight: system.lineHeight.subtext.large, // ensure correct line height
63
64
  },
65
+ '&:hover, &.hover': {
66
+ [buttonStencil.vars.background]: system.color.bg.alt.strong,
67
+ [buttonStencil.vars.border]: system.color.border.input.strong,
68
+ [buttonStencil.vars.label]: system.color.fg.strong,
69
+ [systemIconStencil.vars.color]: 'currentColor',
70
+ [pillCountStencil.vars.backgroundColor]: system.color.bg.muted.softer,
71
+ [pillCountStencil.vars.borderColor]: 'transparent',
72
+ },
73
+ '&:active, &.active': {
74
+ [buttonStencil.vars.background]: system.color.bg.alt.stronger,
75
+ [buttonStencil.vars.border]: system.color.border.input.strong,
76
+ [buttonStencil.vars.label]: system.color.fg.strong,
77
+ [systemIconStencil.vars.color]: 'currentColor',
78
+ [pillCountStencil.vars.backgroundColor]: system.color.bg.muted.softer,
79
+ [pillCountStencil.vars.borderColor]: 'transparent',
80
+ },
64
81
  '&:focus-visible, &.focus': {
65
- [buttonStencil.vars.background]: system.color.bg.alt.soft,
82
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
66
83
  [buttonStencil.vars.border]: system.color.border.primary.default,
67
- [buttonStencil.vars.label]: system.color.text.strong,
68
- [systemIconStencil.vars.color]: system.color.icon.strong,
84
+ [buttonStencil.vars.label]: system.color.fg.strong,
69
85
  borderColor: system.color.border.primary.default,
86
+ [systemIconStencil.vars.color]: 'currentColor',
70
87
  [pillCountStencil.vars.borderColor]: system.color.border.primary.default,
71
88
 
72
89
  ...focusRing({
@@ -77,74 +94,56 @@ export const pillStencil = createStencil({
77
94
  separation: 1,
78
95
  }),
79
96
  },
80
- '&:hover, &.hover': {
81
- [buttonStencil.vars.background]: system.color.bg.alt.strong,
82
- [buttonStencil.vars.border]: system.color.border.input.strong,
83
- [buttonStencil.vars.label]: system.color.text.strong,
84
- [systemIconStencil.vars.color]: system.color.icon.strong,
85
- },
86
- '&:active, &.active': {
87
- [buttonStencil.vars.background]: system.color.bg.alt.stronger,
88
- [buttonStencil.vars.border]: system.color.border.input.strong,
89
- [buttonStencil.vars.label]: system.color.text.strong,
90
- [systemIconStencil.vars.color]: system.color.icon.strong,
91
- [pillCountStencil.vars.backgroundColor]: system.color.bg.alt.stronger,
92
- [pillCountStencil.vars.borderColor]: 'transparent',
93
- },
94
97
  '&:disabled, &.disabled': {
95
- [buttonStencil.vars.background]: system.color.bg.alt.softer,
98
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
96
99
  [buttonStencil.vars.border]: system.color.border.input.disabled,
97
- [buttonStencil.vars.label]: system.color.text.disabled,
98
- [buttonStencil.vars.opacity]: '1',
99
- [systemIconStencil.vars.color]: system.color.icon.soft,
100
- [pillCountStencil.vars.backgroundColor]: system.color.bg.alt.default,
100
+ [buttonStencil.vars.label]: system.color.fg.disabled,
101
+ [systemIconStencil.vars.color]: 'currentColor',
102
+ [pillCountStencil.vars.backgroundColor]: system.color.bg.alt.strong,
101
103
  [pillCountStencil.vars.borderColor]: 'transparent',
102
104
  },
103
105
  }),
104
- });
105
-
106
- export const removeablePillStencil = createStencil({
107
- extends: pillStencil,
108
- base: {
109
- '&:focus-visible, &.focus': {
110
- [buttonStencil.vars.background]: system.color.bg.alt.soft,
111
- [buttonStencil.vars.border]: system.color.border.input.default,
112
- [buttonStencil.vars.label]: system.color.text.strong,
113
- boxShadow: 'none',
114
- },
115
- '&:hover, &.hover': {
116
- [buttonStencil.vars.background]: system.color.bg.alt.soft,
117
- },
118
- '&:active, &.active': {
119
- [buttonStencil.vars.background]: system.color.bg.alt.stronger,
120
- },
121
- '&:disabled, &.disabled': {
122
- [buttonStencil.vars.background]: system.color.bg.alt.softer,
123
- [systemIconStencil.vars.color]: system.color.icon.soft,
124
- },
125
- cursor: 'default',
126
- overflow: 'revert', // override BaseButton overflow styles so the click target exists outside the pill for removable
127
- position: 'relative',
128
- },
129
- });
130
-
131
- export const readyOnlyPillStencil = createStencil({
132
- extends: pillStencil,
133
- base: {
134
- border: `${px2rem(1)} solid ${cssVar(system.color.border.input.default)}`,
135
- cursor: 'default',
136
- [buttonStencil.vars.background]: 'transparent',
137
- '&:hover, &.hover': {
138
- [buttonStencil.vars.background]: 'transparent',
139
- },
140
- '&:focus-visible, &.focus': {
141
- [buttonStencil.vars.background]: 'transparent',
142
- },
143
- '&:active, &.active': {
144
- [buttonStencil.vars.background]: 'transparent',
145
- },
146
- '&:disabled, &.disabled': {
147
- [buttonStencil.vars.background]: 'transparent',
106
+ modifiers: {
107
+ variant: {
108
+ readOnly: {
109
+ border: `${px2rem(1)} solid ${system.color.border.container}`,
110
+ cursor: 'default',
111
+ [buttonStencil.vars.background]: 'transparent',
112
+ '&:hover, &.hover': {
113
+ borderColor: system.color.border.container,
114
+ [buttonStencil.vars.background]: 'transparent',
115
+ },
116
+ '&:focus-visible, &.focus': {
117
+ [buttonStencil.vars.background]: 'transparent',
118
+ },
119
+ '&:active, &.active': {
120
+ [buttonStencil.vars.background]: 'transparent',
121
+ },
122
+ '&:disabled, &.disabled': {
123
+ [buttonStencil.vars.background]: 'transparent',
124
+ },
125
+ },
126
+ removable: {
127
+ '&:focus-visible, &.focus': {
128
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
129
+ [buttonStencil.vars.border]: system.color.border.input.default,
130
+ [buttonStencil.vars.label]: system.color.fg.strong,
131
+ boxShadow: 'none',
132
+ },
133
+ '&:hover, &.hover': {
134
+ [buttonStencil.vars.background]: system.color.bg.alt.strong,
135
+ },
136
+ '&:active, &.active': {
137
+ [buttonStencil.vars.background]: system.color.bg.alt.stronger,
138
+ },
139
+ '&:disabled, &.disabled': {
140
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
141
+ [systemIconStencil.vars.color]: 'currentColor',
142
+ },
143
+ cursor: 'default',
144
+ overflow: 'revert', // override BaseButton overflow styles so the click target exists outside the pill for removable
145
+ position: 'relative',
146
+ },
148
147
  },
149
148
  },
150
149
  });
@@ -256,48 +255,31 @@ export const Pill = createContainer('button')({
256
255
  */
257
256
  Label: PillLabel,
258
257
  },
259
- })<PillProps>(({variant = 'default', maxWidth = 200, children, ...elemProps}, Element, model) => {
258
+ })<PillProps>(({variant, maxWidth = 200, children, ...elemProps}, Element, model) => {
260
259
  const maxWidthCSSValue = typeof maxWidth === 'number' ? px2rem(maxWidth) : maxWidth;
261
- return (
262
- <>
263
- {variant === 'readOnly' && (
264
- <Box
265
- as={Element !== 'button' ? Element : 'span'}
266
- id={model.state.id}
267
- {...mergeStyles(
268
- elemProps,
269
- readyOnlyPillStencil({
270
- maxWidth: maxWidthCSSValue,
271
- })
272
- )}
273
- >
274
- <PillLabel>{children}</PillLabel>
275
- </Box>
276
- )}
277
- {variant === 'default' && (
278
- <Element
279
- disabled={model.state.disabled}
280
- {...mergeStyles(elemProps, [
281
- model.state.disabled ? 'disabled' : undefined,
282
- pillStencil({
283
- maxWidth: maxWidthCSSValue,
284
- }),
285
- ])}
286
- >
287
- {children}
288
- </Element>
289
- )}
290
- {variant === 'removable' && (
291
- <Box
292
- as={Element !== 'button' ? Element : 'span'}
293
- {...mergeStyles(elemProps, [
294
- model.state.disabled ? 'disabled' : undefined,
295
- removeablePillStencil({maxWidth: maxWidthCSSValue}),
296
- ])}
297
- >
298
- {children}
299
- </Box>
300
- )}
301
- </>
260
+
261
+ const isReadOnly = variant === 'readOnly';
262
+
263
+ return variant?.match(/^(readOnly|removable)$/) ? (
264
+ <Box
265
+ as={Element !== 'button' ? Element : 'span'}
266
+ id={isReadOnly ? model.state.id : undefined}
267
+ {...mergeStyles(elemProps, [
268
+ model.state.disabled ? 'disabled' : undefined,
269
+ pillStencil({maxWidth: maxWidthCSSValue, variant}),
270
+ ])}
271
+ >
272
+ {isReadOnly ? <PillLabel>{children}</PillLabel> : children}
273
+ </Box>
274
+ ) : (
275
+ <Element
276
+ disabled={model.state.disabled}
277
+ {...mergeStyles(elemProps, [
278
+ model.state.disabled ? 'disabled' : undefined,
279
+ pillStencil({maxWidth: maxWidthCSSValue}),
280
+ ])}
281
+ >
282
+ {children}
283
+ </Element>
302
284
  );
303
285
  });
@@ -26,8 +26,8 @@ export const pillIconButtonStencil = createStencil({
26
26
  overflow: 'visible',
27
27
  flex: '0 0 auto',
28
28
  [buttonStencil.vars.border]: system.color.border.transparent,
29
- [buttonStencil.vars.background]: system.color.bg.alt.soft,
30
- [systemIconStencil.vars.color]: system.color.icon.default,
29
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
30
+ [systemIconStencil.vars.color]: system.color.fg.strong,
31
31
  [systemIconStencil.vars.size]: system.space.x6,
32
32
  '::after': {
33
33
  content: '""',
@@ -42,15 +42,22 @@ export const pillIconButtonStencil = createStencil({
42
42
 
43
43
  '&:focus-visible, &.focus': {
44
44
  [buttonStencil.vars.border]: system.color.border.transparent,
45
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
45
46
  ...focusRing({
46
47
  innerColor: system.color.border.transparent,
47
48
  }),
48
49
  },
49
50
  '&:hover, &.hover': {
50
51
  [buttonStencil.vars.border]: system.color.border.transparent,
52
+ [buttonStencil.vars.background]: system.color.bg.alt.strong,
53
+ },
54
+ '&:active, &.active': {
55
+ [buttonStencil.vars.border]: system.color.border.transparent,
56
+ [buttonStencil.vars.background]: system.color.bg.alt.stronger,
51
57
  },
52
58
  '&:disabled, &.disabled': {
53
59
  [buttonStencil.vars.border]: system.color.border.transparent,
60
+ [buttonStencil.vars.background]: system.color.bg.alt.default,
54
61
  },
55
62
  },
56
63
  });
package/version.ts ADDED
@@ -0,0 +1 @@
1
+ export const version: string = '%VERSION%';