@dhis2-ui/button 8.16.0-alpha.1 → 8.16.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -183,8 +183,10 @@ DropdownButton.propTypes = {
183
183
  component: _propTypes2.default.element,
184
184
  dataTest: _propTypes2.default.string,
185
185
 
186
- /** Button variant. Mutually exclusive with `primary` and `secondary` props */
187
- destructive: _uiConstants.sharedPropTypes.buttonVariantPropType,
186
+ /**
187
+ * Applies 'destructive' button appearance, implying a dangerous action.
188
+ */
189
+ destructive: _propTypes2.default.bool,
188
190
 
189
191
  /** Make the button non-interactive */
190
192
  disabled: _propTypes2.default.bool,
@@ -200,11 +202,15 @@ DropdownButton.propTypes = {
200
202
  /** Controls popper visibility. When implementing this prop the component becomes a controlled component */
201
203
  open: _propTypes2.default.bool,
202
204
 
203
- /** Button variant. Mutually exclusive with `destructive` and `secondary` props */
204
- primary: _uiConstants.sharedPropTypes.buttonVariantPropType,
205
+ /**
206
+ * Applies 'primary' button appearance, implying the most important action.
207
+ */
208
+ primary: _propTypes2.default.bool,
205
209
 
206
- /** Button variant. Mutually exclusive with `primary` and `destructive` props */
207
- secondary: _uiConstants.sharedPropTypes.buttonVariantPropType,
210
+ /**
211
+ * Applies 'secondary' button appearance.
212
+ */
213
+ secondary: _propTypes2.default.bool,
208
214
 
209
215
  /** Button size. Mutually exclusive with `large` prop */
210
216
  small: _uiConstants.sharedPropTypes.sizePropType,
@@ -146,8 +146,10 @@ SplitButton.propTypes = {
146
146
  component: _propTypes.default.element,
147
147
  dataTest: _propTypes.default.string,
148
148
 
149
- /** Applies 'destructive' appearance to indicate purpose. Mutually exclusive with `primary` and `secondary` props */
150
- destructive: _uiConstants.sharedPropTypes.buttonVariantPropType,
149
+ /**
150
+ * Applies 'destructive' button appearance, implying a dangerous action.
151
+ */
152
+ destructive: _propTypes.default.bool,
151
153
 
152
154
  /** Disables the button and makes it uninteractive */
153
155
  disabled: _propTypes.default.bool,
@@ -162,11 +164,15 @@ SplitButton.propTypes = {
162
164
  large: _uiConstants.sharedPropTypes.sizePropType,
163
165
  name: _propTypes.default.string,
164
166
 
165
- /** Applies 'primary' appearance to indicate purpose. Mutually exclusive with `destructive` and `secondary` props */
166
- primary: _uiConstants.sharedPropTypes.buttonVariantPropType,
167
+ /**
168
+ * Applies 'primary' button appearance, implying the most important action.
169
+ */
170
+ primary: _propTypes.default.bool,
167
171
 
168
- /** Applies 'secondary' appearance to indicate purpose. Mutually exclusive with `primary` and `destructive` props */
169
- secondary: _uiConstants.sharedPropTypes.buttonVariantPropType,
172
+ /**
173
+ * Applies 'secondary' button appearance.
174
+ */
175
+ secondary: _propTypes.default.bool,
170
176
 
171
177
  /** Changes button size. Mutually exclusive with `large` prop */
172
178
  small: _uiConstants.sharedPropTypes.sizePropType,
@@ -163,8 +163,10 @@ DropdownButton.propTypes = {
163
163
  component: PropTypes.element,
164
164
  dataTest: PropTypes.string,
165
165
 
166
- /** Button variant. Mutually exclusive with `primary` and `secondary` props */
167
- destructive: sharedPropTypes.buttonVariantPropType,
166
+ /**
167
+ * Applies 'destructive' button appearance, implying a dangerous action.
168
+ */
169
+ destructive: PropTypes.bool,
168
170
 
169
171
  /** Make the button non-interactive */
170
172
  disabled: PropTypes.bool,
@@ -180,11 +182,15 @@ DropdownButton.propTypes = {
180
182
  /** Controls popper visibility. When implementing this prop the component becomes a controlled component */
181
183
  open: PropTypes.bool,
182
184
 
183
- /** Button variant. Mutually exclusive with `destructive` and `secondary` props */
184
- primary: sharedPropTypes.buttonVariantPropType,
185
+ /**
186
+ * Applies 'primary' button appearance, implying the most important action.
187
+ */
188
+ primary: PropTypes.bool,
185
189
 
186
- /** Button variant. Mutually exclusive with `primary` and `destructive` props */
187
- secondary: sharedPropTypes.buttonVariantPropType,
190
+ /**
191
+ * Applies 'secondary' button appearance.
192
+ */
193
+ secondary: PropTypes.bool,
188
194
 
189
195
  /** Button size. Mutually exclusive with `large` prop */
190
196
  small: sharedPropTypes.sizePropType,
@@ -124,8 +124,10 @@ SplitButton.propTypes = {
124
124
  component: PropTypes.element,
125
125
  dataTest: PropTypes.string,
126
126
 
127
- /** Applies 'destructive' appearance to indicate purpose. Mutually exclusive with `primary` and `secondary` props */
128
- destructive: sharedPropTypes.buttonVariantPropType,
127
+ /**
128
+ * Applies 'destructive' button appearance, implying a dangerous action.
129
+ */
130
+ destructive: PropTypes.bool,
129
131
 
130
132
  /** Disables the button and makes it uninteractive */
131
133
  disabled: PropTypes.bool,
@@ -140,11 +142,15 @@ SplitButton.propTypes = {
140
142
  large: sharedPropTypes.sizePropType,
141
143
  name: PropTypes.string,
142
144
 
143
- /** Applies 'primary' appearance to indicate purpose. Mutually exclusive with `destructive` and `secondary` props */
144
- primary: sharedPropTypes.buttonVariantPropType,
145
+ /**
146
+ * Applies 'primary' button appearance, implying the most important action.
147
+ */
148
+ primary: PropTypes.bool,
145
149
 
146
- /** Applies 'secondary' appearance to indicate purpose. Mutually exclusive with `primary` and `destructive` props */
147
- secondary: sharedPropTypes.buttonVariantPropType,
150
+ /**
151
+ * Applies 'secondary' button appearance.
152
+ */
153
+ secondary: PropTypes.bool,
148
154
 
149
155
  /** Changes button size. Mutually exclusive with `large` prop */
150
156
  small: sharedPropTypes.sizePropType,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dhis2-ui/button",
3
- "version": "8.16.0-alpha.1",
3
+ "version": "8.16.0",
4
4
  "description": "UI Button",
5
5
  "repository": {
6
6
  "type": "git",
@@ -13,7 +13,6 @@
13
13
  "main": "./build/cjs/index.js",
14
14
  "module": "./build/es/index.js",
15
15
  "exports": {
16
- "types": "./types/index.d.ts",
17
16
  "import": "./build/es/index.js",
18
17
  "require": "./build/cjs/index.js"
19
18
  },
@@ -33,22 +32,20 @@
33
32
  },
34
33
  "dependencies": {
35
34
  "@dhis2/prop-types": "^3.1.2",
36
- "@dhis2-ui/layer": "8.16.0-alpha.1",
37
- "@dhis2-ui/loader": "8.16.0-alpha.1",
38
- "@dhis2-ui/popper": "8.16.0-alpha.1",
39
- "@dhis2/ui-constants": "8.16.0-alpha.1",
40
- "@dhis2/ui-icons": "8.16.0-alpha.1",
35
+ "@dhis2-ui/layer": "8.16.0",
36
+ "@dhis2-ui/loader": "8.16.0",
37
+ "@dhis2-ui/popper": "8.16.0",
38
+ "@dhis2/ui-constants": "8.16.0",
39
+ "@dhis2/ui-icons": "8.16.0",
41
40
  "classnames": "^2.3.1",
42
41
  "prop-types": "^15.7.2"
43
42
  },
44
43
  "files": [
45
- "build",
46
- "types"
44
+ "build"
47
45
  ],
48
46
  "devDependencies": {
49
47
  "react": "16.13",
50
48
  "react-dom": "16.13",
51
49
  "styled-jsx": "^4.0.1"
52
- },
53
- "types": "types"
50
+ }
54
51
  }
package/types/index.d.ts DELETED
@@ -1,256 +0,0 @@
1
- import * as React from 'react'
2
-
3
- export type ButtonType = 'submit' | 'reset' | 'button'
4
-
5
- export interface ButtonEventPayload {
6
- value?: string
7
- name?: string
8
- }
9
-
10
- type ButtonEventHandler<Event extends React.SyntheticEvent> = (
11
- arg0: ButtonEventPayload,
12
- event: Event
13
- ) => void
14
-
15
- type ButtonOpenEventHandler<
16
- Event extends React.SyntheticEvent = React.MouseEvent<HTMLButtonElement>
17
- > = (arg0: ButtonEventPayload & { open: boolean }, event: Event) => void
18
-
19
- export interface ButtonProps {
20
- /**
21
- * Component to render inside the button
22
- */
23
- children?: React.ReactNode
24
- /**
25
- * A className that will be passed to the `<button>` element
26
- */
27
- className?: string
28
- /**
29
- * A string that will be applied as a `data-test` attribute on the button element
30
- * for identification during testing
31
- */
32
- dataTest?: string
33
- /**
34
- * Indicates that the button makes potentially dangerous
35
- * deletions or data changes.
36
- * Mutually exclusive with `primary` and `secondary` props
37
- */
38
- destructive?: boolean
39
- /**
40
- * Applies a greyed-out appearance and makes the button non-interactive
41
- */
42
- disabled?: boolean
43
- /**
44
- * An icon element to display inside the button
45
- */
46
- icon?: React.ReactElement
47
- /**
48
- * Use this variant to capture the initial focus on the page.
49
- */
50
- initialFocus?: boolean
51
- /**
52
- * Makes the button large. Mutually exclusive with `small`
53
- */
54
- large?: boolean
55
- /**
56
- * Sets the button into a loading state
57
- */
58
- loading?: boolean
59
- /**
60
- * Sets `name` attribute on button element.
61
- * Gets passed as part of the first argument to callbacks (see `onClick`).
62
- */
63
- name?: string
64
- /**
65
- * Applies 'primary' button appearance.
66
- * Mutually exclusive with `destructive` and `secondary` props
67
- */
68
- primary?: boolean
69
- /**
70
- * Applies 'secondary' button appearance.
71
- * Mutually exclusive with `primary` and `destructive` props
72
- */
73
- secondary?: boolean
74
- /**
75
- * Makes the button small. Mutually exclusive with `large` prop
76
- */
77
- small?: boolean
78
- /**
79
- * Tab index for focusing the button with a keyboard
80
- */
81
- tabIndex?: string
82
- /**
83
- * Changes appearance of button to an on/off state
84
- */
85
- toggled?: boolean
86
- /**
87
- * Sets `type` attribute on `<button>` element
88
- */
89
- type?: ButtonType
90
- /**
91
- * Value associated with the button.
92
- * Gets passed as part of the first argument to callbacks (see `onClick`).
93
- */
94
- value?: string
95
- /**
96
- * Callback to trigger on de-focus (blur).
97
- * Called with same args as `onClick`
98
- */
99
- onBlur?: ButtonEventHandler<React.FocusEvent<HTMLButtonElement>>
100
- /**
101
- * Callback to trigger on click.
102
- * Called with args `({ value, name }, event)`
103
- */
104
- onClick?: ButtonEventHandler<React.MouseEvent<HTMLButtonElement>>
105
- /**
106
- * Callback to trigger on focus. Called with same args as `onClick`
107
- */
108
- onFocus?: ButtonEventHandler<React.FocusEvent<HTMLButtonElement>>
109
- /**
110
- * Callback to trigger on key-down. Called with same args as `onClick`
111
- */
112
- onKeyDown?: ButtonEventHandler<React.KeyboardEvent<HTMLButtonElement>>
113
- }
114
-
115
- export const Button: React.FC<ButtonProps>
116
-
117
- export interface ButtonStripProps {
118
- children?: React.ReactNode
119
- className?: string
120
- dataTest?: string
121
- /**
122
- * Horizontal alignment for buttons. Mutually exclusive with `middle` prop
123
- */
124
- end?: boolean
125
- /**
126
- * Horizontal alignment. Mutually exclusive with `end` prop
127
- */
128
- middle?: boolean
129
- }
130
-
131
- export const ButtonStrip: React.FC<ButtonStripProps>
132
-
133
- export type DropdownButtonType = 'submit' | 'reset' | 'button'
134
-
135
- export interface DropdownButtonProps {
136
- /**
137
- * Children to render inside the buton
138
- */
139
- children?: React.ReactNode
140
- className?: string
141
- /**
142
- * Component to show/hide when button is clicked
143
- */
144
- component?: React.ReactElement<any>
145
- dataTest?: string
146
- /**
147
- * Button variant. Mutually exclusive with `primary` and `secondary` props
148
- */
149
- destructive?: boolean
150
- /**
151
- * Make the button non-interactive
152
- */
153
- disabled?: boolean
154
- icon?: React.ReactElement<any>
155
- /**
156
- * Grants button initial focus on the page
157
- */
158
- initialFocus?: boolean
159
- /**
160
- * Button size. Mutually exclusive with `small` prop
161
- */
162
- large?: boolean
163
- name?: string
164
- /**
165
- * Controls popper visibility. When implementing this prop the component becomes a controlled component
166
- */
167
- open?: boolean
168
- /**
169
- * Button variant. Mutually exclusive with `destructive` and `secondary` props
170
- */
171
- primary?: boolean
172
- /**
173
- * Button variant. Mutually exclusive with `primary` and `destructive` props
174
- */
175
- secondary?: boolean
176
- /**
177
- * Button size. Mutually exclusive with `large` prop
178
- */
179
- small?: boolean
180
- tabIndex?: string
181
- /**
182
- * Type of button. Can take advantage of different default behavior
183
- */
184
- type?: DropdownButtonType
185
- value?: string
186
- /**
187
- * Callback triggered on click.
188
- * Called with signature `({ name: string, value: string, open: bool }, event)`
189
- * Is required when using the `open` prop to override the internal
190
- * state.
191
- */
192
- onClick?: ButtonOpenEventHandler
193
- }
194
-
195
- export class DropdownButton extends React.Component<DropdownButtonProps, any> {
196
- render(): JSX.Element
197
- }
198
-
199
- export type SplitButtonType = 'submit' | 'reset' | 'button'
200
-
201
- export interface SplitButtonProps {
202
- children?: string
203
- className?: string
204
- /**
205
- * Component to render when the dropdown is opened
206
- */
207
- component?: React.ReactElement<any>
208
- dataTest?: string
209
- /**
210
- * Applies 'destructive' appearance to indicate purpose. Mutually exclusive with `primary` and `secondary` props
211
- */
212
- destructive?: boolean
213
- /**
214
- * Disables the button and makes it uninteractive
215
- */
216
- disabled?: boolean
217
- /**
218
- * An icon to add inside the button
219
- */
220
- icon?: React.ReactElement<any>
221
- /**
222
- * Grants the button the initial focus
223
- */
224
- initialFocus?: boolean
225
- /**
226
- * Changes button size. Mutually exclusive with `small` prop
227
- */
228
- large?: boolean
229
- name?: string
230
- /**
231
- * Applies 'primary' appearance to indicate purpose. Mutually exclusive with `destructive` and `secondary` props
232
- */
233
- primary?: boolean
234
- /**
235
- * Applies 'secondary' appearance to indicate purpose. Mutually exclusive with `primary` and `destructive` props
236
- */
237
- secondary?: boolean
238
- /**
239
- * Changes button size. Mutually exclusive with `large` prop
240
- */
241
- small?: boolean
242
- tabIndex?: string
243
- /**
244
- * Type of button. Applied to html `button` element
245
- */
246
- type?: SplitButtonType
247
- /**
248
- * Value associated with the button. Passed in object to onClick handler
249
- */
250
- value?: string
251
- onClick?: ButtonOpenEventHandler
252
- }
253
-
254
- export class SplitButton extends React.Component<SplitButtonProps, any> {
255
- render(): JSX.Element
256
- }