@charcoal-ui/react 4.0.0-beta.4 → 4.0.0-beta.6

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 (141) hide show
  1. package/README.md +1 -1
  2. package/dist/_lib/useClassNames.d.ts +2 -2
  3. package/dist/_lib/useClassNames.d.ts.map +1 -1
  4. package/dist/components/Checkbox/CheckboxInput/index.d.ts +11 -0
  5. package/dist/components/Checkbox/CheckboxInput/index.d.ts.map +1 -0
  6. package/dist/components/Checkbox/CheckboxWithLabel.d.ts +9 -0
  7. package/dist/components/Checkbox/CheckboxWithLabel.d.ts.map +1 -0
  8. package/dist/components/Checkbox/index.d.ts +9 -7
  9. package/dist/components/Checkbox/index.d.ts.map +1 -1
  10. package/dist/components/Clickable/index.d.ts +10 -13
  11. package/dist/components/Clickable/index.d.ts.map +1 -1
  12. package/dist/components/DropdownSelector/index.d.ts.map +1 -1
  13. package/dist/components/FieldLabel/index.d.ts +1 -0
  14. package/dist/components/FieldLabel/index.d.ts.map +1 -1
  15. package/dist/components/IconButton/index.d.ts +7 -5
  16. package/dist/components/IconButton/index.d.ts.map +1 -1
  17. package/dist/components/LoadingSpinner/index.d.ts +1 -0
  18. package/dist/components/LoadingSpinner/index.d.ts.map +1 -1
  19. package/dist/components/Modal/Dialog/index.d.ts +6 -24
  20. package/dist/components/Modal/Dialog/index.d.ts.map +1 -1
  21. package/dist/components/Modal/ModalPlumbing.d.ts +10 -3
  22. package/dist/components/Modal/ModalPlumbing.d.ts.map +1 -1
  23. package/dist/components/Modal/index.d.ts +5 -1
  24. package/dist/components/Modal/index.d.ts.map +1 -1
  25. package/dist/components/Radio/index.d.ts +3 -5
  26. package/dist/components/Radio/index.d.ts.map +1 -1
  27. package/dist/components/SegmentedControl/index.d.ts +1 -0
  28. package/dist/components/SegmentedControl/index.d.ts.map +1 -1
  29. package/dist/components/Switch/SwitchInput/index.d.ts +9 -0
  30. package/dist/components/Switch/SwitchInput/index.d.ts.map +1 -0
  31. package/dist/components/Switch/SwitchWithLabel.d.ts +9 -0
  32. package/dist/components/Switch/SwitchWithLabel.d.ts.map +1 -0
  33. package/dist/components/Switch/index.d.ts +4 -15
  34. package/dist/components/Switch/index.d.ts.map +1 -1
  35. package/dist/components/TagItem/index.d.ts +14 -15
  36. package/dist/components/TagItem/index.d.ts.map +1 -1
  37. package/dist/components/TextArea/index.d.ts +28 -18
  38. package/dist/components/TextArea/index.d.ts.map +1 -1
  39. package/dist/components/TextField/index.d.ts +32 -19
  40. package/dist/components/TextField/index.d.ts.map +1 -1
  41. package/dist/core/SSRProvider.d.ts +3 -1
  42. package/dist/core/SSRProvider.d.ts.map +1 -1
  43. package/dist/index.cjs.js +471 -845
  44. package/dist/index.cjs.js.map +1 -1
  45. package/dist/index.css +732 -28
  46. package/dist/index.css.map +1 -1
  47. package/dist/index.d.ts +2 -3
  48. package/dist/index.d.ts.map +1 -1
  49. package/dist/index.esm.js +427 -800
  50. package/dist/index.esm.js.map +1 -1
  51. package/dist/styled.d.ts +4 -4
  52. package/package.json +11 -10
  53. package/src/_lib/useClassNames.ts +3 -9
  54. package/src/components/Button/__snapshots__/index.story.storyshot +9 -9
  55. package/src/components/Button/index.story.tsx +1 -1
  56. package/src/components/Checkbox/CheckboxInput/__snapshots__/index.story.storyshot +77 -0
  57. package/src/components/Checkbox/CheckboxInput/index.css +111 -0
  58. package/src/components/{CheckboxInput → Checkbox/CheckboxInput}/index.story.tsx +17 -1
  59. package/src/components/Checkbox/CheckboxInput/index.tsx +47 -0
  60. package/src/components/Checkbox/CheckboxWithLabel.tsx +24 -0
  61. package/src/components/Checkbox/__snapshots__/index.story.storyshot +59 -140
  62. package/src/components/Checkbox/index.css +2 -2
  63. package/src/components/Checkbox/index.story.tsx +18 -13
  64. package/src/components/Checkbox/index.tsx +23 -15
  65. package/src/components/Clickable/__snapshots__/index.story.storyshot +4 -80
  66. package/src/components/Clickable/index.css +41 -0
  67. package/src/components/Clickable/index.story.tsx +2 -2
  68. package/src/components/Clickable/index.tsx +25 -85
  69. package/src/components/DropdownSelector/ListItem/__snapshots__/index.story.storyshot +11 -136
  70. package/src/components/DropdownSelector/ListItem/index.story.tsx +1 -1
  71. package/src/components/DropdownSelector/MenuList/__snapshots__/index.story.storyshot +3 -3
  72. package/src/components/DropdownSelector/MenuList/index.story.tsx +1 -1
  73. package/src/components/DropdownSelector/Popover/__snapshots__/index.story.storyshot +1 -1
  74. package/src/components/DropdownSelector/Popover/index.story.tsx +1 -1
  75. package/src/components/DropdownSelector/__snapshots__/index.story.storyshot +184 -1435
  76. package/src/components/DropdownSelector/index.story.tsx +2 -2
  77. package/src/components/DropdownSelector/index.tsx +9 -38
  78. package/src/components/FieldLabel/index.css +35 -0
  79. package/src/components/FieldLabel/index.tsx +15 -105
  80. package/src/components/Icon/__snapshots__/index.story.storyshot +1 -1
  81. package/src/components/Icon/index.story.tsx +1 -1
  82. package/src/components/IconButton/__snapshots__/index.story.storyshot +15 -291
  83. package/src/components/IconButton/index.css +118 -0
  84. package/src/components/IconButton/index.story.tsx +3 -3
  85. package/src/components/IconButton/index.tsx +41 -118
  86. package/src/components/LoadingSpinner/__snapshots__/LoadingSpinnerIcon.story.storyshot +2 -17
  87. package/src/components/LoadingSpinner/__snapshots__/index.story.storyshot +44 -132
  88. package/src/components/LoadingSpinner/index.css +42 -0
  89. package/src/components/LoadingSpinner/index.story.tsx +1 -1
  90. package/src/components/LoadingSpinner/index.tsx +26 -52
  91. package/src/components/Modal/Dialog/index.css +44 -0
  92. package/src/components/Modal/Dialog/index.tsx +13 -57
  93. package/src/components/Modal/ModalPlumbing.css +40 -0
  94. package/src/components/Modal/ModalPlumbing.tsx +22 -61
  95. package/src/components/Modal/__snapshots__/index.story.storyshot +479 -1893
  96. package/src/components/Modal/index.css +36 -0
  97. package/src/components/Modal/index.story.tsx +2 -2
  98. package/src/components/Modal/index.tsx +37 -72
  99. package/src/components/Radio/__snapshots__/index.story.storyshot +55 -780
  100. package/src/components/Radio/index.css +97 -0
  101. package/src/components/Radio/index.story.tsx +2 -11
  102. package/src/components/Radio/index.test.tsx +0 -1
  103. package/src/components/Radio/index.tsx +50 -161
  104. package/src/components/SegmentedControl/__snapshots__/index.story.storyshot +32 -262
  105. package/src/components/SegmentedControl/index.css +50 -0
  106. package/src/components/SegmentedControl/index.story.tsx +1 -1
  107. package/src/components/SegmentedControl/index.tsx +20 -89
  108. package/src/components/Switch/SwitchInput/index.css +82 -0
  109. package/src/components/Switch/SwitchInput/index.tsx +40 -0
  110. package/src/components/Switch/SwitchWithLabel.tsx +24 -0
  111. package/src/components/Switch/__snapshots__/index.story.storyshot +33 -536
  112. package/src/components/Switch/index.css +23 -0
  113. package/src/components/Switch/index.story.tsx +6 -1
  114. package/src/components/Switch/index.tsx +43 -140
  115. package/src/components/TagItem/__snapshots__/index.story.storyshot +161 -1138
  116. package/src/components/TagItem/index.css +140 -0
  117. package/src/components/TagItem/index.story.tsx +2 -2
  118. package/src/components/TagItem/index.tsx +76 -220
  119. package/src/components/TextArea/TextArea.story.tsx +1 -1
  120. package/src/components/TextArea/__snapshots__/TextArea.story.storyshot +214 -1368
  121. package/src/components/TextArea/index.tsx +68 -91
  122. package/src/components/TextField/TextField.story.tsx +1 -1
  123. package/src/components/TextField/__snapshots__/TextField.story.storyshot +287 -1627
  124. package/src/components/TextField/index.tsx +77 -105
  125. package/src/core/SSRProvider.tsx +12 -1
  126. package/src/index.ts +5 -8
  127. package/src/type.d.ts +6 -0
  128. package/dist/components/CheckboxInput/index.d.ts +0 -9
  129. package/dist/components/CheckboxInput/index.d.ts.map +0 -1
  130. package/dist/components/MultiSelect/context.d.ts +0 -14
  131. package/dist/components/MultiSelect/context.d.ts.map +0 -1
  132. package/dist/components/MultiSelect/index.d.ts +0 -36
  133. package/dist/components/MultiSelect/index.d.ts.map +0 -1
  134. package/src/components/CheckboxInput/__snapshots__/index.story.storyshot +0 -109
  135. package/src/components/CheckboxInput/index.css +0 -77
  136. package/src/components/CheckboxInput/index.tsx +0 -53
  137. package/src/components/MultiSelect/__snapshots__/index.story.storyshot +0 -1054
  138. package/src/components/MultiSelect/context.ts +0 -23
  139. package/src/components/MultiSelect/index.story.tsx +0 -112
  140. package/src/components/MultiSelect/index.test.tsx +0 -263
  141. package/src/components/MultiSelect/index.tsx +0 -282
@@ -3,7 +3,7 @@ import Switch from '.'
3
3
  import { Meta, StoryObj } from '@storybook/react'
4
4
 
5
5
  export default {
6
- title: 'Switch',
6
+ title: 'react/Switch',
7
7
  component: Switch,
8
8
  parameters: {
9
9
  layout: 'centered',
@@ -11,6 +11,11 @@ export default {
11
11
  } as Meta<typeof Switch>
12
12
 
13
13
  export const Default: StoryObj<typeof Switch> = {
14
+ argTypes: {
15
+ checked: { type: 'boolean' },
16
+ children: { type: 'string' },
17
+ disabled: { type: 'boolean' },
18
+ },
14
19
  render: function Render(args) {
15
20
  const [checked, setChecked] = useState(false)
16
21
  return (
@@ -1,142 +1,45 @@
1
- import { useSwitch } from '@react-aria/switch'
2
- import type { AriaSwitchProps } from '@react-types/switch'
3
- import { useMemo, memo, forwardRef } from 'react'
4
- import * as React from 'react'
5
- import { useToggleState } from 'react-stately'
6
- import styled from 'styled-components'
7
- import { useObjectRef } from '@react-aria/utils'
8
- import { focusVisibleFocusRingCss } from '@charcoal-ui/styled'
9
-
10
- export type SwitchProps = {
11
- name: string
12
- className?: string
13
- value?: string
14
- checked?: boolean
15
- disabled?: boolean
16
- onChange(checked: boolean): void
17
- } & (
18
- | // children か label は片方が必須
19
- {
20
- children: React.ReactNode
21
- }
22
- | {
23
- label: string
24
- }
25
- )
26
-
27
- const SwitchCheckbox = forwardRef<HTMLInputElement, SwitchProps>(
28
- function SwitchCheckboxInner(props, external) {
29
- const { disabled, className } = props
30
-
31
- const ariaSwitchProps: AriaSwitchProps = useMemo(
32
- () => ({
33
- ...props,
34
-
35
- // children がいない場合は aria-label をつけないといけない
36
- 'aria-label': 'children' in props ? undefined : props.label,
37
- isDisabled: props.disabled,
38
- isSelected: props.checked,
39
- }),
40
- [props]
41
- )
42
-
43
- const state = useToggleState(ariaSwitchProps)
44
- const ref = useObjectRef<HTMLInputElement>(external)
45
- const {
46
- inputProps: { className: _className, type: _type, ...rest },
47
- } = useSwitch(ariaSwitchProps, state, ref)
48
-
49
- return (
50
- <Label className={className} aria-disabled={disabled}>
51
- <SwitchInput {...rest} ref={ref} />
52
- {'children' in props ? (
53
- // eslint-disable-next-line react/destructuring-assignment
54
- <LabelInner>{props.children}</LabelInner>
55
- ) : undefined}
56
- </Label>
57
- )
58
- }
59
- )
60
-
61
- export default memo(SwitchCheckbox)
62
-
63
- const Label = styled.label`
64
- display: inline-grid;
65
- grid-template-columns: auto 1fr;
66
- align-items: center;
67
- cursor: pointer;
68
- outline: 0;
69
-
70
- &:disabled,
71
- &[aria-disabled]:not([aria-disabled='false']) {
72
- opacity: 0.32;
73
- cursor: default;
1
+ import './index.css'
2
+
3
+ import { memo, forwardRef } from 'react'
4
+ import { useId } from '@react-aria/utils'
5
+ import SwitchInput, { type SwitchInputProps } from './SwitchInput'
6
+ import { SwitchWithLabel } from './SwitchWithLabel'
7
+
8
+ export type SwitchProps = SwitchInputProps
9
+
10
+ const Switch = forwardRef<HTMLInputElement, SwitchProps>(function Switch(
11
+ { children, onChange, disabled, className, id, ...props },
12
+ ref
13
+ ) {
14
+ const htmlId = useId(id)
15
+ const noChildren = children === undefined
16
+ const input = (
17
+ <SwitchInput
18
+ {...props}
19
+ disabled={disabled}
20
+ className={noChildren ? className : undefined}
21
+ id={htmlId}
22
+ onChange={onChange}
23
+ ref={ref}
24
+ role="switch"
25
+ type="checkbox"
26
+ />
27
+ )
28
+
29
+ if (noChildren) {
30
+ return input
74
31
  }
75
- `
76
32
 
77
- const LabelInner = styled.div`
78
- font-size: 14px;
79
- line-height: 22px;
80
- color: var(--charcoal-text2);
81
- margin-left: 4px;
82
- `
83
-
84
- const SwitchInput = styled.input.attrs({ type: 'checkbox' })`
85
- appearance: none;
86
- display: inline-flex;
87
- position: relative;
88
- box-sizing: border-box;
89
- width: 28px;
90
- border: 2px solid transparent;
91
-
92
- transition-property: background-color, box-shadow;
93
- transition-duration: 0.2s;
94
- cursor: inherit;
95
-
96
- outline: none;
97
- border-radius: 16px;
98
- height: 16px;
99
- margin: 0;
100
- background-color: var(--charcoal-text4);
101
- :hover {
102
- background-color: var(--charcoal-text4-hover);
103
- }
104
- :active {
105
- background-color: var(--charcoal-text4-press);
106
- }
107
- ${focusVisibleFocusRingCss}
108
-
109
- &::after {
110
- content: '';
111
- position: absolute;
112
- display: block;
113
- top: 0;
114
- left: 0;
115
- width: 12px;
116
- height: 12px;
117
- transform: translateX(0);
118
- transition: transform 0.2s;
119
- border-radius: 1024px;
120
- background-color: var(--charcoal-text5);
121
- :hover {
122
- background-color: var(--charcoal-text5-hover);
123
- }
124
- :active {
125
- background-color: var(--charcoal-text5-press);
126
- }
127
- }
128
-
129
- &:checked {
130
- background-color: var(--charcoal-brand);
131
- :hover {
132
- background-color: var(--charcoal-brand-hover);
133
- }
134
- :active {
135
- background-color: var(--charcoal-brand-press);
136
- }
137
- &::after {
138
- transform: translateX(12px);
139
- transition: transform 0.2s;
140
- }
141
- }
142
- `
33
+ return (
34
+ <SwitchWithLabel
35
+ className={className}
36
+ disabled={disabled}
37
+ id={htmlId}
38
+ input={input}
39
+ >
40
+ {children}
41
+ </SwitchWithLabel>
42
+ )
43
+ })
44
+
45
+ export default memo(Switch)