@charcoal-ui/react 5.0.0-beta.2 → 5.0.0-beta.4

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 (53) hide show
  1. package/dist/_lib/createDivComponent.d.ts +1 -1
  2. package/dist/_lib/useForwardedRef.d.ts.map +1 -1
  3. package/dist/components/Button/index.d.ts +1 -12
  4. package/dist/components/Button/index.d.ts.map +1 -1
  5. package/dist/components/Checkbox/CheckboxWithLabel.d.ts +3 -3
  6. package/dist/components/Checkbox/CheckboxWithLabel.d.ts.map +1 -1
  7. package/dist/components/Checkbox/index.d.ts +6 -6
  8. package/dist/components/Clickable/index.d.ts +1 -1
  9. package/dist/components/Clickable/index.d.ts.map +1 -1
  10. package/dist/components/DropdownSelector/ListItem/index.d.ts +1 -1
  11. package/dist/components/DropdownSelector/ListItem/index.d.ts.map +1 -1
  12. package/dist/components/DropdownSelector/MenuItem/index.d.ts.map +1 -1
  13. package/dist/components/DropdownSelector/Popover/usePreventScroll.d.ts.map +1 -1
  14. package/dist/components/DropdownSelector/index.d.ts.map +1 -1
  15. package/dist/components/IconButton/index.d.ts +1 -1
  16. package/dist/components/IconButton/index.d.ts.map +1 -1
  17. package/dist/components/Modal/ModalPlumbing.d.ts +3 -3
  18. package/dist/components/Modal/index.d.ts +8 -8
  19. package/dist/components/Modal/index.d.ts.map +1 -1
  20. package/dist/components/MultiSelect/index.d.ts +6 -6
  21. package/dist/components/MultiSelect/index.d.ts.map +1 -1
  22. package/dist/components/Radio/RadioGroup/index.d.ts.map +1 -1
  23. package/dist/components/Radio/RadioInput/index.d.ts.map +1 -1
  24. package/dist/components/Radio/index.d.ts +3 -3
  25. package/dist/components/Radio/index.d.ts.map +1 -1
  26. package/dist/components/Switch/SwitchWithLabel.d.ts +3 -3
  27. package/dist/components/Switch/SwitchWithLabel.d.ts.map +1 -1
  28. package/dist/components/TagItem/index.d.ts +5 -5
  29. package/dist/components/TagItem/index.d.ts.map +1 -1
  30. package/dist/components/TextArea/index.d.ts +11 -11
  31. package/dist/components/TextArea/index.d.ts.map +1 -1
  32. package/dist/components/TextField/AssistiveText/index.d.ts +1 -1
  33. package/dist/components/TextField/index.d.ts +11 -11
  34. package/dist/components/TextField/index.d.ts.map +1 -1
  35. package/dist/core/SSRProvider.d.ts +1 -1
  36. package/dist/core/themeHelper.d.ts.map +1 -1
  37. package/dist/index.cjs +1 -1
  38. package/dist/index.cjs.map +1 -1
  39. package/dist/index.js +1 -1
  40. package/dist/index.js.map +1 -1
  41. package/package.json +8 -17
  42. package/src/_lib/useForwardedRef.tsx +1 -0
  43. package/src/components/Button/index.story.tsx +4 -4
  44. package/src/components/DropdownSelector/DropdownMenuItem/index.tsx +1 -1
  45. package/src/components/DropdownSelector/ListItem/index.tsx +1 -1
  46. package/src/components/DropdownSelector/MenuItem/index.tsx +2 -1
  47. package/src/components/DropdownSelector/Popover/usePreventScroll.tsx +1 -0
  48. package/src/components/DropdownSelector/index.tsx +1 -0
  49. package/src/components/Modal/index.story.tsx +4 -12
  50. package/src/components/MultiSelect/index.test.tsx +4 -4
  51. package/src/components/MultiSelect/index.tsx +1 -1
  52. package/src/components/Radio/RadioInput/index.tsx +1 -0
  53. package/src/components/TagItem/index.tsx +4 -4
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@charcoal-ui/react",
3
- "version": "5.0.0-beta.2",
3
+ "version": "5.0.0-beta.4",
4
4
  "license": "Apache-2.0",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",
@@ -26,7 +26,6 @@
26
26
  "*.css"
27
27
  ],
28
28
  "devDependencies": {
29
- "@babel/core": "^7.23.9",
30
29
  "@react-types/dialog": "^3.5.15",
31
30
  "@react-types/switch": "^3.1.2",
32
31
  "@storybook/addon-actions": "^8.0.5",
@@ -42,15 +41,9 @@
42
41
  "@vitejs/plugin-react": "^4.3.1",
43
42
  "autoprefixer": "^10.4.19",
44
43
  "jsdom": "^24.1.0",
45
- "npm-run-all": "^4.1.5",
46
44
  "react": "^18.3.1",
47
45
  "react-dom": "^18.3.1",
48
- "react-router-dom": "^6.2.1",
49
- "rimraf": "^3.0.2",
50
- "tsup": "^6.5.0",
51
- "typescript": "^4.9.5",
52
- "vitest": "^2.0.1",
53
- "@charcoal-ui/esbuild-plugin-styled-components": "5.0.0-beta.2"
46
+ "react-router-dom": "^6.2.1"
54
47
  },
55
48
  "dependencies": {
56
49
  "@react-aria/button": "^3.9.1",
@@ -68,14 +61,13 @@
68
61
  "react-spring": "^9.0.0",
69
62
  "react-stately": "^3.26.0",
70
63
  "warning": "^4.0.3",
71
- "@charcoal-ui/foundation": "5.0.0-beta.2",
72
- "@charcoal-ui/icons": "5.0.0-beta.2",
73
- "@charcoal-ui/theme": "5.0.0-beta.2",
74
- "@charcoal-ui/utils": "5.0.0-beta.2"
64
+ "@charcoal-ui/icons": "5.0.0-beta.4",
65
+ "@charcoal-ui/foundation": "5.0.0-beta.4",
66
+ "@charcoal-ui/theme": "5.0.0-beta.4",
67
+ "@charcoal-ui/utils": "5.0.0-beta.4"
75
68
  },
76
69
  "peerDependencies": {
77
- "react": ">=17.0.0",
78
- "styled-components": ">=5.1.1"
70
+ "react": ">=17.0.0"
79
71
  },
80
72
  "files": [
81
73
  "src",
@@ -91,9 +83,8 @@
91
83
  },
92
84
  "gitHead": "e1ece2e43901ae667afdd5c178040607d939dcd5",
93
85
  "scripts": {
94
- "build": "run-p --print-label 'build:*'",
86
+ "build": "run-s --print-label 'build:*'",
95
87
  "build:tsdown": "tsdown",
96
- "build-old:tsup": "tsup",
97
88
  "build:dts": "tsc --project tsconfig.build.json --pretty --emitDeclarationOnly",
98
89
  "typecheck": "tsc --project tsconfig.build.json --pretty --noEmit",
99
90
  "clean": "rimraf dist .tsbuildinfo",
@@ -8,6 +8,7 @@ export function useForwardedRef<T>(ref: React.ForwardedRef<T>) {
8
8
  if (typeof ref === 'function') {
9
9
  ref(innerRef.current)
10
10
  } else {
11
+ // eslint-disable-next-line react-compiler/react-compiler
11
12
  ref.current = innerRef.current
12
13
  }
13
14
  })
@@ -143,23 +143,23 @@ export const AriaDisabled: StoryObj<typeof Button> = {
143
143
  <h2>{`disabled={true}`}</h2>
144
144
  <div style={{ display: 'flex', gap: '8px' }}>
145
145
  <div>
146
- <Button disabled={true}>属性なし</Button>
146
+ <Button disabled>属性なし</Button>
147
147
  </div>
148
148
  <div>
149
- <Button aria-disabled disabled={true}>
149
+ <Button aria-disabled disabled>
150
150
  aria-disabled
151
151
  </Button>
152
152
  </div>
153
153
  <div>
154
154
  <Button
155
155
  aria-disabled="true"
156
- disabled={true}
156
+ disabled
157
157
  >{`aria-disabled="true"`}</Button>
158
158
  </div>
159
159
  <div>
160
160
  <Button
161
161
  aria-disabled="false"
162
- disabled={true}
162
+ disabled
163
163
  >{`aria-disabled="false"`}</Button>
164
164
  </div>
165
165
  </div>
@@ -27,7 +27,7 @@ export default function DropdownMenuItem(props: DropdownMenuItemProps) {
27
27
  className="charcoal-dropdown-selector-menu-item"
28
28
  data-selected={isSelected}
29
29
  >
30
- {props.children}
30
+ {children}
31
31
  </span>
32
32
  </MenuItem>
33
33
  )
@@ -19,7 +19,7 @@ const ListItem = forwardRef(function ListItem<T extends React.ElementType>(
19
19
  ) {
20
20
  const Component = useMemo(() => as ?? 'li', [as])
21
21
  const classNames = useClassNames('charcoal-list-item', className)
22
- return <Component className={classNames} ref={ref} {...props}></Component>
22
+ return <Component className={classNames} ref={ref} {...props} />
23
23
  }) as <T extends React.ElementType = 'li'>(p: ListItemProps<T>) => JSX.Element
24
24
 
25
25
  export default ListItem
@@ -14,11 +14,12 @@ export type MenuItemProps<T extends React.ElementType = 'li'> = {
14
14
  const MenuItem = forwardRef(function MenuItem<
15
15
  T extends React.ElementType = 'li'
16
16
  >(
17
- { className, value, disabled, ...props }: MenuItemProps<T>,
17
+ { className: _, value, disabled, ...props }: MenuItemProps<T>,
18
18
  ref: ForwardedRef<HTMLLIElement>
19
19
  ) {
20
20
  const [handleKeyDown, setContextValue] = useMenuItemHandleKeyDown(value)
21
21
  return (
22
+ // @ts-expect-error TODO: fix mismatch between MenuItemProps and ListItemProps
22
23
  <ListItem
23
24
  {...props}
24
25
  ref={ref}
@@ -9,6 +9,7 @@ export function usePreventScroll(
9
9
  if (isOpen && element) {
10
10
  const defaultPaddingRight = element.style.paddingRight
11
11
  const defaultOverflow = element.style.overflow
12
+ // eslint-disable-next-line react-compiler/react-compiler
12
13
  element.style.paddingRight = `${
13
14
  window.innerWidth - element.clientWidth
14
15
  }px`
@@ -95,6 +95,7 @@ export default function DropdownSelector({
95
95
  })}
96
96
  </select>
97
97
  </div>
98
+ {/* eslint-disable-next-line jsx-a11y/role-supports-aria-props */}
98
99
  <button
99
100
  className="charcoal-dropdown-selector-button"
100
101
  aria-labelledby={labelId}
@@ -68,7 +68,7 @@ const M = (props: ModalProps) => {
68
68
  possimus fugiat aspernatur, numquam, commodi repellat.
69
69
  </StyledModalText>
70
70
  <ModalAlign>
71
- <TextField showLabel label="Name" placeholder="Nagisa"></TextField>
71
+ <TextField showLabel label="Name" placeholder="Nagisa" />
72
72
  </ModalAlign>
73
73
  <ModalAlign>
74
74
  <TextField
@@ -76,7 +76,7 @@ const M = (props: ModalProps) => {
76
76
  showLabel
77
77
  label="Country"
78
78
  placeholder="Tokyo"
79
- ></TextField>
79
+ />
80
80
  </ModalAlign>
81
81
  <ModalAlign>
82
82
  <DropdownSelector
@@ -161,18 +161,10 @@ export const FullBottomSheet: StoryObj<typeof Modal> = {
161
161
  possimus fugiat aspernatur, numquam, commodi repellat.
162
162
  </StyledModalText>
163
163
  <ModalAlign>
164
- <TextField
165
- showLabel
166
- label="Name"
167
- placeholder="Nagisa"
168
- ></TextField>
164
+ <TextField showLabel label="Name" placeholder="Nagisa" />
169
165
  </ModalAlign>
170
166
  <ModalAlign>
171
- <TextField
172
- showLabel
173
- label="Country"
174
- placeholder="Tokyo"
175
- ></TextField>
167
+ <TextField showLabel label="Country" placeholder="Tokyo" />
176
168
  </ModalAlign>
177
169
  </ModalVStack>
178
170
  <ModalButtons>
@@ -137,7 +137,7 @@ describe('MultiSelect', () => {
137
137
  let allOptions: HTMLInputElement[]
138
138
 
139
139
  beforeEach(() => {
140
- render(<TestComponent selected={['option1']} parentDisabled={true} />)
140
+ render(<TestComponent selected={['option1']} parentDisabled />)
141
141
 
142
142
  option1 = screen.getByDisplayValue('option1')
143
143
  option2 = screen.getByDisplayValue('option2')
@@ -157,7 +157,7 @@ describe('MultiSelect', () => {
157
157
  let allOptions: HTMLInputElement[]
158
158
 
159
159
  beforeEach(() => {
160
- render(<TestComponent selected={['option1']} readonly={true} />)
160
+ render(<TestComponent selected={['option1']} readonly />)
161
161
 
162
162
  option1 = screen.getByDisplayValue('option1')
163
163
  option2 = screen.getByDisplayValue('option2')
@@ -177,7 +177,7 @@ describe('MultiSelect', () => {
177
177
  let allOptions: HTMLInputElement[]
178
178
 
179
179
  beforeEach(() => {
180
- render(<TestComponent selected={['option1']} invalid={true} />)
180
+ render(<TestComponent selected={['option1']} invalid />)
181
181
 
182
182
  option1 = screen.getByDisplayValue('option1')
183
183
  option2 = screen.getByDisplayValue('option2')
@@ -197,7 +197,7 @@ describe('MultiSelect', () => {
197
197
  let option2: HTMLInputElement
198
198
 
199
199
  beforeEach(() => {
200
- render(<TestComponent selected={[]} firstOptionDisabled={true} />)
200
+ render(<TestComponent selected={[]} firstOptionDisabled />)
201
201
 
202
202
  option1 = screen.getByDisplayValue('option1')
203
203
  option2 = screen.getByDisplayValue('option2')
@@ -74,7 +74,7 @@ const MultiSelect = forwardRef<HTMLInputElement, MultiSelectProps>(
74
74
  className="charcoal-multi-select-overlay"
75
75
  data-overlay={variant === 'overlay'}
76
76
  aria-invalid={invalid}
77
- aria-hidden={true}
77
+ aria-hidden
78
78
  >
79
79
  <Icon name="24/Check" unsafe-non-guideline-scale={16 / 24} />
80
80
  </div>
@@ -26,6 +26,7 @@ const RadioInput = forwardRef<HTMLInputElement, RadioInputProps>(
26
26
  const classNames = useClassNames('charcoal-radio-input', className)
27
27
 
28
28
  return (
29
+ // eslint-disable-next-line jsx-a11y/role-supports-aria-props
29
30
  <input
30
31
  className={classNames}
31
32
  ref={ref}
@@ -5,9 +5,9 @@ import { useClassNames } from '../../_lib/useClassNames'
5
5
 
6
6
  import './index.css'
7
7
 
8
- const sizeMap = {
9
- S: 32,
10
- M: 40,
8
+ type SizeMap = {
9
+ S: 32
10
+ M: 40
11
11
  }
12
12
 
13
13
  export type TagItemProps<T extends React.ElementType = 'button'> = {
@@ -16,7 +16,7 @@ export type TagItemProps<T extends React.ElementType = 'button'> = {
16
16
  bgColor?: string
17
17
  bgImage?: string
18
18
  status?: 'default' | 'active' | 'inactive'
19
- size?: keyof typeof sizeMap
19
+ size?: keyof SizeMap
20
20
  /**
21
21
  * The component used for root element.
22
22
  * @type T extends React.ElementType = 'button'